Provide a way to offset line numbers in wrapped scripts #21919
Labels
area:compiler-plugins
Issues tied with handling of compiler plugins.
area:positions
area:tooling
itype:enhancement
Many Scala tools wrap snippets of Scala code before execution: Mill, Ammonite, ScalaCLI, and others. In Scala 2, we could use a post-parser compiler plugin to fix up all the line numbers and positions, such that source locations reported by
sourcecode.Line
/sourcecode.File
and downstream error messages surfaced by typer or runtime exceptions were properly attributed.In Scala 3, this is no longer possible. Thus tools like Mill/Ammonite/ScalaCLI now need a three-pronged approach:
sourcecode.Line
andsourcecode.File
, and for post-typer compile error messagesThis logic has been implemented at least three times, with @alexarchambault being the author of the Ammonite and ScalaCLI copies, and @bishabosha being the author of the Mill copy. To be clear, the Scala 2 approach wasn't perfect (parser errors would still use the wrong line number), so both workflows can be improved upon
It would be nice if we could provide something built in to just make the Scala compiler subtract certain lines from the line number reporting automatically. Mill and Ammonite internally use magic comments (see below) to power the Scala 2 compiler plugin and the Scala 3 triple code paths (above), and perhaps similar magic comments could be adapted to work generally across all Scala 3 tooling
The existing
dotty.tools.SourceFile.headerPattern
is similar, but ultimately the exact opposite of this use case:headerPattern
is meant to tell the compiler to ignore lines of code during compilation and add the ignored line count for error reporting,CC @odersky we discussed this briefly in lausanne
The text was updated successfully, but these errors were encountered: