]> git.vomp.tv Git - vompclient.git/blob - directory.cc
dvbsubtitles fixup part 2
[vompclient.git] / directory.cc
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19 */
20
21 #include "directory.h"
22
23 Directory::Directory(const char* newName)
24 {
25   index = -1;
26
27   name = new char[strlen(newName) + 1];
28   strcpy(name, newName);
29
30   parent = NULL;
31 }
32
33 Directory::~Directory()
34 {
35   if (name) delete[] name;
36   name = NULL;
37   index = -1; // just in case
38   UINT i;
39
40   for (i = 0; i < dirList.size(); i++)
41   {
42     delete dirList[i];
43   }
44   dirList.clear();
45
46   for (i = 0; i < recList.size(); i++)
47   {
48     delete recList[i];
49   }
50   recList.clear();
51 }
52
53 Directory* Directory::getDirByName(char* dirName)
54 {
55   for(UINT i = 0; i < dirList.size(); i++)
56   {
57     if (!strcmp(dirName, dirList[i]->name)) return dirList[i];
58   }
59   return NULL;
60 }
61
62 ULONG Directory::getNumRecordings()
63 {
64   ULONG total = recList.size();
65   for(UINT i = 0; i < dirList.size(); i++)
66   {
67     total += dirList[i]->getNumRecordings();
68   }
69   return total;
70 }
71
72 ULONG Directory::getNumNewRecordings()
73 {
74   ULONG total = 0;
75   for (UINT i = 0; i < recList.size(); i++)
76   {
77     if (recList[i]->getNew()) ++total;
78   }
79  
80   for(UINT i = 0; i < dirList.size(); i++)
81   {
82     total += dirList[i]->getNumNewRecordings();
83   }
84   return total;
85 }
86
87 void Directory::sort(bool chronoSortOrder)
88 {
89   // Sort the directory order
90   ::sort(dirList.begin(), dirList.end(), DirectorySorter());
91
92   // Sort the recordings order
93   if (chronoSortOrder)
94     ::sort(recList.begin(), recList.end(), RecordingSorterChrono());
95   else
96     ::sort(recList.begin(), recList.end(), RecordingSorterAlpha());
97
98   // Now get the dirs to sort themselves! oh I love recursion.
99   for(UINT i = 0; i < dirList.size(); i++) dirList[i]->sort(chronoSortOrder);
100 }