171 lines
4.5 KiB
Python
Executable File
171 lines
4.5 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(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 __get__(self, ind):
|
|
return "(get[" + str(ind) + "])"
|
|
def __set__(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.__get__(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
|