blob: 55b24b7a1d6f620f62c27662f04d787ca30fd1fc (
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
|
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace HandBrakeWPF.Utilities.Input
{
using System.IO;
using HandBrakeWPF.Helpers;
/// <summary>
/// Imports chapter markers in the ChaptersDb.org TXT format
/// More info: http://www.chapterdb.org/docs
/// </summary>
public class ChapterImporterTxt
{
/// <summary>
/// The file filter value for the OpenFileDialog
/// </summary>
public static string FileFilter => "Text files (*.txt)|*.txt";
/// <summary>
/// Imports all chapter information from the given <see cref="filename"/> into the <see cref="chapterMap"/> dictionary.
/// </summary>
/// <param name="filename">The full path and filename of the chapter marker file to import</param>
/// <param name="chapterMap">The dictionary that should be populated with parsed chapter markers</param>
public static void Import(string filename, ref Dictionary<int, Tuple<string, TimeSpan>> chapterMap)
{
using (var file = new StreamReader(filename))
{
// Indexing is 1-based
int chapterMapIdx = 1;
TimeSpan prevChapterStart = TimeSpan.Zero;
while (!file.EndOfStream)
{
// Read the lines in pairs, the duration is always first then the chapter name
var chapterStartRaw = file.ReadLine();
var chapterName = file.ReadLine();
// If either of the values is null then the end of the file has been reached and we need to terminate
if (chapterName == null || chapterStartRaw == null)
break;
// Split the values on '=' and take the left side
chapterName = chapterName.Split(new []{ '=' }, 2).LastOrDefault();
chapterStartRaw = chapterStartRaw.Split(new[] { '=' }, 2).LastOrDefault();
// Parse the time
if(!string.IsNullOrWhiteSpace(chapterStartRaw))
{
var chapterStart = TimeSpanHelper.ParseChapterTimeStart(chapterStartRaw);
// If we're past the first chapter in the file then calculate the duration for the previous chapter
if (chapterMapIdx > 1)
{
var old = chapterMap[chapterMapIdx - 1];
chapterMap[chapterMapIdx - 1] = new Tuple<string, TimeSpan>(old.Item1, chapterStart - prevChapterStart);
}
prevChapterStart = chapterStart;
}
// Save the chapter info, we calculate the duration in the next iteration (look back)
chapterMap[chapterMapIdx++] = new Tuple<string, TimeSpan>(chapterName, TimeSpan.Zero);
}
}
}
}
}
|