summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xlorry-controller9
-rw-r--r--lorrycontroller/__init__.py1
-rw-r--r--lorrycontroller/workingstate.py37
3 files changed, 44 insertions, 3 deletions
diff --git a/lorry-controller b/lorry-controller
index 1b2fb74..10bad19 100755
--- a/lorry-controller
+++ b/lorry-controller
@@ -12,6 +12,7 @@ defaults = {
}
from lorrycontroller.confparser import LorryControllerConfig
+from lorrycontroller.workingstate import WorkingStateManager
class LorryController(cliapp.Application):
@@ -44,9 +45,11 @@ class LorryController(cliapp.Application):
logging.error("Unable to find lorry-controller.conf in git")
raise SystemExit(4)
- conf = LorryControllerConfig(self.settings,
- 'git/lorry-controller.conf')
-
+ self.conf = LorryControllerConfig(self.settings,
+ 'git/lorry-controller.conf')
+
+ with WorkingStateManager(self) as mgr:
+ pass
def rungit(self, args):
self.runcmd(['git']+args, cwd=os.path.join(self.settings['work-area'],
diff --git a/lorrycontroller/__init__.py b/lorrycontroller/__init__.py
index 3c29d56..f70b747 100644
--- a/lorrycontroller/__init__.py
+++ b/lorrycontroller/__init__.py
@@ -2,3 +2,4 @@
#
import confparser
+import workingstate
diff --git a/lorrycontroller/workingstate.py b/lorrycontroller/workingstate.py
new file mode 100644
index 0000000..39d0065
--- /dev/null
+++ b/lorrycontroller/workingstate.py
@@ -0,0 +1,37 @@
+# Copyright (C) 2012 Codethink Limited
+#
+
+import json
+import os
+import logging
+
+class WorkingStateManager(object):
+ '''Manage the working state of lorry-controller'''
+
+ def __init__(self, app):
+ self.app = app
+ self.workdir = os.path.join(self.app.settings['work-area'], 'work')
+
+ def __enter__(self):
+ self._load_state()
+ return self
+
+ def __exit__(self, exctype, excvalue, exctraceback):
+ self.save_state()
+
+ def _load_state(self):
+ self.lorry_state_file = os.path.join(self.workdir,
+ "last-lorry-state.json")
+ if os.path.exists(self.lorry_state_file):
+ logging.debug("Loading state file: %s" % self.lorry_state_file)
+ with open(self.lorry_state_file, "r") as fh:
+ self.lorry_state = json.load(fh)
+ else:
+ self.lorry_state = dict()
+
+ def save_state(self):
+ logging.debug("Serialising state: %s" % self.lorry_state_file)
+ with open(self.lorry_state_file, "w") as fh:
+ json.dump(self.lorry_state, fh, sort_keys=True, indent=4)
+ fh.write("\n")
+