ab2311def9
Store function / operator types when they are registered.
2018-03-15 19:41:11 -07:00
429c0bde3e
Add syntax sugar for let.
2018-03-14 13:30:20 -07:00
bb61dbcd54
Add support for the return keyword.
2018-03-08 21:31:24 -08:00
f3f1cc8c43
Rename all the tree enums to have a prefix.
...
This prevents some possible naming collisions.
2018-03-08 21:13:25 -08:00
2d26e45e90
Add function node parsing.
2018-03-08 21:10:05 -08:00
2487cdebe0
Add the ability to parse types.
...
This ability is not integrated with the rest of the parser - in fact, the grammar for things like function declarations (where type declarations are necessary) is not yet determined.
2018-03-06 16:47:11 -08:00
45d955b8bd
Add utility functions for copying strings.
2018-03-06 16:45:55 -08:00
bb26405df0
Add a parse type struct, used to hold type data as it is parsed.
2018-03-06 16:45:43 -08:00
ac8e2ff418
Implement the do-while loop.
2018-02-27 12:30:37 -08:00
976b6d1b1a
Add code to parse while loops.
2018-02-27 11:57:45 -08:00
127a59ba50
Add comments to the debug header.
2018-02-27 11:08:14 -08:00
08513a2315
Add function to print to file.
2018-02-26 18:14:31 -08:00
65071d47b3
Add a function to print the parse tree.
2018-02-25 23:09:35 -08:00
88108bb3c0
Make the has string and has vector functions public.
2018-02-25 22:57:45 -08:00
52ac67026f
Remove function tokens. If functions are first class, they're variables.
2018-02-25 14:12:34 -08:00
7a84babf1e
Add basic function call parsing.
2018-02-24 20:08:17 -08:00
e5c2570bac
Implement parsing if expressions.
2018-02-20 16:38:02 -08:00
8ffcbb0ee2
Make blocks expressions, and add implicit void expression at block ends.
2018-02-18 21:05:06 -08:00
96b2dc234f
Remove currently unused node types from the tree code.
2018-02-18 19:42:54 -08:00
07284d1fb2
Add a table entry free function.
2018-02-17 19:53:33 -08:00
811704be25
Add a recursive tree freeing function.
2018-02-17 19:20:10 -08:00
b1aa2a4bf5
Implement associativity storage for operators.
2018-02-17 16:00:39 -08:00
8cd1d23120
Add functions to separately register different types of operators.
2018-02-17 14:01:48 -08:00
a3ce8fbd9c
Tone down the current token list, in favor of adding them later.
2018-02-17 13:32:55 -08:00
841c2f15e5
Add function to free tree nodes.
2018-02-17 12:55:50 -08:00
ee19f55058
Implement convenience functions for looking up the implemented entries.
2018-02-11 23:00:07 -08:00
72be209f0f
Implement two entry types and a function to store entries in table.
2018-02-11 22:50:08 -08:00
3de3f1ec00
Move structs used to hold custom operators and functions into new header
2018-02-11 22:38:40 -08:00
74034c7b76
Rename header files.
2018-02-11 22:32:42 -08:00
f67b98d7a6
Add a parser struct.
2018-02-11 22:26:19 -08:00
37a6f31b5f
Start the overarching library code, and move result enum elsewhere.
2018-02-11 22:11:33 -08:00
e5351c17a2
Fix code to stick to proper naming convention.
2018-02-11 21:22:01 -08:00
0958ecd1eb
Begin working on an initial implementation for the parser.
2018-02-10 22:40:34 -08:00
6d836a5513
Add parser state code and skeleton for the parsing procedure.
2018-02-10 22:22:51 -08:00
03f27bda18
Write a basic tree header file to hold the structure of the parsed code.
2018-02-10 22:15:51 -08:00
1a6a80d26b
Add the search feature.
2018-02-10 17:57:24 -08:00
a27bdc37f5
Begin working on a table struct to hold information during runtime.
2018-02-10 17:53:07 -08:00
0ff71a9389
Implement lexing code.
2018-02-10 17:13:59 -08:00
b46dccb70d
Add a utility header to convert error codes.
2018-02-10 16:01:08 -08:00
2db840288d
Implement the initialization and freeing of lexer.
2018-02-10 14:21:04 -08:00
10652048ab
Begin working on the lexer.
2018-02-10 13:57:16 -08:00