summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJuan Manuel Tomás <jtomas1815@gmail.com>2022-07-08 22:48:47 -0300
committerJuan Manuel Tomás <jtomas1815@gmail.com>2022-07-08 22:48:47 -0300
commitadbc4248120e245fb68f8658bb765fe04c6ecdab (patch)
tree61f6331ccdf0f517b19ef3ea36087e617bc50b67
parent653fdc8cdc1040cc5647a7cebfd274bf49bd8a21 (diff)
downloadstk-adbc4248120e245fb68f8658bb765fe04c6ecdab.tar.gz
stk-adbc4248120e245fb68f8658bb765fe04c6ecdab.zip
Make this thing probably turing complete
-rw-r--r--input.stk6
-rw-r--r--main.py76
2 files changed, 62 insertions, 20 deletions
diff --git a/input.stk b/input.stk
index 51e3270..8b4f68f 100644
--- a/input.stk
+++ b/input.stk
@@ -1,3 +1,3 @@
-5 dup * dup * dup * print
-34 35 + print
-1 0 - print
+Loops ten times asking for user input. If the input is 0 or nothing, print 69420, else print back the number from the input.
+10 [ 0 1 , [ ~ . ! -- ] [ 69420 . ! ] -- ]
+
diff --git a/main.py b/main.py
index b2fd03e..6c177d0 100644
--- a/main.py
+++ b/main.py
@@ -1,18 +1,37 @@
-parameter_registers = ['rdi', 'rsi', 'rdx', 'rcx', 'r8', 'r9']
-return_registers = ['rax', 'rdx']
-
-syscall_registers = ['rdi', 'rsi', 'rdx', 'r10', 'r8', 'r9']
-static_chain_pointer = 'r10'
-
-fparameter_registers = ['xmm0', 'xmm1', 'xmm2', 'xmm3', 'xmm4', 'xmm5', 'xmm6', 'xmm7']
-freturn_registers = ['xmm0', 'xmm1']
-
-callee_must_clean = ['rbx', 'rsp', 'rbp', 'r12', 'r13', 'r14', 'r15']
-
code = []
code.append('format elf64 executable 3')
code.append('entry start')
+
+code.append('read:')
+code.append('xor rax, rax')
+code.append('xor rdi, rdi')
+code.append('mov rsi, int_buffer')
+code.append('mov rdx, 20')
+code.append('syscall')
+code.append('xor rcx, rcx')
+code.append('mov cl, [int_buffer + rax - 1]')
+code.append('cmp rcx, 10')
+code.append('jne newlineskip')
+code.append('dec rax')
+code.append('newlineskip:')
+code.append('mov rsi, rax')
+code.append('xor rax, rax')
+code.append('cmp rsi, 0')
+code.append('je skipread')
+code.append('xor rcx, rcx')
+code.append('mov rdi, 10')
+code.append('keepreading:')
+code.append('mul rdi')
+code.append('mov dl, [int_buffer + rcx]')
+code.append('sub rdx, 48')
+code.append('add rax, rdx')
+code.append('inc rcx')
+code.append('cmp rcx, rsi')
+code.append('jl keepreading')
+code.append('skipread:')
+code.append('ret')
+
code.append('print:')
code.append('mov [rsp - 8], rbx')
code.append('mov rax, [rsp + 8]')
@@ -48,6 +67,8 @@ code.append('mov rbx, [rsp - 8]')
code.append('ret')
code.append('start:')
+loop_stack = []
+loop_index = -1
with open('input.stk', 'r') as f:
text = f.read()
words = text.replace('\n', ' ').strip().split(' ')
@@ -60,25 +81,46 @@ with open('input.stk', 'r') as f:
code.append('add rax, rdi')
code.append('push rax')
elif word == '-':
- code.append('pop rax')
code.append('pop rdi')
+ code.append('pop rax')
code.append('sub rax, rdi')
code.append('push rax')
+ elif word == '++':
+ code.append('pop rax')
+ code.append('inc rax')
+ code.append('push rax')
+ elif word == '--':
+ code.append('pop rax')
+ code.append('dec rax')
+ code.append('push rax')
elif word == '*':
code.append('pop rax')
code.append('pop rdi')
code.append('mul rdi')
code.append('push rax')
- elif word == 'pop':
+ elif word == '!':
code.append('pop rax')
- elif word == 'dup':
+ elif word == '~':
code.append('pop rax')
code.append('push rax')
code.append('push rax')
- elif word == 'print':
+ elif word == '.':
code.append('call print')
- else:
- print('Unknown word:', word)
+ code.append('pop rax')
+ elif word == ',':
+ code.append('call read')
+ code.append('push rax')
+ elif word == '[':
+ loop_index += 1
+ loop_stack.append(loop_index)
+ code.append('l' + str(loop_index) + ':')
+ code.append('cmp DWORD [rsp], 0')
+ code.append('je e' + str(loop_index))
+ elif word == ']':
+ loop_end = loop_stack.pop()
+ code.append('jmp l' + str(loop_end))
+ code.append('e' + str(loop_end) + ':')
+ code.append('pop rax')
code.append('mov rax, 60')
code.append('mov rdi, 0')