]> git.vomp.tv Git - vompclient.git/blob - vrecordinglist.cc
Options view files added, new remote type supported
[vompclient.git] / vrecordinglist.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 "vrecordinglist.h"
22
23 VRecordingList::VRecordingList()
24 {
25   if (Video::getInstance()->getFormat() == Video::PAL)
26   {
27     setScreenPos(80, 70);
28   }
29   else
30   {
31     setScreenPos(70, 35);
32   }
33
34   setDimensions(420, 570);
35
36   setBackgroundColour(Colour::VIEWBACKGROUND);
37   setTitleBarOn(1);
38   setTitleBarColour(Colour::TITLEBARBACKGROUND);
39
40   sl.setScreenPos(screenX + 10, screenY + 30 + 5);
41   sl.setDimensions(height - 30 - 15 - 30, width - 20);
42 }
43
44 VRecordingList::~VRecordingList()
45 {
46   // only delete the list if this is not a sub dir window
47   if (recDir->isRoot) delete recDir;
48 }
49
50 void VRecordingList::setDir(Directory* tdir)
51 {
52   recDir = tdir;
53   int first = 1;
54
55   char tempA[300]; // FIXME  this is guesswork!
56   char tempB[300]; // FIXME
57   struct tm* btime;
58
59   char spaces[13];
60   char theNumber[10];
61   int theNumberLength;
62
63   Directory* dir;
64   recDir->dirList->reset();
65   while((dir = (Directory*)recDir->dirList->getCurrent()))
66   {
67     strcpy(spaces, "            ");
68     theNumberLength = snprintf(theNumber, 9, "%lu", dir->getNumRecordings());
69
70     spaces[11 - theNumberLength] = '\0';
71
72     //snprintf(tempA, 299, "<dir>            %s", dir->name);
73     snprintf(tempA, 299, "<dir> %s%s%s", theNumber, spaces, dir->name);
74     //int numSize = snprintf(tempA
75
76     dir->index = sl.addOption(tempA, first);
77     first = 0;
78     recDir->dirList->next();
79   }
80
81   // temp FIXME
82   List* recList = recDir->recList;
83
84   // FIXME convert the whole program to time_t's
85
86
87   Recording* rec;
88   recList->reset();
89   while((rec = (Recording*)recList->getCurrent()))
90   {
91     btime = localtime((time_t*)&rec->start);
92     strftime(tempA, 299, "%0d/%0m %0H:%0M ", btime);
93     sprintf(tempB, "%s %s", tempA, rec->getProgName());
94     rec->index = sl.addOption(tempB, first);
95     first = 0;
96     recList->next();
97   }
98
99   if (!recDir->isRoot)
100   {
101     snprintf(tempA, 299, "Recordings - %s", recDir->name);
102     setTitleText(tempA);
103   }
104   else
105   {
106     setTitleText("Recordings");
107   }
108 }
109
110 void VRecordingList::draw()
111 {
112   View::draw();
113   sl.draw();
114
115   // Put the status stuff at the bottom
116
117   WSymbol w;
118
119   w.nextSymbol = WSymbol::UP;
120   w.setScreenPos(screenX + 20, screenY + 385);
121   w.draw();
122
123   w.nextSymbol = WSymbol::DOWN;
124   w.setScreenPos(screenX + 50, screenY + 385);
125   w.draw();
126
127   w.nextSymbol = WSymbol::SKIPBACK;
128   w.setScreenPos(screenX + 85, screenY + 385);
129   w.draw();
130
131   w.nextSymbol = WSymbol::SKIPFORWARD;
132   w.setScreenPos(screenX + 115, screenY + 385);
133   w.draw();
134
135   w.nextSymbol = WSymbol::PLAY;
136   w.setScreenPos(screenX + 150, screenY + 385);
137   w.draw();
138
139   // FIXME Right justify this!
140   drawText("[ok] = menu", 450, 385, Colour::LIGHTTEXT);
141
142   doShowingBar();
143
144   char freeSpace[50];
145   int gigFree = Directory::freeSpace / 1024;
146   snprintf(freeSpace, 49, "%lu%%, %iGB free", Directory::usedPercent, gigFree);
147   drawTextRJ(freeSpace, 560, 5, Colour::LIGHTTEXT);
148 }
149
150 void VRecordingList::doShowingBar()
151 {
152   int topOption = sl.getTopOption() + 1;
153   if (sl.getNumOptions() == 0) topOption = 0;
154
155   char showing[200];
156   sprintf(showing, "%i to %i of %i", topOption, sl.getBottomOption(), sl.getNumOptions());
157   Box b;
158   b.setScreenPos(screenX + 220, screenY + 385);
159   b.setDimensions(25, 160);
160   b.fillColour(Colour::VIEWBACKGROUND);
161   b.drawText(showing, 0, 0, Colour::LIGHTTEXT);
162 }
163
164
165
166 void VRecordingList::processMessage(Message* m)
167 {
168   Log::getInstance()->log("VRecordingList", Log::DEBUG, "Got message value %lu", m->message);
169   if (m->message == Message::DELETE_SELECTED_RECORDING)
170   {
171     Log::getInstance()->log("VRecordingList", Log::DEBUG, "Doing delete selected");
172     doDeleteSelected();
173     return;
174   }
175
176   if (m->message == Message::PLAY_SELECTED_RECORDING)
177   {
178     doPlay();
179     return;
180   }
181
182   if (m->message == Message::RESUME_SELECTED_RECORDING)
183   {
184     doResume();
185     return;
186   }
187 }
188
189 void VRecordingList::doDeleteSelected()
190 {
191   Recording* toDelete = getCurrentOptionRecording();
192
193   int saveIndex;
194   int saveTop;
195
196   if (toDelete)
197   {
198     saveIndex = toDelete->index;
199     saveTop = sl.getTopOption();
200     Log::getInstance()->log("VRecordingList", Log::DEBUG, "FOUND: %i %s %s\n", toDelete->index, toDelete->getProgName(), toDelete->fileName);
201     recDir->recList->remove(toDelete);
202     Log::getInstance()->log("VRecordingList", Log::DEBUG, "I have removed: %s %s\n", toDelete->getProgName(), toDelete->fileName);
203
204     VDR* vdr = VDR::getInstance();
205     vdr->deleteRecording(toDelete->fileName);
206
207     delete toDelete;
208
209     sl.clear();
210     setDir(recDir);
211     sl.hintSetCurrent(saveIndex);
212     sl.hintSetTop(saveTop);
213     draw();
214   }
215
216   Message* m2 = new Message();
217   m2->from = this;
218   m2->to = ViewMan::getInstance();
219   m2->message = Message::UPDATE_SCREEN;
220   ViewMan::getInstance()->postMessage(m2);
221 }
222
223 int VRecordingList::doPlay()
224 {
225   Recording* toPlay = getCurrentOptionRecording();
226   if (toPlay)
227   {
228     VVideoRec* vidrec = new VVideoRec(toPlay);
229     ViewMan::getInstance()->addNoLock(vidrec);
230     vidrec->draw();
231     vidrec->show();
232     vidrec->go(0);
233     return 1;
234   }
235   // should not get to here
236   return 0;
237 }
238
239 int VRecordingList::doResume()
240 {
241   Recording* toResume = getCurrentOptionRecording();
242   if (toResume)
243   {
244     ULLONG position = VDR::getInstance()->getResumePoint(toResume->fileName);
245
246     VVideoRec* vidrec = new VVideoRec(toResume);
247     ViewMan::getInstance()->addNoLock(vidrec);
248     vidrec->draw();
249     vidrec->show();
250     vidrec->go(position);
251     return 1;
252   }
253   // should not get to here
254   return 0;
255 }
256
257 Recording* VRecordingList::getCurrentOptionRecording()
258 {
259   Recording* current;
260   for(recDir->recList->reset(); (current = (Recording*)recDir->recList->getCurrent()); recDir->recList->next())
261   {
262     if (current->index == sl.getCurrentOption()) return current;
263   }
264   return NULL;
265 }
266
267 int VRecordingList::handleCommand(int command)
268 {
269   switch(command)
270   {
271     case Remote::DF_UP:
272     case Remote::UP:
273     {
274       sl.up();
275       sl.draw();
276
277       doShowingBar();
278       show();
279       return 2;
280     }
281     case Remote::DF_DOWN:
282     case Remote::DOWN:
283     {
284       sl.down();
285       sl.draw();
286
287       doShowingBar();
288       show();
289       return 2;
290     }
291     case Remote::SKIPBACK:
292     {
293       sl.pageUp();
294       sl.draw();
295
296       doShowingBar();
297       show();
298       return 2;
299     }
300     case Remote::SKIPFORWARD:
301     {
302       sl.pageDown();
303       sl.draw();
304
305       doShowingBar();
306       show();
307       return 2;
308     }
309     case Remote::OK:
310     {
311       if (sl.getNumOptions() == 0) return 2;
312
313       // Check to see if it is a sub directory
314       Directory* curDir;
315       for(recDir->dirList->reset(); (curDir = (Directory*)recDir->dirList->getCurrent()); recDir->dirList->next())
316       {
317         if (curDir->index == sl.getCurrentOption())
318         {
319           VRecordingList* sub = new VRecordingList();
320           sub->setDir(curDir);
321           ViewMan::getInstance()->addNoLock(sub);
322
323           sub->draw();
324           sub->show();
325
326           return 2;
327         }
328       }
329
330       // check to see if it's a recording
331       Recording* current;
332       for(recDir->recList->reset(); (current = (Recording*)recDir->recList->getCurrent()); recDir->recList->next())
333       {
334         if (current->index == sl.getCurrentOption())
335         {
336           Log::getInstance()->log("VRecordingList", Log::DEBUG, "Found the option you pointed at. %s %s", current->getProgName(), current->fileName);
337
338           VRecordingMenu* v = new VRecordingMenu();
339           v->setParent(this);
340           v->setRecording(current);
341           ViewMan::getInstance()->addNoLock(v);
342           v->draw();
343           v->show();
344           return 2;
345         }
346       }
347       // should not get to here
348       return 1;
349     }
350     case Remote::BACK:
351     {
352       return 4;
353     }
354     case Remote::PLAY:
355     {
356       if (doPlay()) return 2;
357       return 1;
358     }
359
360   }
361   // stop command getting to any more views
362   return 1;
363 }