]> git.vomp.tv Git - vompclient.git/blob - vepgsettimer.cc
Portability
[vompclient.git] / vepgsettimer.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 "vepgsettimer.h"
22
23 VEpgSetTimer::VEpgSetTimer(Event* tevent, Channel* tchannel)
24 {
25   viewman = ViewMan::getInstance();
26   vdr = VDR::getInstance();
27   logger = Log::getInstance();
28
29   event = tevent;
30   channel = tchannel;
31
32   create(400, 240);
33   if (Video::getInstance()->getFormat() == Video::PAL)
34   {
35     setScreenPos(150, 170);
36   }
37   else
38   {
39     setScreenPos(140, 140);
40   }
41
42   setBackgroundColour(Colour::VIEWBACKGROUND);
43   setTitleBarOn(1);
44   setTitleBarColour(Colour::TITLEBARBACKGROUND);
45   setBorderOn(true);
46   setTitleText(tr("Set Timer"));
47
48   buttonYes.setSurface(surface);
49   buttonNo.setSurface(surface);
50   buttonYes.setSurfaceOffset(80, 40 + (7 * surface->getFontHeight()));
51   buttonNo.setSurfaceOffset(220, 40 + (7 * surface->getFontHeight()));
52
53   buttonYes.setText(tr("Yes"));
54   buttonNo.setText(tr("No"));
55   buttonYes.setActive(1);
56   selectedOption = YES;
57
58   logger->log("VEPGST", Log::DEBUG, "Title: %s", event->title);
59   logger->log("VEPGST", Log::DEBUG, "Time: %lu", event->time);
60   logger->log("VEPGST", Log::DEBUG, "Duration: %lu", event->duration);
61   logger->log("VEPGST", Log::DEBUG, "Channel: %i", channel->number);
62 }
63
64 VEpgSetTimer::~VEpgSetTimer()
65 {
66 }
67
68 char* VEpgSetTimer::genTimerString()
69 {
70   // Allocate to return
71   char* timerString = new char[1024];
72
73   // Other
74   struct tm* btime;
75   int flags;
76   char dateString[20];
77   char startMargin[10];
78   time_t startTime;
79   char startString[10];
80   char endMargin[10];
81   time_t endTime;
82   char endString[10];
83   char priority[10];
84   char lifetime[10];
85   char* eventTitle;
86
87   flags = 1; // hard coded active timer flag
88
89   btime = localtime((time_t*)&event->time);
90   strftime(dateString, 19, "%Y-%m-%d", btime);
91
92   char* startMarginConfig = vdr->configLoad("Timers", "Start margin");
93   if (startMarginConfig)
94   {
95     strncpy(startMargin, startMarginConfig, 9);
96     delete[] startMarginConfig;
97   }
98   else strcpy(startMargin, "5");
99
100   startTime = event->time - (atoi(startMargin) * 60);
101   btime = localtime(&startTime);
102   strftime(startString, 9, "%H%M", btime);
103
104   char* endMarginConfig = vdr->configLoad("Timers", "End margin");
105   if (endMarginConfig)
106   {
107     strncpy(endMargin, endMarginConfig, 9);
108     delete[] endMarginConfig;
109   }
110   else strcpy(endMargin, "5");
111
112   endTime = event->time + event->duration + (atoi(endMargin) * 60);
113   btime = localtime(&endTime);
114   strftime(endString, 9, "%H%M", btime);
115
116   char* priorityConfig = vdr->configLoad("Timers", "Priority");
117   if (priorityConfig)
118   {
119     strncpy(priority, priorityConfig, 9);
120     delete[] priorityConfig;
121   }
122   else strcpy(priority, "99");
123
124   char* lifetimeConfig = vdr->configLoad("Timers", "Lifetime");
125   if (lifetimeConfig)
126   {
127     strncpy(lifetime, lifetimeConfig, 9);
128     delete[] lifetimeConfig;
129   }
130   else strcpy(lifetime, "99");
131
132   eventTitle = new char[strlen(event->title) + 1];
133   strcpy(eventTitle, event->title);
134   for(UINT i=0; i < strlen(eventTitle); i++) if (eventTitle[i] == ':') eventTitle[i] = '|';
135
136   SNPRINTF(timerString, 1023, "%i:%lu:%s:%s:%s:%s:%s:%s:",
137     flags, channel->number, dateString,
138     startString, endString,
139     priority, lifetime, eventTitle);
140
141   delete[] eventTitle;
142
143   return timerString;
144 }
145
146 void VEpgSetTimer::swap()
147 {
148   if (selectedOption == NO)
149   {
150     selectedOption = YES;
151     buttonYes.setActive(1);
152     buttonNo.setActive(0);
153   }
154   else if (selectedOption == YES)
155   {
156     selectedOption = NO;
157     buttonYes.setActive(0);
158     buttonNo.setActive(1);
159   }
160 }
161
162 void VEpgSetTimer::draw()
163 {
164   View::draw();
165   drawPara(event->title, 10, 40, Colour::LIGHTTEXT);
166   drawText(channel->name, 10, 40 + (2 * surface->getFontHeight()), Colour::LIGHTTEXT);
167
168   char fullString[20];
169   time_t t;
170   struct tm* btime;
171   char timeString[10];
172   btime = localtime((time_t*)&event->time);
173   strftime(timeString, 9, "%0H:%0M - ", btime); // and format it as hh:mm -
174   strcpy(fullString, timeString); // put it in our buffer
175   t = event->time + event->duration; //get programme end time
176   btime = localtime(&t);
177   strftime(timeString, 9, "%0H:%0M", btime); // and format it as hh:mm -
178   strcat(fullString, timeString); // put it in our buffer
179
180   drawText(fullString, 10, 40 + (3 * surface->getFontHeight()), Colour::LIGHTTEXT);
181   drawText(tr("Create this timer?"), 10, 40 + (5 * surface->getFontHeight()), Colour::LIGHTTEXT);
182
183   buttonYes.draw();
184   buttonNo.draw();
185 }
186
187 int VEpgSetTimer::handleCommand(int command)
188 {
189   switch(command)
190   {
191     case Remote::DF_LEFT:
192     case Remote::LEFT:
193     {
194       swap();
195       draw();
196       ViewMan::getInstance()->updateView(this);
197       return 2;
198     }
199     case Remote::DF_RIGHT:
200     case Remote::RIGHT:
201     {
202       swap();
203       draw();
204       ViewMan::getInstance()->updateView(this);
205       return 2;
206     }
207     case Remote::BACK:
208     {
209       return 4;
210     }
211     case Remote::OK:
212     {
213       if (selectedOption != YES) return 4;
214       doit();
215       return 4;
216     }
217   }
218
219   return 1;
220 }
221
222
223 void VEpgSetTimer::doit()
224 {
225   char* timerString = genTimerString();
226   logger->log("VEPGST", Log::DEBUG, "%s", timerString);
227
228   ULONG ret = vdr->setEventTimer(timerString);
229   delete[] timerString;
230
231   if (!vdr->isConnected())
232   {
233     Command::getInstance()->connectionLost();
234   }
235
236   if (ret == 0) logger->log("VEPGST", Log::DEBUG, "Success");
237   else if (ret == 1) logger->log("VEPGST", Log::DEBUG, "Fail: Timer already set for this event");
238   else if (ret == 2) logger->log("VEPGST", Log::DEBUG, "Fail: General failure setting timer");
239
240   VInfo* vi = new VInfo();
241   vi->create(400, 150);
242   vi->setExitable();
243   vi->setBorderOn(1);
244   vi->setTitleBarOn(0);
245
246   if (Video::getInstance()->getFormat() == Video::PAL)
247     vi->setScreenPos(170, 200);
248   else
249     vi->setScreenPos(160, 150);
250
251   if (ret == 0) vi->setOneLiner(tr("Timer set successfully"));
252   else if (ret == 1) vi->setOneLiner(tr("There is already a timer for this event"));
253   else if (ret == 2) vi->setOneLiner(tr("Failure setting timer"));
254   vi->draw();
255
256   Message* m = new Message();
257   m->message = Message::ADD_VIEW;
258   m->to = viewman;
259   m->parameter = (ULONG)vi;
260
261   viewman->postMessage(m);
262 }