blob: dbd331257e1daab7eca0f3a5b663649f696ff0c3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
|
/* HBJobOutputFileWriter.h $
This file is part of the HandBrake source code.
Homepage: <http://handbrake.fr/>.
It may be used under the terms of the GNU General Public License. */
#import "HBJobOutputFileWriter.h"
#import "HBJob.h"
#import "HBUtilities.h"
#import "HBPreferencesKeys.h"
@interface HBJobOutputFileWriter ()
@property (nonatomic, readonly) NSURL *outputFolderURL;
@property (nonatomic, readwrite) BOOL accessingSecurityScopedFile;
@end
@implementation HBJobOutputFileWriter
- (nullable instancetype)initWithJob:(HBJob *)job
{
// Establish the log file location to write to.
// We need to get the current time in YY-MM-DD HH-MM-SS format to put at the beginning of the name of the log file
time_t _now = time(NULL);
struct tm *now = localtime(&_now);
NSString *dateForLogTitle = [NSString stringWithFormat:@"%02d-%02d-%02d %02d-%02d-%02d",
now->tm_year + 1900,
now->tm_mon + 1,
now->tm_mday,now->tm_hour,
now->tm_min, now->tm_sec];
// Assemble the new log file name as YY-MM-DD HH-MM-SS mymoviename.txt
NSString *outputDateFileName = [NSString stringWithFormat:@"%@ %@.txt",
job.outputFileName.stringByDeletingPathExtension,
dateForLogTitle];
NSURL *outputURL = nil;
if ([NSUserDefaults.standardUserDefaults boolForKey:HBEncodeLogLocation])
{
// if we are putting it in the same directory with the movie
outputURL = [job.outputURL URLByAppendingPathComponent:outputDateFileName];
#ifdef __SANDBOX_ENABLED__
_outputFolderURL = job.outputURL;
_accessingSecurityScopedFile = [_outputFolderURL startAccessingSecurityScopedResource];
#endif
}
else
{
// if we are putting it in the default ~/Libraries/Application Support/HandBrake/EncodeLogs logs directory
NSURL *encodeLogDirectory = [[HBUtilities appSupportURL] URLByAppendingPathComponent:@"EncodeLogs"];
outputURL = [encodeLogDirectory URLByAppendingPathComponent:outputDateFileName];
}
self = [super initWithFileURL:outputURL];
if (self)
{
// Additional header info.
[self write:job.outputFileName];
[self write:@"\nPreset: "];
[self write:job.presetName];
[self write:@"\n"];
}
return self;
}
- (void)dealloc
{
#ifdef __SANDBOX_ENABLED__
if (_accessingSecurityScopedFile)
{
[_outputFolderURL.URLByDeletingLastPathComponent stopAccessingSecurityScopedResource];
}
#endif
}
@end
|