kuroko/test/test.krk

173 lines
4.6 KiB
Python
Executable File

#!/home/klange/Projects/kuroko/kuroko
import time
# You may want to look at this in an editor with the syntax highlighting
# set to Python. Not even bim has a highlighter for Kuroko yet.
if False:
print("Kuroko has Python-style syntax")
print("with significant whitespace.")
print("Blank lines are ignored.")
# Comments should work, too.
print("None of this should print, since it's in an `if False:`")
print("This is the first line that should print.")
# Only str can be concatenated with str
print("We can do simple concatenation " + str(123) + ".")
# Lox only has a 'Number' type for numerical values, but we have
# Integer and Floating to separate the two.
print(4.2 * 9.7) # Should be 40.74
print(1 + 2 + 3)
# Other bases:
print("Hex:", 0xFF, "Octal:", 0o123, "Binary:", 0b1010)
# This `for init, cond, step:` syntax is possibly temporary? I do intend to
# implement iterators and `for VAR in ITER:` like in Python, but C-style for
# loops are also useful...
for i = 0; i < 10; i = i + 1:
print("i =", i)
# Functions work like in Python, though currently no default values.
def function(arg): # And of course the parser will handle comments here...
print("This is a function that does a thing!")
if arg == "demo": # Or here...
print("You passed 'demo' as an argument!")
else: # And definitely here.
print("You passed something else.")
return 42
print("This code is after the function definition")
# While I'm following the book, variable declarations are explicit with `let`.
# I don't know if I want to implement Python's scoping rules, which are a bit
# ... different from other languages in that lots of control flow that you
# would normally think of as introducing scope does not do so in Python. For
# now we're following traditional scoping rules, and a simple `let foo` at
# the head of the appropriate block should work okay.
let result = function("demo")
print("The function call returned:", result)
# `sleep()` is a native function bind. Lox has `clock` as an example, but I
# figured something with arguments would be more useful? The purpose of this
# language is to be used for writing syntax highlighters, configs, and also
# plugins for bim, so native bindings are going to be very important.
result = time.sleep(0.1)
print("Call to sleep returned:", result)
function("something else")
# This is some stuff to test closures
class Funcs:
let funcs = Funcs()
if True:
let a = 1
def f():
print(a)
let b = 2
def g():
print(b)
let c = 3
def h():
print(c)
funcs.f = f
funcs.g = g
funcs.f()
funcs.g()
def outer(): # test
#foo
#multiple lines
let x = "outside"
def inner():
print(x)
return inner
print("Function is defined, creating it...")
let closure = outer()
print("And executing the result...")
# This should correctly print "outside"
closure()
# This is surprisingly similar to Python already...
print("Let's do some classes.")
class Test: # This is a test class
# `self` is actually optional - it's implictly passed.
# If you include it in a parameter list, it's completely ignored.
def __init__(self):
self.foo = "bax"
# Look, a method!
def doAThing():
print("yay: " + self.foo)
print(Test)
let test = Test()
#print(test) # Removed because of pointer output
test.doAThing()
test.foo = "bar"
print(test.foo)
print('<bound method Test.doAThing of ' in str(test.doAThing))
test.doAThing()
class SuperClass():
def __init__(self):
self.a = "class"
def aMethod(self):
print("This is a great " + self.a + "!")
def __str__(self):
return "(I am a " + self.a + ")"
def __repr__(self):
return "(I am a " + self.a + ")"
def __getitem__(self, ind):
return "(get[" + str(ind) + "])"
def __setitem__(self, ind, val):
print("(set[" + str(ind) + "] = " + val + ")")
class SubClass(SuperClass):
def __init__(self):
self.a = "teapot"
let subclass = SubClass()
subclass.aMethod()
# Nope
#print(self)
# Also nope
#def notAMethod():
# print(self)
# Definitely nope
#def notAMethoDeither(self):
# print(self)
print("Subclass says:", subclass)
subclass.__getitem__(123)
print(subclass[123])
subclass[456] = "test"
print("Let's make a hashmap:")
let hash = dict()
hash["hello"] = "world"
print(hash["hello"])
print("Let's make some lists:")
let l = list()
print("Length before:", len(l))
l.append(1)
l.append(2)
l.append(3)
print("Length after:", len(l))
for j = 0; j < len(l); j = j + 1:
print("j=" + str(j) + ", list[j]=" + str(l[j]))
print("Can we call properties of strings?".__len__()) # Of course we can.
return 0