pocketlang/docs/TODO.txt
2021-06-13 21:57:54 +05:30

84 lines
2.3 KiB
Plaintext

// To implement.
- Refactor fiber into a module and is_done as an attribute.
- def f(x)
f(x) ## not tco, unless return f(x)
end
if a function's last statement is a call, we can perform tco.
- Recursive call to anonymous functions.
- move moduleAddGlobalInternal() to var.h (also other var functions).
- refactor build.bat batch script to powershell
refactor makefile and setup a github action.
- Hex, binary literals and floats like ".5".
- change or add => to_string() to value.as_string
and add as_repr, as_bool.
- Make bool and num are incompatible
1 + true - make it not allowed.
- support new line just after '=' (and other places)
- REPL error message should be the first one (not the last).
>>> def f()
... _f = func()
... _f() // _f not defined (no closure).
... end
Error: Expected an expression // expected Name '_f' not defined.
- literal function recursive call.
func(a, b)
self(a, b) // Something like this.
end
- Implement argparse.
- -v --version
- emit opcodes
- maybe write a similer .pyc file for pocket
- --docs to generate docs from cstring.
- dump compiled code to a file.
- In keyword.
- Structs (maybe enums).
- Implement file IO (require structs).
- Implement utf8 support.
- Implement gdb like debugger (add color print for readability).
- Initialize imported scripts (require fiber based vm).
- Complete all the TODO; macros.
- implement MAX_ARGC checks (would cause a buffer overflow if not)
when compiling and calling a function (also in fibers).
// Low priority.
- Ignore line with '\' character.
- Make it possible to override function names.
- To do so the functions and global variables should be in the same
buffer as the property of the script.
- Function docstring property.
- Union tagging alter in var.
- Github actions.
// Add more.
- Single header for embedding (script in pk, require file IO).
- Complete core methods.
- Complete var methods.
- Complete core functions.
- Complete builtin operators.
- Complete opcodes.
- Complete core libs.
- Complete the docs.
- More Tests.
// Bugs.
It's at pre-alpha and every thing is left to
implement, and nothing would be work as expected.
- f = func print() end; print(f) # semicollon should be there.
def f() print() end print(f) # semicollon should be there.
make it okey to use semicollon freely like new lines.