Added tests for `and` subroutine from stdlib.
authorAaron Taylor <ataylor@subgeniuskitty.com>
Thu, 1 Aug 2019 02:26:08 +0000 (19:26 -0700)
committerAaron Taylor <ataylor@subgeniuskitty.com>
Thu, 1 Aug 2019 02:26:08 +0000 (19:26 -0700)
stdlib_tests/3004_and.pvvs [new file with mode: 0644]
stdlib_tests/vv_test.py

diff --git a/stdlib_tests/3004_and.pvvs b/stdlib_tests/3004_and.pvvs
new file mode 100644 (file)
index 0000000..a468c82
--- /dev/null
@@ -0,0 +1,37 @@
+@ Test 0 ^ 0 = 0
+SSSSN           | PUSH 0
+SSSSN           | PUSH 0
+NSTTSTSSTN      | JSR > 101001 (and)
+NSTTSSTN        | JSR > 1001 (print number from stack)
+
+@ Test 0 ^ 1 = 0
+SSSSN           | PUSH 0
+SSSTN           | PUSH +1
+NSTTSTSSTN      | JSR > 101001 (and)
+NSTTSSTN        | JSR > 1001 (print number from stack)
+
+@ Test 1 ^ 1 = 1
+SSSTN           | PUSH +1
+SSSTN           | PUSH +1
+NSTTSTSSTN      | JSR > 101001 (and)
+NSTTSSTN        | JSR > 1001 (print number from stack)
+
+@ Test 1 ^ 1...1 = 1
+SSSTN           | PUSH +1
+SSTTN           | PUSH -1
+NSTTSTSSTN      | JSR > 101001 (and)
+NSTTSSTN        | JSR > 1001 (print number from stack)
+
+@ Test 1010...1010 ^ 111111 = 101010
+@ Note that -6148914691236517206 = 1010...1010 in twos-complement but we 
+@ enter it in sign magnitude format so the bit pattern appears different.
+SSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTSTTSN | PUSH -6148914691236517206
+SSSTTTTTTN      | PUSH +63
+NSTTSTSSTN      | JSR > 101001 (and)
+NSTTSSTN        | JSR > 1001 (print number from stack)
+
+@ All done.
+NNN             | DIE
+
+#include <logic.pvvs>
+#include <stdio.pvvs>
index aa5bda0..7ac408c 100755 (executable)
@@ -33,6 +33,7 @@ tests = [
         ['3001_not', '', '-1+0-6148914691236517206+6148914691236517205'],
         ['3002_lshift', '', '+1+2+4611686018427387904-9223372036854775808-9223372036854775808+0'],
         ['3003_rshift', '', '+1+1+1-4611686018427387903-576460752303423478-1-1'],
         ['3001_not', '', '-1+0-6148914691236517206+6148914691236517205'],
         ['3002_lshift', '', '+1+2+4611686018427387904-9223372036854775808-9223372036854775808+0'],
         ['3003_rshift', '', '+1+1+1-4611686018427387903-576460752303423478-1-1'],
+        ['3004_and', '', '+0+0+1+1+42'],
         ] 
 
 for test in tests:
         ] 
 
 for test in tests: