Add next state advancer

This commit is contained in:
lash 2022-02-02 09:27:57 +00:00
parent b9925a5038
commit f0ac792c4a
Signed by: lash
GPG Key ID: 21D2E7BB88C2A746
6 changed files with 51 additions and 6 deletions

View File

@ -1,3 +1,5 @@
- 0.0.14
* Add next state advancer
- 0.0.13 - 0.0.13
* Add next state peek * Add next state peek
- 0.0.12 - 0.0.12

View File

@ -1,6 +1,6 @@
[metadata] [metadata]
name = shep name = shep
version = 0.0.13 version = 0.0.14
description = Multi-state key stores using bit masks description = Multi-state key stores using bit masks
author = Louis Holbrook author = Louis Holbrook
author_email = dev@holbrook.no author_email = dev@holbrook.no

View File

@ -58,11 +58,14 @@ class PersistedState(State):
def move(self, key, to_state): def move(self, key, to_state):
from_state = self.state(key) from_state = self.state(key)
k_from = self.name(from_state)
to_state = super(PersistedState, self).move(key, to_state) to_state = super(PersistedState, self).move(key, to_state)
return self.__movestore(key, from_state, to_state)
def __movestore(self, key, from_state, to_state):
k_from = self.name(from_state)
k_to = self.name(to_state) k_to = self.name(to_state)
self.__ensure_store(k_to) self.__ensure_store(k_to)
contents = self.__stores[k_from].get(key) contents = self.__stores[k_from].get(key)
@ -96,3 +99,9 @@ class PersistedState(State):
k = self.name(state) k = self.name(state)
return self.__stores[k].path(key=key) return self.__stores[k].path(key=key)
def next(self, key=None):
from_state = self.state(key)
to_state = super(PersistedState, self).next(key)
return self.__movestore(key, from_state, to_state)

View File

@ -132,8 +132,8 @@ class State:
def name(self, v): def name(self, v):
if v == None: if v == None or v == 0:
return self.NEW return 'NEW'
k = self.__reverse.get(v) k = self.__reverse.get(v)
if k == None: if k == None:
raise StateInvalid(v) raise StateInvalid(v)
@ -269,6 +269,14 @@ class State:
return self.__keys[state] return self.__keys[state]
def sync(self, state):
pass
def path(self, state, key=None):
return None
def peek(self, key): def peek(self, key):
state = self.__keys_reverse.get(key) state = self.__keys_reverse.get(key)
if state == None: if state == None:
@ -284,3 +292,9 @@ class State:
raise StateInvalid('unknown state {}'.format(state)) raise StateInvalid('unknown state {}'.format(state))
return state return state
def next(self, key):
from_state = self.state(key)
new_state = self.peek(key)
return self.__move(key, from_state, new_state)

View File

@ -23,7 +23,7 @@ class SimpleFileStore:
raise FileExistsError(fp) raise FileExistsError(fp)
if contents == None: if contents == None:
raise FileExistsError('will not overwrite empty content on existing file {}. Use rm then add instead'.format(fp)) raise FileExistsError('will not overwrite empty content on existing file {}. Use rm then add instead'.format(fp))
elif contents == None: if contents == None:
contents = '' contents = ''
f = open(fp, 'w') f = open(fp, 'w')

View File

@ -145,7 +145,27 @@ class TestStateReport(unittest.TestCase):
d = os.path.join(self.d, 'FOO', 'BAR') d = os.path.join(self.d, 'FOO', 'BAR')
self.assertEqual(self.states.path(self.states.FOO, key='BAR'), d) self.assertEqual(self.states.path(self.states.FOO, key='BAR'), d)
def test_next(self):
self.states.put('abcd')
self.states.next('abcd')
self.assertEqual(self.states.state('abcd'), self.states.FOO)
self.states.next('abcd')
self.assertEqual(self.states.state('abcd'), self.states.BAR)
with self.assertRaises(StateInvalid):
self.states.next('abcd')
fp = os.path.join(self.d, 'FOO', 'abcd')
with self.assertRaises(FileNotFoundError):
os.stat(fp)
fp = os.path.join(self.d, 'BAR', 'abcd')
os.stat(fp)
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()