summaryrefslogtreecommitdiff
path: root/vdr-vdrmanager/helpers.cpp
diff options
context:
space:
mode:
authorlado <herrlado@gmail.com>2011-10-20 04:02:38 +0200
committerlado <herrlado@gmail.com>2011-10-20 04:02:38 +0200
commit7f28775e74babd24aba04fc3f5cf2f0e118d2ad5 (patch)
treeaf5a6c5d65ddf1815153754de658eb93299afe03 /vdr-vdrmanager/helpers.cpp
parent2d2b88862e96220a4a7befa5fa5fae8909857e1d (diff)
downloadvdr-manager-7f28775e74babd24aba04fc3f5cf2f0e118d2ad5.tar.gz
vdr-manager-7f28775e74babd24aba04fc3f5cf2f0e118d2ad5.tar.bz2
better handling of timer commands, now with own C D M commands. Old impl had bug with -0
Diffstat (limited to 'vdr-vdrmanager/helpers.cpp')
-rw-r--r--vdr-vdrmanager/helpers.cpp61
1 files changed, 37 insertions, 24 deletions
diff --git a/vdr-vdrmanager/helpers.cpp b/vdr-vdrmanager/helpers.cpp
index 63f2ac9..1b7b548 100644
--- a/vdr-vdrmanager/helpers.cpp
+++ b/vdr-vdrmanager/helpers.cpp
@@ -177,38 +177,48 @@ string cHelpers::SetTimerIntern(string args) {
// separete timer number
size_t sep = args.find(':');
if (sep == string::npos) {
- return "!ERROR\r\n";
- }
- int number = atoi(args.c_str());
- bool delTimer = number < 0;
- if (delTimer) {
- number = -number;
+ return "!ERROR:no separator found\r\n";
}
- string params = args.substr(sep+1);
+
+ char c = args[0];
+ string numberstr = args.substr(sep-1,1);
+
+ int number = atoi(numberstr.c_str());
+
+ string params = args.substr(sep+1);
+
+
// parse timer
cTimer * timer = new cTimer;
if (!timer->Parse(params.c_str())) {
delete timer;
- return "!ERROR\r\n";
+ return "!ERROR:can not parse params '"+params+"'\r\n";
}
-
- if (!number) {
- // new timer
+
+ cTimer * oldTimer;
+ switch(c){
+ case 'C': // new timer
+ case 'c':
Timers.Add(timer);
- } else {
- // modify timer
+ break;
+ case 'D':
+ case 'd':
+ // delete timer
delete timer;
- cTimer * oldTimer = Timers.Get(number);
- if (!oldTimer) {
- return "!ERROR\r\n";
- }
- if (delTimer) {
- Timers.Del(oldTimer, true);
- } else {
- oldTimer->Parse(params.c_str());
- }
+ oldTimer = Timers.Get(number);
+ Timers.Del(oldTimer, true);
+ break;
+ case 'M':
+ case 'm':
+ // modify
+ oldTimer = Timers.Get(number);
+ oldTimer->Parse(params.c_str());
+ break;
+ default:
+ return "!ERROR:unknown timer command\r\n";
}
+
Timers.Save();
return "START\r\nEND\r\n";
@@ -314,7 +324,10 @@ string cHelpers::ToText(cTimer * timer) {
const cList<cEvent> * events = schedule->Events();
cEvent * match = NULL;
for(cEvent * event = events->First(); event; event = events->Next(event)) {
- if (IsWantedTime(timer->StartTime(), event)) {
+
+ time_t startTime = event->StartTime();
+ time_t stopTime = startTime + event->Duration();
+ if(startTime <= timer->StartTime() && timer->StopTime() >= stopTime){
match = event;
break;
}
@@ -348,7 +361,7 @@ string cHelpers::ToText(cTimer * timer) {
result += MapSpecialChars(timer->File());
result += ":";
result += MapSpecialChars(timer->Aux() ? timer->Aux() : "");
- if(match){
+ if(match && false){
result += ":";
result += MapSpecialChars(match->ShortText() ? match->ShortText() : "");
result += ":";