mirror of
https://github.com/transmission/transmission
synced 2025-01-18 21:09:55 +00:00
refactor: reduce use of tr_malloc / tr_free (#3652)
* refactor: avoid tr_new in macos Torrent.trashDataFile * refactor: avoid tr_new in maco PiecesView * refactor: avoid tr_new in qt createVariant()
This commit is contained in:
parent
293f4f6759
commit
6278ea7017
3 changed files with 22 additions and 26 deletions
|
@ -2,6 +2,8 @@
|
||||||
// It may be used under the MIT (SPDX: MIT) license.
|
// It may be used under the MIT (SPDX: MIT) license.
|
||||||
// License text can be found in the licenses/ folder.
|
// License text can be found in the licenses/ folder.
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include <libtransmission/transmission.h>
|
#include <libtransmission/transmission.h>
|
||||||
#include <libtransmission/utils.h>
|
#include <libtransmission/utils.h>
|
||||||
|
|
||||||
|
@ -26,7 +28,7 @@ enum
|
||||||
|
|
||||||
@interface PiecesView ()
|
@interface PiecesView ()
|
||||||
|
|
||||||
@property(nonatomic) int8_t* fPieces;
|
@property(nonatomic) std::vector<int8_t> fPieces;
|
||||||
|
|
||||||
@property(nonatomic) NSInteger fNumPieces;
|
@property(nonatomic) NSInteger fNumPieces;
|
||||||
@property(nonatomic) NSInteger fAcross;
|
@property(nonatomic) NSInteger fAcross;
|
||||||
|
@ -57,7 +59,6 @@ enum
|
||||||
|
|
||||||
- (void)dealloc
|
- (void)dealloc
|
||||||
{
|
{
|
||||||
tr_free(_fPieces);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)setTorrent:(Torrent*)torrent
|
- (void)setTorrent:(Torrent*)torrent
|
||||||
|
@ -84,8 +85,7 @@ enum
|
||||||
|
|
||||||
- (void)clearView
|
- (void)clearView
|
||||||
{
|
{
|
||||||
tr_free(self.fPieces);
|
self.fPieces.clear();
|
||||||
self.fPieces = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)updateView
|
- (void)updateView
|
||||||
|
@ -96,25 +96,25 @@ enum
|
||||||
}
|
}
|
||||||
|
|
||||||
//determine if first time
|
//determine if first time
|
||||||
BOOL const first = self.fPieces == NULL;
|
BOOL const first = std::empty(self.fPieces);
|
||||||
if (first)
|
if (first)
|
||||||
{
|
{
|
||||||
self.fPieces = (int8_t*)tr_malloc(self.fNumPieces * sizeof(int8_t));
|
self.fPieces.resize(self.fNumPieces);
|
||||||
}
|
}
|
||||||
|
|
||||||
int8_t* pieces = NULL;
|
auto pieces = std::vector<int8_t>{};
|
||||||
float* piecesPercent = NULL;
|
auto piecesPercent = std::vector<float>{};
|
||||||
|
|
||||||
BOOL const showAvailability = [NSUserDefaults.standardUserDefaults boolForKey:@"PiecesViewShowAvailability"];
|
BOOL const showAvailability = [NSUserDefaults.standardUserDefaults boolForKey:@"PiecesViewShowAvailability"];
|
||||||
if (showAvailability)
|
if (showAvailability)
|
||||||
{
|
{
|
||||||
pieces = (int8_t*)tr_malloc(self.fNumPieces * sizeof(int8_t));
|
pieces.resize(self.fNumPieces);
|
||||||
[self.torrent getAvailability:pieces size:self.fNumPieces];
|
[self.torrent getAvailability:std::data(pieces) size:std::size(pieces)];
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
piecesPercent = (float*)tr_malloc(self.fNumPieces * sizeof(float));
|
piecesPercent.resize(self.fNumPieces);
|
||||||
[self.torrent getAmountFinished:piecesPercent size:self.fNumPieces];
|
[self.torrent getAmountFinished:std::data(piecesPercent) size:std::size(piecesPercent)];
|
||||||
}
|
}
|
||||||
|
|
||||||
NSImage* image = self.image;
|
NSImage* image = self.image;
|
||||||
|
@ -193,9 +193,6 @@ enum
|
||||||
[image unlockFocus];
|
[image unlockFocus];
|
||||||
[self setNeedsDisplay];
|
[self setNeedsDisplay];
|
||||||
}
|
}
|
||||||
|
|
||||||
tr_free(pieces);
|
|
||||||
tr_free(piecesPercent);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)acceptsFirstMouse:(NSEvent*)event
|
- (BOOL)acceptsFirstMouse:(NSEvent*)event
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
// License text can be found in the licenses/ folder.
|
// License text can be found in the licenses/ folder.
|
||||||
|
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include <fmt/format.h>
|
#include <fmt/format.h>
|
||||||
|
|
||||||
|
@ -1535,14 +1536,14 @@ bool trashDataFile(char const* filename, tr_error** error)
|
||||||
- (void)setFilePriority:(tr_priority_t)priority forIndexes:(NSIndexSet*)indexSet
|
- (void)setFilePriority:(tr_priority_t)priority forIndexes:(NSIndexSet*)indexSet
|
||||||
{
|
{
|
||||||
NSUInteger const count = indexSet.count;
|
NSUInteger const count = indexSet.count;
|
||||||
tr_file_index_t* files = static_cast<tr_file_index_t*>(tr_malloc(count * sizeof(tr_file_index_t)));
|
auto files = std::vector<tr_file_index_t>{};
|
||||||
|
files.resize(count);
|
||||||
for (NSUInteger index = indexSet.firstIndex, i = 0; index != NSNotFound; index = [indexSet indexGreaterThanIndex:index], i++)
|
for (NSUInteger index = indexSet.firstIndex, i = 0; index != NSNotFound; index = [indexSet indexGreaterThanIndex:index], i++)
|
||||||
{
|
{
|
||||||
files[i] = index;
|
files[i] = index;
|
||||||
}
|
}
|
||||||
|
|
||||||
tr_torrentSetFilePriorities(self.fHandle, files, count, priority);
|
tr_torrentSetFilePriorities(self.fHandle, std::data(files), std::size(files), priority);
|
||||||
tr_free(files);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
- (BOOL)hasFilePriority:(tr_priority_t)priority forIndexes:(NSIndexSet*)indexSet
|
- (BOOL)hasFilePriority:(tr_priority_t)priority forIndexes:(NSIndexSet*)indexSet
|
||||||
|
|
|
@ -16,7 +16,6 @@
|
||||||
|
|
||||||
#include <libtransmission/rpcimpl.h>
|
#include <libtransmission/rpcimpl.h>
|
||||||
#include <libtransmission/transmission.h>
|
#include <libtransmission/transmission.h>
|
||||||
#include <libtransmission/utils.h> // tr_free
|
|
||||||
#include <libtransmission/version.h> // LONG_VERSION_STRING
|
#include <libtransmission/version.h> // LONG_VERSION_STRING
|
||||||
|
|
||||||
#include "VariantHelpers.h"
|
#include "VariantHelpers.h"
|
||||||
|
@ -31,15 +30,14 @@ namespace
|
||||||
char const constexpr* const RequestDataPropertyKey{ "requestData" };
|
char const constexpr* const RequestDataPropertyKey{ "requestData" };
|
||||||
char const constexpr* const RequestFutureinterfacePropertyKey{ "requestReplyFutureInterface" };
|
char const constexpr* const RequestFutureinterfacePropertyKey{ "requestReplyFutureInterface" };
|
||||||
|
|
||||||
void destroyVariant(tr_variant* json)
|
|
||||||
{
|
|
||||||
tr_variantFree(json);
|
|
||||||
tr_free(json);
|
|
||||||
}
|
|
||||||
|
|
||||||
TrVariantPtr createVariant()
|
TrVariantPtr createVariant()
|
||||||
{
|
{
|
||||||
return { tr_new0(tr_variant, 1), &destroyVariant };
|
return { new tr_variant{},
|
||||||
|
[](tr_variant* var)
|
||||||
|
{
|
||||||
|
tr_variantFree(var);
|
||||||
|
delete var;
|
||||||
|
} };
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
Loading…
Reference in a new issue