aboutsummaryrefslogtreecommitdiff
path: root/diplomacy/utils/scheduler_event.py
diff options
context:
space:
mode:
authorPhilip Paquette <pcpaquette@gmail.com>2018-09-26 07:48:55 -0400
committerPhilip Paquette <pcpaquette@gmail.com>2019-04-18 11:14:24 -0400
commit6187faf20384b0c5a4966343b2d4ca47f8b11e45 (patch)
tree151ccd21aea20180432c13fe4b58240d3d9e98b6 /diplomacy/utils/scheduler_event.py
parent96b7e2c03ed98705754f13ae8efa808b948ee3a8 (diff)
Release v1.0.0 - Diplomacy Game Engine - AGPL v3+ License
Diffstat (limited to 'diplomacy/utils/scheduler_event.py')
-rw-r--r--diplomacy/utils/scheduler_event.py42
1 files changed, 42 insertions, 0 deletions
diff --git a/diplomacy/utils/scheduler_event.py b/diplomacy/utils/scheduler_event.py
new file mode 100644
index 0000000..1d097d8
--- /dev/null
+++ b/diplomacy/utils/scheduler_event.py
@@ -0,0 +1,42 @@
+# ==============================================================================
+# Copyright (C) 2019 - Philip Paquette, Steven Bocco
+#
+# This program is free software: you can redistribute it and/or modify it under
+# the terms of the GNU Affero General Public License as published by the Free
+# Software Foundation, either version 3 of the License, or (at your option) any
+# later version.
+#
+# This program is distributed in the hope that it will be useful, but WITHOUT
+# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+# FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
+# details.
+#
+# You should have received a copy of the GNU Affero General Public License along
+# with this program. If not, see <https://www.gnu.org/licenses/>.
+# ==============================================================================
+""" Scheduler event describing scheduler state for a specific data. """
+
+from diplomacy.utils.jsonable import Jsonable
+
+class SchedulerEvent(Jsonable):
+ """ Scheduler event class. Properties:
+ - time_unit: unit time (in seconds) used by scheduler (time between 2 tasks checkings).
+ Currently 1 second in server scheduler.
+ - time_added: scheduler time (nb. time units) when data was added to scheduler.
+ - delay: scheduler time (nb. time units) to wait before processing time.
+ - current_time: current scheduler time (nb. time units).
+ """
+ __slots__ = ['time_unit', 'time_added', 'delay', 'current_time']
+ model = {
+ 'time_unit': int,
+ 'time_added': int,
+ 'delay': int,
+ 'current_time': int
+ }
+
+ def __init__(self, **kwargs):
+ self.time_unit = 0
+ self.time_added = 0
+ self.delay = 0
+ self.current_time = 0
+ super(SchedulerEvent, self).__init__(**kwargs)