X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=client%2Fclient.c;h=ce1d1f2164a805ccc9bbb97739bf93e2581379c5;hb=09b207a39b7791098daafd7d87c3ad9d3db3e19f;hp=0218fb7a4c7e438477fb100eecb7b12d8e959027;hpb=8246c6551faa818be7a58638dbbc2e521f21c454;p=mTask.git diff --git a/client/client.c b/client/client.c index 0218fb7..ce1d1f2 100644 --- a/client/client.c +++ b/client/client.c @@ -45,7 +45,12 @@ void read_message(void) break; case MSG_DEL_TASK: debug("Receiving a delete task request"); - task_delete(); + c = read16(); + task_delete(c); + //Write acknowledgement + write_byte('d'); + write16(c); + write_byte('\n'); break; case MSG_GET_TASK: debug("Receiving a task"); @@ -63,6 +68,8 @@ void read_message(void) default: debug("Unknown message: %X", c); } + } else { +// debug("No input"); } } @@ -73,36 +80,29 @@ void loop(void) if(getmillis()-loopmillis < LOOPDELAY){ return; } + loopmillis = getmillis(); #endif - - int ct; - long cyclestart; - struct task *curtask; + debug("Loop"); read_message(); //Run tasks - cyclestart = getmillis(); - for(ct = 0; cttaskid); + run_task(t); //Interval task, and interval passed - } else if(cyclestart-curtask->lastrun > curtask->interval){ - debug("Running interval task: %d", ct); - run_task(curtask); + } else if(cyclestart-t->lastrun > t->interval){ + debug("Running interval task: %d", t->taskid); + run_task(t); //Oneshot task, thus disable - if(curtask->interval == 0){ - curtask->used = false; + if(t->interval == 0){ + task_delete(t->taskid); } - curtask->lastrun = cyclestart; + t->lastrun = cyclestart; } } }