About Social Code
summaryrefslogtreecommitdiff
path: root/main.rhm
diff options
context:
space:
mode:
Diffstat (limited to 'main.rhm')
-rw-r--r--main.rhm91
1 files changed, 27 insertions, 64 deletions
diff --git a/main.rhm b/main.rhm
index 5648c53..c49216b 100644
--- a/main.rhm
+++ b/main.rhm
@@ -1,67 +1,30 @@
#lang rhombus/static
import:
- "world.rhm"
-
-fun test(test_result :: Boolean, test_str :: String):
- if test_result
- | println("Passed " +& test_str)
- | println("Failed " +& test_str)
-
-fun
-| reset_entity(entity :: world.Entity): reset_entity(entity, 0, 0)
-| reset_entity(entity :: world.Entity, x :: Int, y :: Int):
- entity.x := x
- entity.y := y
-
-let wrld = world.World()
-let chunk = world.Chunk(64, 64, 0, 0)
-wrld.chunks.add(chunk)
-let entity = world.EntityPlayer(0, 0, 0, chunk)
-wrld.entities.add(entity)
-
-
-reset_entity(entity)
-test(entity.move(1, 0), "move horizontal")
-
-reset_entity(entity, 1, 1)
-test(entity.move(0, 1), "move vertical")
-
-reset_entity(entity)
-test(entity.move(1, 1), "move diagonal")
-
-reset_entity(entity)
-test(!entity.move(2, 0), "move diagonal")
-
-reset_entity(entity)
-test(!entity.move(0, 0), "starting pos")
-
-let new_chunk = world.Chunk(64, 64, 1, 0)
-chunk.add_neighbour(new_chunk, world.Direction.east)
-reset_entity(entity, 63, 0)
-test(entity.move(64, 0), "cross chunk")
-test(entity.current_chunk == new_chunk, "changed chunk")
-
-entity.current_chunk := chunk
-reset_entity(entity, 0, 1)
-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)
-entity.equip[world.Slot.right_hand] := world.Item.bronze_axe
-let other_ent = world.EntityGatherable(1, 1, 1, chunk, world.ItemCap.chop)
-let gather_result = entity.gather(other_ent)
-test(gather_result == world.ActionResponse.ok || gather_result == world.ActionResponse.unsuccessful, "gathering")
-
-reset_entity(other_ent, 2, 2)
-entity.timer := 0
-test(entity.gather(other_ent) == world.ActionResponse.invalid, "gather too far away")
-
-reset_entity(other_ent, 64, 0)
-reset_entity(entity, 63, 0)
-entity.timer := 0
-let gather_result = entity.gather(other_ent)
-test(gather_result == world.ActionResponse.ok || gather_result == world.ActionResponse.unsuccessful, "gather accross chunk")
-entity.tick()
-test(entity.gather(other_ent) == world.ActionResponse.cooldown, "gather cooldown")
+ lib("web-server/http.rkt") open
+ lib("web-server/servlet.rkt") open
+ lib("web-server/servlet-env.rkt") open
+ "thread/thread.rhm" open
+
+fun start(req):
+ #{response/xexpr}("Hello world!")
+
+//#{serve/servlet}(start, #{#:launch-browser?}: #false, #{#:servlet-path}: "/game")
+
+fun loop():
+ println("Hello World!")
+ sleep(1)
+ loop()
+
+fun hello():
+ let thread_evt = thread_receive_evt()
+ let sync_res = sync_timeout(1/500, thread_evt)
+ if !sync_res
+ | println("No sync result")
+ | println("Got message " +& thread_receive())
+
+println("Creating thread")
+def thr: thread(hello)
+thread_send(thr, "Hello")
+thread_wait(thr)
+println("Thread done")