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>
6 lines
263 B
Text
6 lines
263 B
Text
{"textDocument": {"uri": "file:///compHeader.lean"},
|
|
"position": {"line": 2, "character": 22}}
|
|
{"items":
|
|
[{"label": "veryLongNam", "kind": 6, "detail": "Sort u_1"},
|
|
{"label": "veryLongNameForCompletion", "kind": 21, "detail": "Type"}],
|
|
"isIncomplete": true}
|