]> git.vomp.tv Git - vompclient.git/blob - directory.cc
Preparations for dynamic mode switching
[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 void Directory::sort(bool chronoSortOrder)
73 {
74   // Sort the directory order
75   ::sort(dirList.begin(), dirList.end(), DirectorySorter());
76
77   // Sort the recordings order
78   if (chronoSortOrder)
79     ::sort(recList.begin(), recList.end(), RecordingSorterChrono());
80   else
81     ::sort(recList.begin(), recList.end(), RecordingSorterAlpha());
82
83   // Now get the dirs to sort themselves! oh I love recursion.
84   for(UINT i = 0; i < dirList.size(); i++) dirList[i]->sort(chronoSortOrder);
85 }