This PR adds per-package server options to resolve #2455. It is based on the previous work in #2456, but takes a different approach: options are loaded for the specific file in the file worker when `print-paths` is called, instead of loading them in the watchdog with a separate Lake command. This change addresses review comments made in #2456. In doing so, it introduces two new Lake config fields: - `leanOptions`: `-D` flag options that are passed to both the language server and `lean` when building. - `moreServerOptions`: `-D` flag options that are passed to the language server. Since `print-paths` must also accept a file path to compute the options for that file, this PR is changing the API for `print-paths`. As there have been numerous complaints about the name `print-paths`, I also decided to change it to `setup-file` in this PR, since it would break compatibility with the old Lake API anyways. This PR deprecates the Lakefile field `moreServerArgs` in favor of `moreGlobalServerArgs`, as suggested in the review for #2456. Fixes #2455 --------- Co-authored-by: digama0 <mcarneir@andrew.cmu.edu>
8 lines
448 B
Text
8 lines
448 B
Text
{"textDocument": {"uri": "file:///goalIssue.lean"},
|
|
"position": {"line": 2, "character": 12}}
|
|
{"rendered": "```lean\nx : Nat\nthis : x + x = x + x\n⊢ 0 + x = x\n```",
|
|
"goals": ["x : Nat\nthis : x + x = x + x\n⊢ 0 + x = x"]}
|
|
{"textDocument": {"uri": "file:///goalIssue.lean"},
|
|
"position": {"line": 8, "character": 12}}
|
|
{"rendered": "```lean\ncase zero\n⊢ 0 + Nat.zero = Nat.zero\n```",
|
|
"goals": ["case zero\n⊢ 0 + Nat.zero = Nat.zero"]}
|