| Commit message (Collapse) | Author | Age | Files | Lines | |
|---|---|---|---|---|---|
| * | Removes lots of old atom based code from walk | Charlie Stanton | 2023-07-19 | 1 | -11/+0 | 
| | | |||||
| * | Huge refactor to a more value based system, doing away with terminals. Also ↵ | Charlie Stanton | 2023-07-19 | 9 | -507/+1254 | 
| | | | | | introduces unit testing | ||||
| * | Update subex , literal to no longer include terminals | Charlie Stanton | 2023-04-26 | 2 | -7/+7 | 
| | | |||||
| * | Improves RunTransducer by reusing state slices for states and newStates | Charlie Stanton | 2023-04-25 | 1 | -1/+4 | 
| | | |||||
| * | Improves performance of pruneStates by modifying states in place | Charlie Stanton | 2023-04-25 | 1 | -5/+7 | 
| | | |||||
| * | Refines storing and loading to use ids generated when the subex is compiled ↵ | Charlie Stanton | 2023-04-25 | 4 | -67/+117 | 
| | | | | | instead of the runes | ||||
| * | Simplify the OutputStack, improves performance by simplifying from an ↵ | Charlie Stanton | 2023-04-24 | 1 | -25/+21 | 
| | | | | | interface to a single struct | ||||
| * | Adds a check to end subex execution early if no viable branches remain | Charlie Stanton | 2023-04-24 | 1 | -0/+3 | 
| | | |||||
| * | Remove redundant subex/main.main function | Charlie Stanton | 2023-04-24 | 1 | -49/+0 | 
| | | |||||
| * | Replaces the interfaces implementation of Atom with a tagged union based ↵ | Charlie Stanton | 2023-04-21 | 4 | -47/+42 | 
| | | | | | implementation | ||||
| * | Changes the implementation of Atomise and Compound to no longer use goroutines | Charlie Stanton | 2023-04-21 | 2 | -9/+14 | 
| | | | | | This results in a massive performance boost, ~4x speedup | ||||
| * | Add :xyz: replacement syntax that removes whatever is before it and inserts ↵ | Charlie Stanton | 2023-04-21 | 3 | -5/+41 | 
| | | | | | whatever is inside it | ||||
| * | Adds String methods to all SubexASTs for debugging purposes | Charlie Stanton | 2023-04-21 | 1 | -0/+51 | 
| | | |||||
| * | Radically changes precedences so concatenation is now the strongest | Charlie Stanton | 2023-04-21 | 1 | -13/+13 | 
| | | | | | We'll see if this sticks | ||||
| * | Add ^xyz^ as a shorthand for ="xyz"= in subex | Charlie Stanton | 2023-04-21 | 1 | -7/+18 | 
| | | |||||
| * | Add subex syntax to copy across booleans, numbers, strings and values | Charlie Stanton | 2023-04-21 | 3 | -1/+137 | 
| | | |||||
| * | Properly exports all SubexASTs | Charlie Stanton | 2023-04-20 | 2 | -59/+59 | 
| | | |||||
| * | Add ~xyz~ shorthand for =`xyz`= | Charlie Stanton | 2023-04-20 | 1 | -1/+10 | 
| | | |||||
| * | Fix bug that would crash if given an empty subex | Charlie Stanton | 2023-04-20 | 1 | -1/+5 | 
| | | |||||
| * | Remove the @, ~ and # syntax for terminal literals | Charlie Stanton | 2023-04-20 | 1 | -30/+0 | 
| | | |||||
| * | Replaces the start and end terminals of strings with a single terminal, with ↵ | Charlie Stanton | 2023-04-20 | 1 | -1/+11 | 
| | | | | | " as a literal for it | ||||
| * | Change output syntax to =xyz= instead of "xyz" | Charlie Stanton | 2023-04-20 | 1 | -3/+3 | 
| | | | | | This frees up " to be used for a string terminal literal | ||||
| * | Adds non-string literal syntax to subex | Charlie Stanton | 2023-04-20 | 2 | -0/+89 | 
| | | |||||
| * | Adds parsing substitute commands, though executing them currently does nothing | Charlie Stanton | 2023-04-19 | 1 | -0/+8 | 
| | | |||||
| * | Changes the parsing API for subex to be more suitable to being part of a ↵ | Charlie Stanton | 2023-04-19 | 3 | -54/+60 | 
| | | | | | larger program | ||||
| * | Adds a dummy method to atom so the compiler checks that only valid atoms are ↵ | Charlie Stanton | 2023-04-19 | 1 | -6/+6 | 
| | | | | | allowed | ||||
| * | Adds the NOT operator | Charlie Stanton | 2023-04-19 | 3 | -0/+41 | 
| | | |||||
| * | Adds the reciprocal operator | Charlie Stanton | 2023-04-19 | 3 | -0/+51 | 
| | | |||||
| * | Fixes internal error messages for arithmetic functions | Charlie Stanton | 2023-04-19 | 1 | -4/+4 | 
| | | |||||
| * | Adds the negate operator | Charlie Stanton | 2023-04-19 | 3 | -0/+49 | 
| | | | | | Negates all of the numbers produced by its content subex | ||||
| * | Combines sum and product into an arithmetic state that contains a function ↵ | Charlie Stanton | 2023-04-19 | 3 | -115/+101 | 
| | | | | | | | for it's operation Creates arithmetic.go which will house all of these functions | ||||
| * | Adds product/and operator | Charlie Stanton | 2023-04-19 | 3 | -22/+87 | 
| | | |||||
| * | Adjusts the sum operator to act as boolean OR when all inputs are booleans | Charlie Stanton | 2023-04-19 | 1 | -5/+15 | 
| | | |||||
| * | Replaces a few instances of SubexStates with pointers as they should be | Charlie Stanton | 2023-04-19 | 2 | -2/+2 | 
| | | | | | This potentially avoids bugs/errors and also improves the performance of pruning | ||||
| * | Changes parser so the storing operator is postfix instead of prefix | Charlie Stanton | 2023-04-19 | 1 | -14/+10 | 
| | | |||||
| * | Replaces the parent/child implementation for operators like store and sum ↵ | Charlie Stanton | 2023-04-19 | 3 | -168/+119 | 
| | | | | | | | | | | with an output stack Previously a store state was a parent of another state machine that it would run inside of itself in order to capture the output to be stored. This was limited as the greedyness of the child would not be transferred to the parent. The new implementation gives states more control over the output state and turns it into a stack. By pushing to the stack before the child and popping afterwards, all of the child's output can be retrieved while the child is very much part of the complete machine. | ||||
| * | Adds casting strings to numbers in the sum operator | Charlie Stanton | 2023-04-19 | 2 | -13/+36 | 
| | | |||||
| * | Creates functions for compounding atoms back into values in the walk module ↵ | Charlie Stanton | 2023-04-18 | 1 | -73/+19 | 
| | | | | | and uses them in subex/main | ||||
| * | Refactors store and sum states to use the new SubexParentState for states ↵ | Charlie Stanton | 2023-04-18 | 1 | -53/+104 | 
| | | | | | that run machines within themselves | ||||
| * | Fixes bug where stores wouldn't work inside other stores sometimes | Charlie Stanton | 2023-04-18 | 1 | -1/+1 | 
| | | | | | Something like $a($b(test)..."$b") wouldn't work as expected, this works now | ||||
| * | Adds the sum operator | Charlie Stanton | 2023-04-18 | 3 | -9/+78 | 
| | | | | | Currently doesn't parse strings as each atom is considered independantly. Instead individual characters in strings can be cast | ||||
| * | Removes try, maybe, maximise and minimise | Charlie Stanton | 2023-04-18 | 2 | -63/+1 | 
| | | | | | These are no longer necessary and have been replaced by repeat | ||||
| * | Adds the repeat construct, obsoleting maximise, minimise, try, maybe and ↵ | Charlie Stanton | 2023-04-18 | 3 | -12/+151 | 
| | | | | | | | probably more The repeat construct repeats a subex a number of times, this number is based on a provided list which is ordered by priority and can be unbounded. | ||||
| * | Fix bug where SubexStoreState is sometimes not a pointer | Charlie Stanton | 2023-03-15 | 1 | -1/+1 | 
| | | |||||
| * | Renames TransducerOutput to OutputContent (and related types) and moves into ↵ | Charlie Stanton | 2023-03-05 | 4 | -29/+28 | 
| | | | | | main/subexstate.go | ||||
| * | Changes the slot map so only runes can be used as slots | Charlie Stanton | 2023-03-05 | 2 | -7/+5 | 
| | | |||||
| * | Renames walk.Datum to walk.Atom | Charlie Stanton | 2023-03-05 | 4 | -89/+105 | 
| | | |||||
| * | Refactors out terminator literal stuff into a separate parsing function | Charlie Stanton | 2023-03-05 | 1 | -117/+37 | 
| | | |||||
| * | Adds syntax to recognise and deal with starting and ending arrays, maps and ↵ | Charlie Stanton | 2023-02-26 | 1 | -0/+123 | 
| | | | | | strings | ||||
| * | Replace append with walk.ConcatData in many places to fix bug to do with ↵ | Charlie Stanton | 2023-02-26 | 2 | -7/+7 | 
| | | | | | | | semantics of append When doing append, be very careful as it does make changes in place to the underlying array of the slice which may affect other slices | ||||
