summary refs log tree commit diff
path: root/src/opcodes.rs
diff options
context:
space:
mode:
authorAshelyn Rose <git@ashen.earth>2024-12-24 17:43:08 -0700
committerAshelyn Rose <git@ashen.earth>2024-12-24 17:43:08 -0700
commita73ee8e7d8abcc865c9c151ef0e53bc73143dedc (patch)
treedd8694e8aed722356dd731b6b0b167504d644286 /src/opcodes.rs
parent77c2625a52c18f3364fe6b91b7466aaaa3d9aac3 (diff)
Implement call variants
Diffstat (limited to 'src/opcodes.rs')
-rw-r--r--src/opcodes.rs48
1 files changed, 32 insertions, 16 deletions
diff --git a/src/opcodes.rs b/src/opcodes.rs
index 1fbc80f..c583909 100644
--- a/src/opcodes.rs
+++ b/src/opcodes.rs
@@ -174,17 +174,19 @@ generate_opcodes!(
 
         #[code(0x40)]
         fn Copy(param: u32) -> u32 {
-            return param
+            param
         },
 
         #[code(0x41)]
-        fn Copys() {
-            todo!();
+        fn Copys(param: u32) -> u32 {
+            panic!("Copys not implemented");
+            param
         },
 
         #[code(0x42)]
-        fn Copyb() {
-            todo!();
+        fn Copyb(param: u32) -> u32 {
+            panic!("Copyb not implemented");
+            param
         },
 
         #[code(0x44)]
@@ -386,8 +388,10 @@ generate_opcodes!(
         },
 
         #[code(0x130)]
-        fn Glk() {
-            todo!();
+        fn Glk(&mut interpreter, glk_func: u32, num_args: u32) -> u32 {
+            println!("glk({glk_func}, {num_args})");
+            Glk::call_func(interpreter, glk_func, num_args);
+            return 0
         },
 
         #[code(0x140)]
@@ -450,19 +454,31 @@ generate_opcodes!(
             return 0;
         },
 
-        #[code(0x161)]
-        fn Callfi() {
-            todo!();
+        #[code(0x161), no_store]
+        fn Callfi(&mut interpreter, func_addr: u32, param0: u32) -> u32 {
+            interpreter.create_return_stub();
+            interpreter.call_function(func_addr, vec![param0]);
+
+            // This gets ignored because of gen_return_stub but it's here for type reasons
+            return 0;
         },
 
-        #[code(0x162)]
-        fn Callfii() {
-            todo!();
+        #[code(0x162), no_store]
+        fn Callfii(&mut interpreter, func_addr: u32, param0: u32, param1: u32) -> u32 {
+            interpreter.create_return_stub();
+            interpreter.call_function(func_addr, vec![param0, param1]);
+
+            // This gets ignored because of gen_return_stub but it's here for type reasons
+            return 0;
         },
 
-        #[code(0x163)]
-        fn Callfiii() {
-            todo!();
+        #[code(0x163), no_store]
+        fn Callfiii(&mut interpreter, func_addr: u32, param0: u32, param1: u32, param2: u32) -> u32 {
+            interpreter.create_return_stub();
+            interpreter.call_function(func_addr, vec![param0, param1, param2]);
+
+            // This gets ignored because of gen_return_stub but it's here for type reasons
+            return 0;
         },
 
         #[code(0x170)]