From 57dc34b23fcc2eee74ea137d0609fc755176725c Mon Sep 17 00:00:00 2001
From: Adam Frisby
Date: Thu, 3 May 2007 04:34:18 +0000
Subject: * Added NOOP, POP, POPV, POPQ, DUP, DUPV, DUPQ instructions. *
Placeholders for POPS, POPL, POPIP, POPBP, POPSP, POPSLR, DUPS, DUPL
---
libraries/libLSL/lslByteCode.cs | 90 +++++++++++++++++++++++++++++++++++++++++
1 file changed, 90 insertions(+)
(limited to 'libraries/libLSL')
diff --git a/libraries/libLSL/lslByteCode.cs b/libraries/libLSL/lslByteCode.cs
index eb98773..1b37f49 100644
--- a/libraries/libLSL/lslByteCode.cs
+++ b/libraries/libLSL/lslByteCode.cs
@@ -13,27 +13,117 @@ namespace libLSL
byte ins = nextInstruction();
lslOpcodes code = (lslOpcodes)ins;
+ Object arg1;
+ Object arg2;
+
switch (code)
{
case lslOpcodes.OP_NOOP:
break;
+
case lslOpcodes.OP_POP:
popBytes(4);
break;
+ case lslOpcodes.OP_POPS:
+ case lslOpcodes.OP_POPL:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_POPV:
+ popBytes(12);
+ break;
+ case lslOpcodes.OP_POPQ:
+ popBytes(16);
+ break;
+
+ case lslOpcodes.OP_POPARG:
+ popBytes((Int32)arg1);
+ break;
+
+ case lslOpcodes.OP_POPIP:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_POPBP:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_POPSP:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_POPSLR:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_DUP:
+ pushBytes(getBytes(4));
+ break;
+
+ case lslOpcodes.OP_DUPS:
+ case lslOpcodes.OP_DUPL:
+ // Do Stuff
+ break;
+
+ case lslOpcodes.OP_DUPV:
+ pushBytes(getBytes(12));
+ break;
+
+ case lslOpcodes.OP_DUPQ:
+ pushBytes(getBytes(16));
+ break;
+
default:
break;
}
}
+ ///
+ /// Advance the instruction pointer, pull the current instruction
+ ///
+ ///
byte nextInstruction()
{
return 0;
}
+ ///
+ /// Removes bytes from the stack
+ ///
+ /// Number of bytes
void popBytes(int num)
{
}
+
+ ///
+ /// Pushes Bytes to the stack
+ ///
+ /// Ze bytes!
+ void pushBytes(byte[] bytes)
+ {
+
+ }
+
+ ///
+ /// Get Bytes from the stack
+ ///
+ /// Number of bytes
+ /// Ze bytes!
+ byte[] getBytes(int num)
+ {
+
+ }
+
+ ///
+ /// Saves bytes to the local frame
+ ///
+ /// Ze bytes!
+ /// Index in local frame
+ void storeBytes(byte[] bytes, int index)
+ {
+
+ }
}
}
--
cgit v1.1