diff options
author | Lucas Fryzek <lucas.fryzek@fryzekconcepts.com> | 2025-03-23 22:38:25 +0000 |
---|---|---|
committer | Lucas Fryzek <lucas.fryzek@fryzekconcepts.com> | 2025-03-23 22:38:25 +0000 |
commit | c803ecf4213487591e75f66a6f1c1b0ac1ea4f5e (patch) | |
tree | d8d1d3be9b1e57f6ab3d98efbb8a5bf2672b4918 /src | |
parent | a2feba2d918db861ea85d22887f73993c173e742 (diff) |
Get threading of world working
Diffstat (limited to 'src')
-rw-r--r-- | src/world.rhm | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/src/world.rhm b/src/world.rhm index 9357422..13fe048 100644 --- a/src/world.rhm +++ b/src/world.rhm @@ -3,6 +3,7 @@ import: "chunk.rhm" open "entity.rhm" open "item.rhm" open + "../thread/thread.rhm" open export: Chunk @@ -18,9 +19,43 @@ export: Item Slot +class MessageLogin(user :: String, thr) + class World(chunks :: MutableList.now_of(Chunk), entities :: MutableList.now_of(Entity)): + field thread_evt = thread_receive_evt() + field tick_length = 0.6 // tick length is 600ms + constructor(): super(MutableList(), MutableList()) + method login(user :: String, thr): + // TODO should be accessing some DB to get player + let player = EntityPlayer(0, 0, 0, chunks) + player.equip[Slot.right_hand] := Item.bronze_axe + entities.add(player) + + method process_messages(timestamp :: Real): + let time_passed = current_timestamp() - timestamp + let remaining_time = math.max(tick_length - time_passed, 0) + let sync_res = sync_timeout(remaining_time, thread_evt) + if sync_res + | let msg = thread_receive() + match msg + | MessageLogin(user, thr): login(user, thr) + | ~else: println("Unknown message " +& msg) + process_messages(timestamp) + | #true // Return here + + method tick_loop(): + // TODO step through entities and simulate them + let starting_time = current_timestamp() + process_messages(starting_time) + println("Done tick") + tick_loop() + + + method simulate(): + tick_loop() + |