Skip to content

Commit

Permalink
Add initial support for OpenBSD with attribute openbsd. Closes casey#…
Browse files Browse the repository at this point in the history
  • Loading branch information
vtamara committed Dec 1, 2024
1 parent beaec7e commit 1ac4393
Show file tree
Hide file tree
Showing 6 changed files with 31 additions and 13 deletions.
15 changes: 8 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ Yay, all your tests passed!
[`make`'s complexity and idiosyncrasies](#what-are-the-idiosyncrasies-of-make-that-just-avoids).
No need for `.PHONY` recipes!

- Linux, MacOS, and Windows are supported with no additional dependencies.
- Linux, MacOS, OpenBSD and Windows are supported with no additional dependencies.
(Although if your system doesn't have an `sh`, you'll need to
[choose a different shell](#shell).)

Expand Down Expand Up @@ -1986,6 +1986,7 @@ change their behavior.
| `[no-cd]`<sup>1.9.0</sup> | recipe | Don't change directory before executing recipe. |
| `[no-exit-message]`<sup>1.7.0</sup> | recipe | Don't print an error message if recipe fails. |
| `[no-quiet]`<sup>1.23.0</sup> | recipe | Override globally quiet recipes and always echo out the recipe. |
| `[openbsd]`<sup>1.x.0</sup> | recipe | Enable recipe on OpenBSD. |
| `[positional-arguments]`<sup>1.29.0</sup> | recipe | Turn on [positional arguments](#positional-arguments) for this recipe. |
| `[private]`<sup>1.10.0</sup> | alias, recipe | Make recipe, alias, or variable private. See [Private Recipes](#private-recipes). |
| `[script]`<sup>1.33.0</sup> | recipe | Execute recipe as script. See [script recipes](#script-recipes) for more details. |
Expand Down Expand Up @@ -2762,12 +2763,12 @@ Hola from a nushell script!
Hello from ruby!
```

On Unix-like operating systems, including Linux and MacOS, shebang recipes are
executed by saving the recipe body to a file in a temporary directory, marking
the file as executable, and executing it. The OS then parses the shebang line
into a command line and invokes it, including the path to the file. For
example, if a recipe starts with `#!/usr/bin/env bash`, the final command that
the OS runs will be something like `/usr/bin/env bash
On Unix-like operating systems, including Linux, MacOS and OpenBSD, shebang
recipes are executed by saving the recipe body to a file in a temporary
directory, marking the file as executable, and executing it. The OS then
parses the shebang line into a command line and invokes it, including the
path to the file. For example, if a recipe starts with `#!/usr/bin/env bash`,
the final command that the OS runs will be something like `/usr/bin/env bash
/tmp/PATH_TO_SAVED_RECIPE_BODY`.

Shebang line splitting is operating system dependent. When passing a command
Expand Down
2 changes: 1 addition & 1 deletion crates-io-readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,6 @@ test TEST: build

`just` produces detailed error messages and avoids `make`'s idiosyncrasies, so debugging a justfile is easier and less surprising than debugging a makefile.

It works on Linux, MacOS, and Windows.
It works on Linux, MacOS, OpenBSD and Windows.

Read more on [GitHub](https://github.com/casey/just).
4 changes: 4 additions & 0 deletions src/attribute.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ pub(crate) enum Attribute<'src> {
NoCd,
NoExitMessage,
NoQuiet,
Openbsd,
PositionalArguments,
Private,
Script(Option<Interpreter<'src>>),
Expand All @@ -36,6 +37,7 @@ impl AttributeDiscriminant {
| Self::NoCd
| Self::NoExitMessage
| Self::NoQuiet
| Self::Openbsd
| Self::PositionalArguments
| Self::Private
| Self::Unix
Expand Down Expand Up @@ -83,6 +85,7 @@ impl<'src> Attribute<'src> {
AttributeDiscriminant::NoCd => Self::NoCd,
AttributeDiscriminant::NoExitMessage => Self::NoExitMessage,
AttributeDiscriminant::NoQuiet => Self::NoQuiet,
AttributeDiscriminant::Openbsd => Self::Openbsd,
AttributeDiscriminant::PositionalArguments => Self::PositionalArguments,
AttributeDiscriminant::Private => Self::Private,
AttributeDiscriminant::Script => Self::Script({
Expand Down Expand Up @@ -131,6 +134,7 @@ impl Display for Attribute<'_> {
| Self::NoCd
| Self::NoExitMessage
| Self::NoQuiet
| Self::Openbsd
| Self::PositionalArguments
| Self::Private
| Self::Script(None)
Expand Down
4 changes: 3 additions & 1 deletion src/recipe.rs
Original file line number Diff line number Diff line change
Expand Up @@ -116,12 +116,14 @@ impl<'src, D> Recipe<'src, D> {
let windows = self.attributes.contains(&Attribute::Windows);
let linux = self.attributes.contains(&Attribute::Linux);
let macos = self.attributes.contains(&Attribute::Macos);
let openbsd = self.attributes.contains(&Attribute::Openbsd);
let unix = self.attributes.contains(&Attribute::Unix);

(!windows && !linux && !macos && !unix)
(!windows && !linux && !macos && !openbsd && !unix)
|| (cfg!(target_os = "windows") && windows)
|| (cfg!(target_os = "linux") && (linux || unix))
|| (cfg!(target_os = "macos") && (macos || unix))
|| (cfg!(target_os = "openbsd") && (openbsd || unix))
|| (cfg!(windows) && windows)
|| (cfg!(unix) && unix)
}
Expand Down
9 changes: 5 additions & 4 deletions tests/attributes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ fn all() {
[macos]
[windows]
[linux]
[openbsd]
[unix]
[no-exit-message]
foo:
Expand Down Expand Up @@ -48,7 +49,7 @@ fn multiple_attributes_one_line() {
Test::new()
.justfile(
"
[macos, windows,linux]
[macos, windows,linux,openbsd]
[no-exit-message]
foo:
exit 1
Expand All @@ -64,7 +65,7 @@ fn multiple_attributes_one_line_error_message() {
Test::new()
.justfile(
"
[macos, windows linux]
[macos, windows linux,openbsd]
[no-exit-message]
foo:
exit 1
Expand All @@ -75,7 +76,7 @@ fn multiple_attributes_one_line_error_message() {
error: Expected ']', ':', ',', or '(', but found identifier
——▶ justfile:1:17
1 │ [macos, windows linux]
1 │ [macos, windows linux,openbsd]
│ ^^^^^
",
)
Expand All @@ -88,7 +89,7 @@ fn multiple_attributes_one_line_duplicate_check() {
Test::new()
.justfile(
"
[macos, windows, linux]
[macos, windows, linux, openbsd]
[linux]
foo:
exit 1
Expand Down
10 changes: 10 additions & 0 deletions tests/os_attributes.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,11 @@ fn os() {
[linux]
foo:
echo quxx
[openbsd]
foo:
echo openbsd
",
)
.stdout(if cfg!(target_os = "macos") {
Expand All @@ -55,6 +60,8 @@ fn os() {
"baz\n"
} else if cfg!(target_os = "linux") {
"quxx\n"
} else if cfg!(target_os = "openbsd") {
"openbsd\n"
} else {
panic!("unexpected os family")
})
Expand All @@ -64,6 +71,8 @@ fn os() {
"echo baz\n"
} else if cfg!(target_os = "linux") {
"echo quxx\n"
} else if cfg!(target_os = "openbsd") {
"echo openbsd\n"
} else {
panic!("unexpected os family")
})
Expand All @@ -78,6 +87,7 @@ fn all() {
[macos]
[windows]
[linux]
[openbsd]
[unix]
foo:
echo bar
Expand Down

0 comments on commit 1ac4393

Please sign in to comment.