X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=game_common.py;h=5aa4b2544729d337fcef2ee939fe1ddeddc3ea63;hb=9c3865bbfc4fe7721f8c2f057bce85e2300ea528;hp=6a77d9c6fa0c5062f73a1b089089416bc054c82e;hpb=17984bc886e3a233b828a53354467bbda2c43692;p=plomrogue2-experiments diff --git a/game_common.py b/game_common.py index 6a77d9c..5aa4b25 100644 --- a/game_common.py +++ b/game_common.py @@ -1,40 +1,47 @@ from parser import ArgError -class World: - - def __init__(self): - self.turn = 0 - self.map_size = (0, 0) - self.terrain_map = '' - self.things = [] - self.Thing = Thing # child classes may use an extended Thing class here +class Map: - def set_map_size(self, yx): - y, x = yx - self.map_size = (y, x) - self.terrain_map = '' - for y in range(self.map_size[0]): - self.terrain_map += '?' * self.map_size[1] + def __init__(self, size=(0, 0), terrain=''): + self.size = size + self.terrain = terrain - def set_map_line(self, y, line): - width_map = self.map_size[1] - if y >= self.map_size[0]: + def set_line(self, y, line): + height_map = self.size[0] + width_map = self.size[1] + if y >= height_map: raise ArgError('too large row number %s' % y) width_line = len(line) if width_line > width_map: raise ArgError('too large map line width %s' % width_line) - self.terrain_map = self.terrain_map[:y * width_map] + line + \ - self.terrain_map[(y + 1) * width_map:] + self.terrain = self.terrain[:y * width_map] + line +\ + self.terrain[(y + 1) * width_map:] - def get_thing(self, i): + def get_position_index(self, yx): + return yx[0] * self.size[1] + yx[1] + + +class World: + + def __init__(self): + self.Map = Map # child classes may use an extended Map class here + self.Thing = Thing # child classes may use an extended Thing class here + self.turn = 0 + self.map_ = self.Map() + self.things = [] + + def get_thing(self, id_): for thing in self.things: - if i == thing.id_: + if id_ == thing.id_: return thing - t = self.Thing(self, i) + t = self.Thing(self, id_) self.things += [t] return t + def new_map(self, yx): + self.map_ = self.Map(yx, '?') + class Thing: @@ -43,3 +50,21 @@ class Thing: self.id_ = id_ self.type_ = '?' self.position = [0,0] + + +class CommonCommandsMixin: + + def cmd_MAP(self, yx): + """Create new map of size yx and only '?' cells.""" + self.world.new_map(yx) + cmd_MAP.argtypes = 'yx_tuple:nonneg' + + def cmd_THING_TYPE(self, i, type_): + t = self.world.get_thing(i) + t.type_ = type_ + cmd_THING_TYPE.argtypes = 'int:nonneg string' + + def cmd_THING_POS(self, i, yx): + t = self.world.get_thing(i) + t.position = list(yx) + cmd_THING_POS.argtypes = 'int:nonneg yx_tuple:nonneg'