-
-
Notifications
You must be signed in to change notification settings - Fork 377
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(features): enable building with all-features (#286)
Before this change, it wasn't possible to build all features and all targets at the same time, which prevents rust-analyzer from working for the whole project. Adds a bacon.toml file to the project, which is used by bacon https://dystroy.org/bacon/ Configures docs.rs to show the feature flags that are necessary to make modules / types / functions available.
- Loading branch information
Showing
4 changed files
with
105 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
# This is a configuration file for the bacon tool | ||
# | ||
# Bacon repository: https://github.com/Canop/bacon | ||
# Complete help on configuration: https://dystroy.org/bacon/config/ | ||
# You can also check bacon's own bacon.toml file | ||
# as an example: https://github.com/Canop/bacon/blob/main/bacon.toml | ||
|
||
default_job = "check" | ||
|
||
[jobs.check] | ||
command = ["cargo", "check", "--all-features", "--color", "always"] | ||
need_stdout = false | ||
|
||
[jobs.check-all] | ||
command = ["cargo", "check", "--all-targets", "--all-features", "--color", "always"] | ||
need_stdout = false | ||
|
||
[jobs.clippy] | ||
command = [ | ||
"cargo", "clippy", | ||
"--all-targets", | ||
"--color", "always", | ||
] | ||
need_stdout = false | ||
|
||
[jobs.test] | ||
command = [ | ||
"cargo", "test", | ||
"--all-features", | ||
"--color", "always", | ||
"--", "--color", "always", # see https://github.com/Canop/bacon/issues/124 | ||
] | ||
need_stdout = true | ||
|
||
[jobs.doc] | ||
command = [ | ||
"cargo", "+nightly", "doc", | ||
"-Zunstable-options", "-Zrustdoc-scrape-examples", | ||
"--all-features", | ||
"--color", "always", | ||
"--no-deps", | ||
] | ||
env.RUSTDOCFLAGS = "--cfg docsrs" | ||
need_stdout = false | ||
|
||
# If the doc compiles, then it opens in your browser and bacon switches | ||
# to the previous job | ||
[jobs.doc-open] | ||
command = [ | ||
"cargo", "+nightly", "doc", | ||
"-Zunstable-options", "-Zrustdoc-scrape-examples", | ||
"--all-features", | ||
"--color", "always", | ||
"--no-deps", | ||
"--open", | ||
] | ||
env.RUSTDOCFLAGS = "--cfg docsrs" | ||
need_stdout = false | ||
on_success = "job:doc" # so that we don't open the browser at each change | ||
|
||
# You can run your application and have the result displayed in bacon, | ||
# *if* it makes sense for this crate. You can run an example the same | ||
# way. Don't forget the `--color always` part or the errors won't be | ||
# properly parsed. | ||
[jobs.run] | ||
command = [ | ||
"cargo", "run", | ||
"--color", "always", | ||
# put launch parameters for your program behind a `--` separator | ||
] | ||
need_stdout = true | ||
allow_warnings = true | ||
|
||
[jobs.check-crossterm] | ||
command = ["cargo", "check", "--color", "always", "--all-targets", "--no-default-features", "--features", "crossterm"] | ||
|
||
[jobs.check-termion] | ||
command = ["cargo", "check", "--color", "always", "--all-targets", "--no-default-features", "--features", "termion"] | ||
|
||
[jobs.check-termwiz] | ||
command = ["cargo", "check", "--color", "always", "--all-targets", "--no-default-features", "--features", "termwiz"] | ||
|
||
# You may define here keybindings that would be specific to | ||
# a project, for example a shortcut to launch a specific job. | ||
# Shortcuts to internal functions (scrolling, toggling, etc.) | ||
# should go in your personal global prefs.toml file instead. | ||
[keybindings] | ||
# alt-m = "job:my-job" | ||
ctrl-c = "job:check-crossterm" | ||
ctrl-t = "job:check-termion" | ||
ctrl-w = "job:check-termwiz" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters