@masala/parser
Version:
Masala Parser
84 lines (75 loc) • 3.81 kB
JavaScript
import { describe, it, expect } from 'vitest'
import { GenLex } from '../../lib/genlex/genlex'
import { F, C } from '../../lib/parsec/index' // Added .js extension
import Streams from '../../lib/stream'
function createParser() {
const genlex = new GenLex()
genlex.setSeparatorsParser(F.not(C.charIn('+-<>[],.')))
// Define tokens for each Brainfuck command
genlex.keywords(['+', '-', '<', '>', '[', ']', ',', '.'])
// The grammar will collect all recognized tokens
const grammar = F.any()
.map((token) => token.value)
.rep()
return genlex.use(grammar)
}
describe('GenLex Brainfuck Tokenizer Tests', () => {
it('parser is valid', () => {
let hW =
'++++++++[>++++[>++>+++>+++>+<<<<-]>+>+>->>+[<]<-]>>.>---.+++++++..+++.>>.<-.<.+++.------.--------.>>+.>++.'
let parser = createParser()
const response = parser.parse(Streams.ofString(hW))
expect(response.isAccepted()).toBe(true)
// Check if all characters that are commands were tokenized
// The original test's response.offset was the count of actual Brainfuck command characters.
const actualBfChars = hW
.split('')
.filter((char) => '+-<>[],.'.includes(char)).length
expect(response.value.size()).toBe(actualBfChars)
// The GenLex offset would be the number of tokens found.
expect(response.offset).toBe(actualBfChars)
})
it('comments are accepted', () => {
let hW = `++++++++ Set Cell
[
>++++ Add 4 to Cell
[ as the cell will be cleared by the loop
>++ Add 2 to Cell
>+++ Add 3 to Cell
>+++ Add 3 to Cell
>+ Add 1 to Cell
<<<<- Decrement the loop counter in Cell
] Loop till Cell
>+ Add 1 to Cell
>+ Add 1 to Cell
>- Subtract 1 from Cell
>>+ Add 1 to Cell
[<] Move back to the first zero cell you find; this will
be Cell
<- Decrement the loop Counter in Cell
] Loop till Cell
Cell No : 0 1 2 3 4 5 6
Contents: 0 0 72 104 88 32 8
Pointer : ^
>>. Cell
>---. Subtract 3 from Cell
+++++++..+++. Likewise for 'llo' from Cell
>>. Cell
<-. Subtract 1 from Cell
<. Cell
+++.------.--------. Cell
>>+. Add 1 to Cell
>++. And finally a newline from Cell
let parser = createParser()
const response = parser.parse(Streams.ofString(hW))
expect(response.isAccepted()).toBe(true)
// The original test asserted offset 106. This is the count of actual Brainfuck command characters.
const bfCommandCharsInString = hW
.split('')
.filter((char) => '+-<>[],.'.includes(char)).length
// response.offset should be the number of tokens (bfCommandCharsInString)
expect(response.offset).toBe(bfCommandCharsInString)
expect(response.value.size()).toBe(bfCommandCharsInString)
expect(bfCommandCharsInString).toBe(106) // Validating the count itself based on original test
})
})