]> git.vomp.tv Git - vompclient.git/blob - directory.cc
Fix line endings
[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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #include "directory.h"
22
23 Directory::Directory(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()
73 {
74   // Sort the directory order
75   ::sort(dirList.begin(), dirList.end(), DirectorySorter());
76
77   // Sort the recordings order
78   ::sort(recList.begin(), recList.end(), RecordingSorter());
79
80   // Now get the dirs to sort themselves! oh I love recursion.
81   for(UINT i = 0; i < dirList.size(); i++) dirList[i]->sort();
82 }