diff options
author | Chimrod <> | 2023-09-22 15:06:51 +0200 |
---|---|---|
committer | Chimrod <> | 2023-09-22 15:06:51 +0200 |
commit | 91d8d283760e5da4c777fad5ffbd29b9bf3ca71d (patch) | |
tree | 149af37d1b5c09a580ce477960b0b299b28128ae /readme.md | |
parent | 5b42128cac499b6f54d8e882e2363f5e7135b366 (diff) |
Updated the readme
Diffstat (limited to 'readme.md')
-rw-r--r-- | readme.md | 46 |
1 files changed, 45 insertions, 1 deletions
@@ -1,4 +1,48 @@ # QSP Syntax Parser -This tool is a syntax analyzer for the QSP Language. +This tool is a syntax analyzer for the QSP Language. It contains a syntaxic +parser able to read the QSP language, and allow some analysis over it. + +The application does not use regexes, but translates the source qsp file using +a grammar to represent each instruction. + +In this way, the application is able to : + +1. Point out an error in the source code, indicating the line that could not be + translated. +2. Perform operations on the file representation. + +## Reading QSP + +The QSP language was not designed to be processed in this way. There are +ambivalent cases that cannot be represented cleanly via a grammar. + +An example is the `!` character, which can indicate the start of a comment, or +an inequality operator. + +Another example is the `*` character, which can be the first character of an +instruction, or a multiplication operation. For example: + +- `*clr()` is a valid instruction, but `5 *clr()` is not. +- `*rnd()` is an invalid instruction, but `5 *rnd()` is valid. +(As a bonus `rnd* rnd()` is also valid…) + +What's more, the language is very permissive, allowing for structures that are +actually incorrect. + +For example: + +``` +if $PARGS[0] = 'Day1': +end + +elseif $ARGS[0] = 'Week1': +end +``` + +As a result, the application may pick up errors on particular cases that are +nonetheless valid. I've tried to respect the syntax of the QSP language as much +as possible, but on borderline cases, I consider that being stricter is +positive. + |