+ self.resetRepeated()
+ self.backoff = 0
+
+ self.disabled = False
+
+ def resetRepeated(self):
+ self.repeated = int(0)
+
+ def setRepeated(self, day):
+ self.repeated |= (2 ** day)
+ print "Repeated: " + str(self.repeated)
+
+ def isRunning(self):
+ return self.state == self.StateRunning
+
+ # update self.begin and self.end according to the self.repeated-flags
+ def processRepeated(self):
+ print "ProcessRepeated"
+ if (self.repeated != 0):
+ now = int(time.time()) + 1
+
+ #to avoid problems with daylight saving, we need to calculate with localtime, in struct_time representation
+ localbegin = time.localtime(self.begin)
+ localend = time.localtime(self.end)
+ localnow = time.localtime(now)
+
+ print time.strftime("%c", localbegin)
+ print time.strftime("%c", localend)
+
+ day = []
+ flags = self.repeated
+ for x in range(0, 7):
+ if (flags & 1 == 1):
+ day.append(0)
+ print "Day: " + str(x)
+ else:
+ day.append(1)
+ flags = flags >> 1
+
+ print time.strftime("%c", localnow)
+ while ((day[localbegin.tm_wday] != 0) or ((day[localbegin.tm_wday] == 0) and localend < localnow)):
+ print time.strftime("%c", localbegin)
+ print time.strftime("%c", localend)
+ #add one day to the struct_time, we have to convert using gmt functions, because the daylight saving flag might change after we add our 86400 seconds
+ localbegin = time.gmtime(calendar.timegm(localbegin) + 86400)
+ localend = time.gmtime(calendar.timegm(localend) + 86400)
+
+ #we now have a struct_time representation of begin and end in localtime, but we have to calculate back to (gmt) seconds since epoch
+ self.begin = int(time.mktime(localbegin))
+ self.end = int(time.mktime(localend)) + 1
+
+ print "ProcessRepeated result"
+ print time.strftime("%c", time.localtime(self.begin))
+ print time.strftime("%c", time.localtime(self.end))
+
+ self.timeChanged()
+
+ def __lt__(self, o):
+ return self.getNextActivation() < o.getNextActivation()