blob: 7f2f3d020af4b871188862a3ecbf2cb3c31e9a8a (
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
|
/* 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"
@implementation HBJobOutputFileWriter
- (nullable instancetype)initWithJob:(HBJob *)job
{
NSURL *outputURL= job.destURL;
// 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",
outputURL.lastPathComponent.stringByDeletingPathExtension,
dateForLogTitle];
if ([[NSUserDefaults standardUserDefaults] boolForKey:@"EncodeLogLocation"])
{
// if we are putting it in the same directory with the movie
outputURL = [outputURL.URLByDeletingLastPathComponent URLByAppendingPathComponent:outputDateFileName];
}
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.destURL.lastPathComponent];
[self write:@"\nPreset: "];
[self write:job.presetName];
[self write:@"\n"];
}
return self;
}
@end
|