Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Smart indent matches partial command matches #133

Open
CareyJWilliams opened this issue Jan 23, 2022 · 4 comments
Open

Smart indent matches partial command matches #133

CareyJWilliams opened this issue Jan 23, 2022 · 4 comments
Labels

Comments

@CareyJWilliams
Copy link
Contributor

The basic-language support in ChoicescriptIDE/monaco-editor defines the "smart" indentation behaviour based on RegExes.
Whilst implementing *ifid I noticed that it's incorrectly treated as a indenting command, because the 'if' part is matched.
Unfortunately this seems to extend to invalid commands as well, for e.g.:

*ifishouldnotiwouldnot

Will trigger an automatic indent.

@danspinola
Copy link

I don't know if it'll help, but you can add a boundary anchor \b to the regex, forcing it to match the exact word:

      '))\\b.*\\s*$'

@CareyJWilliams
Copy link
Contributor Author

CareyJWilliams commented Apr 29, 2022

I don't know if it'll help, but you can add a boundary anchor \b to the regex, forcing it to match the exact word:

      '))\\b.*\\s*$'

Thanks Dan, I haven't yet had a chance to look at this (and many other bugs) in any great detail. Your suggestion certainly sounds feasible though, and I'd be very happy to take a PR ;)

@danspinola
Copy link

Sure, but you'll have to walk me through how to build it so I can test before pushing. 😅

@CareyJWilliams
Copy link
Contributor Author

CareyJWilliams commented May 2, 2022

Sure, but you'll have to walk me through how to build it so I can test before pushing. 😅

  1. Clone: https://github.com/ChoicescriptIDE/monaco-editor
  2. run npm install . in the directory
  3. Make any desired changes to src/basic-languages/choicescript/choicescript.ts
  4. Build with npm run release
  5. Run tests with npm run test (unit) and npm run smoketest (integration)

There aren't actually any unit tests for ChoiceScript yet, because Monarch unit tests are extremely painful to write and I'm expecting a lot of churn in this area.
Run them anyway just to make sure something hasn't gone horribly wrong, and then use a web-server to perform manual testing: e.g. python -m http.server and navigate to test/manual/index.html in a browser. Select ChoiceScript as the language (and sample) and ensure you're using a cs-* theme (or things won't highlight correctly):

Screenshot 2022-05-02 at 15 36 50

There's documentation and a playground for Monarch (the grammar framework) here: https://microsoft.github.io/monaco-editor/monarch.html.

That should get you going, but feel free to shout if you've got any more specific questions.

Don't worry about the validation errors, they're from the language server (which is very buggy atm) rather than the tokenizer.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants