diff options
author | Lucas Fryzek <lucas.fryzek@fryzekconcepts.com> | 2025-03-20 23:01:42 +0000 |
---|---|---|
committer | Lucas Fryzek <lucas.fryzek@fryzekconcepts.com> | 2025-03-20 23:04:16 +0000 |
commit | f4e83d48a0e355707dbe6912b4c585436757bb6e (patch) | |
tree | 640ea9b1c4c135cd558275031e76dd56b638cc48 | |
parent | f741a652f283c4533723a03eca7cf315a487ce92 (diff) |
Add skeleton for gathering
-rw-r--r-- | main.rhm | 4 | ||||
-rw-r--r-- | world.rhm | 19 |
2 files changed, 22 insertions, 1 deletions
@@ -47,5 +47,9 @@ entity.current_chunk.set_tile(0, 1, world.Tile(#'wall_north)) test(!entity.move(0, 0), "Blocked by wall") test(entity.move(1,1), "Move by wall") +reset_entity(entity, 0, 0) +let other_ent = world.Entity(1, 1, 1, chunk) +test(entity.gather(other_ent), "Gathering") + //world.entities //println(@str{Entity is @(entity.x) @(entity.y)}) @@ -116,13 +116,30 @@ class Entity(id:: Int, mutable x :: Int, mutable y :: Int, mutable current_chunk cond | validate_dist(x, y, max_dist) && target_chunk != #false && validate_move(x, y, max_dist, target_chunk!!): - this.current_chunk := target_chunk + this.current_chunk := target_chunk!! this.x := x this.y := y #true | ~else: #false + method gather(target_entity :: Entity): + let x = target_entity.x + let y = target_entity.y + let target_chunk = validate_chunk(x, y) + + fun validate_gather_resource() :: Boolean: + // TODO figure out how to implement resource gathering + // it could be better to keep them as a tile and update the + // tile from regular to consumed + #false + + cond + | validate_dist(x, y, 1) && target_chunk != #false && validate_gather_resource(): + #true + | ~else: + #false + class World(chunks :: MutableList.now_of(Chunk), entities :: MutableList.now_of(Entity)): |