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

Improved error reporting #72

Open
kevinramharak opened this issue Aug 24, 2020 · 2 comments
Open

Improved error reporting #72

kevinramharak opened this issue Aug 24, 2020 · 2 comments
Labels
enhancement New feature or request error handling Related to Oak's error handling system

Comments

@kevinramharak
Copy link
Contributor

I have been doing a bit of research on how to improve error reporting by capturing information about the original source file. Larlpop does not support anything out of the box except for 2 pseudo symbols 'documented' here.

I took a look at how other programming languages use this and it seems codespan is a fairly mature solution. A more barebones solution like codemap might be easier to use to prototype.

This would not only improve error reporting by showing what part of the source code contains the error but sets up a next step like sourcemaps. I think the javascript target is a great environment to test sourcemaps since it has great sourcemap support (at least on chrome). It might even be possible have the debugger work straight away if the sourcemaps are implemented correctly.

In my attempt to set up an MVP I ran into a few problems:

  • Include needs to be moved to TIR #68 needs to be resolved before a solid implentation can be included
  • The first file is compiled in bin.rs where the file name and contents are available. The rest of the files are only accessible inside tir/hir. This would make it a bit akward with passing around the meta data structure.
  • It is a bit unclear who should own this data, currently a new parser is created in lib.rs with parser::ProgramParser::new(). Maybe this data structure should be owned by the parser and the instance should be kept and passed to any include statements so a parser owns the complete meta data of a oak program?
@adam-mcdaniel adam-mcdaniel added the enhancement New feature or request label Aug 24, 2020
@adam-mcdaniel
Copy link
Owner

Issue #68 has been fixed by PR #74, so now this might be something we could start working on.

The main problem is that 99% of the typechecking errors are in MIR, and by this time, most of the code has been twisted and manipulated into code that's different from the user's. Would codespan make it possible to do better error messages despite this?

@kevinramharak
Copy link
Contributor Author

kevinramharak commented Aug 25, 2020

Well, as far as I know we have to capture from which tokens the AST nodes are created and then pass them down correctly. The @L and @R in lalrpop are indexes into a &str so those can be captured to form some kind of Token or MetaData structure. Those indexes and a file name would be enough meta data to map it back to the original source code no matter how far down the IR you go. At least that is how I infer how it should work.

@adam-mcdaniel adam-mcdaniel added the error handling Related to Oak's error handling system label Aug 25, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request error handling Related to Oak's error handling system
Projects
None yet
Development

No branches or pull requests

2 participants