summaryrefslogtreecommitdiff
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* src/paca.mjs (rangeStateStep): Refine indentation and alignmentEuAndreh2025-07-131-3/+3
|
* src/paca.mjs ({escaping,range}StateStep): Add leading underscore to ignored argsEuAndreh2025-07-131-2/+2
|
* src/paca.mjs (rangeStateStep): Return ValueError when range number decreasesEuAndreh2025-07-131-1/+2
|
* Hoist `numFromDigits()` before its usageEuAndreh2025-07-131-5/+5
| | | | | | | | | * src/paca.mjs (numFromDigits): Move it to before the *StateStep functions, as it is now used in `rangeStateStep()` function. So instead of letting it be defined afters its usage, move it up. * tests/paca.mjs: Do the same hoisting to the import of the `numFromDigits` name, to the definition of `test_numFromDigits` and its inclusion in the order of the call to `runTests()`.
* Add "[" to the possible characters of TRANSITION_FNS.EuAndreh2025-07-131-0/+12
| | | | | | | | | | | | | | Introducing "[" now we will start to write the code to parse the character class expressions, i.e. [a-z0-9]. The `context` key will contain a `set` with all the literal characters that were found, and all the ranges too. For parsing the ranges, a `range` key equivalent to the one for the {m,n} range is used. Despite the superficial syntax being simmilar, its logic, semantic and implementation will be different. * src/paca.mjs (TRANSITION_FNS) <"[">: Add new transition function for handling the start of a character class expression. * tests/paca.mjs (TRANSITION_FNS): Add a singular test entry, that exercises the conditionless body of the function.
* Add simple test for TRANSITION_FNSEuAndreh2025-07-131-2/+2
| | | | | | | | | | * src/paca.mjs (TRANSITION_FNS): Add trailing underscore to ignored arguments, even though it breaks the name of the `_state` and `context` destructuring arguments. * tests/paca.mjs (test_TRANSITION_FNS): Add new test function with a single case for each transition character. Since these transitions are unconditional and contain no logic, this single sample test is enough to cover for all of its behaviour.
* Revert "src/paca.mjs: Temporarily export internal functions"EuAndreh2025-07-121-4/+4
| | | | This reverts commit 15f206e4940cb80ff98eea7c376d9c618f80ed0e.
* src/paca.mjs: Temporarily export internal functionsEuAndreh2025-07-121-4/+4
|
* src/paca.mjs (tokenizeRegexStep): Simplify bodyEuAndreh2025-07-111-105/+127
| | | | | | | | | | When handling a custom state, dispatch it to the appropriate function in `STATE_FNS`; and when looking for chars that enters these custom states, dispatch it to the appropriate function in `TRANSITION_FNS`. The body of each part didn't change, so no tests had to be modified. But now we can write specific tests for each case, and remove the bulk of the logic out of `tokenizeRegexFn()`.
* src/paca.mjs (tokenizeRegexStep): Fix missing concat when escapingEuAndreh2025-07-111-5/+8
|
* src/paca.mjs: Remove calls to arr.concat([]) with unneeded wrapping ↵EuAndreh2025-07-111-14/+6
| | | | singleton array
* src/paca.mjs (tokenizeRegexStep): Support tokenizing range exps {m,n}EuAndreh2025-07-111-2/+98
|
* src/paca.mjs (tokenizeRegexStep): Include `context` key in reduced stateEuAndreh2025-07-111-3/+8
|
* src/paca.mjs: Move error detection from tokenizeRegexStep => tokenizeRegexEuAndreh2025-07-111-8/+12
|
* src/paca.mjs: Remove unused repeat(3) importEuAndreh2025-07-111-1/+1
|
* Finish implementation of unit testsEuAndreh2025-07-091-14/+17
|
* Implement v0 version of NFA and DFA; WIP testsEuAndreh2025-07-071-0/+436