Skip to content

Commit

Permalink
Switch to --alias-style flag
Browse files Browse the repository at this point in the history
  • Loading branch information
marcaddeo committed Oct 31, 2024
1 parent 7cebc58 commit 4505816
Show file tree
Hide file tree
Showing 8 changed files with 99 additions and 77 deletions.
8 changes: 8 additions & 0 deletions src/alias_style.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
use super::*;

#[derive(Debug, PartialEq, Clone, ValueEnum)]
pub(crate) enum AliasStyle {
Inline,
InlineLeft,
Recipe,
}
39 changes: 16 additions & 23 deletions src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ use {

#[derive(Debug, PartialEq)]
pub(crate) struct Config {
pub(crate) alias_style: AliasStyle,
pub(crate) check: bool,
pub(crate) color: Color,
pub(crate) command_color: Option<ansi_term::Color>,
Expand All @@ -18,14 +19,12 @@ pub(crate) struct Config {
pub(crate) dump_format: DumpFormat,
pub(crate) explain: bool,
pub(crate) highlight: bool,
pub(crate) inline_aliases_left: bool,
pub(crate) invocation_directory: PathBuf,
pub(crate) list_heading: String,
pub(crate) list_prefix: String,
pub(crate) list_submodules: bool,
pub(crate) load_dotenv: bool,
pub(crate) no_aliases: bool,
pub(crate) no_inline_aliases: bool,
pub(crate) no_dependencies: bool,
pub(crate) one: bool,
pub(crate) search_config: SearchConfig,
Expand Down Expand Up @@ -82,6 +81,7 @@ mod cmd {
}

mod arg {
pub(crate) const ALIAS_STYLE: &str = "ALIAS_STYLE";
pub(crate) const ARGUMENTS: &str = "ARGUMENTS";
pub(crate) const CHECK: &str = "CHECK";
pub(crate) const CHOOSER: &str = "CHOOSER";
Expand All @@ -95,7 +95,6 @@ mod arg {
pub(crate) const EXPLAIN: &str = "EXPLAIN";
pub(crate) const GLOBAL_JUSTFILE: &str = "GLOBAL-JUSTFILE";
pub(crate) const HIGHLIGHT: &str = "HIGHLIGHT";
pub(crate) const INLINE_ALIASES_LEFT: &str = "INLINE-ALIASES-LEFT";
pub(crate) const JUSTFILE: &str = "JUSTFILE";
pub(crate) const LIST_HEADING: &str = "LIST-HEADING";
pub(crate) const LIST_PREFIX: &str = "LIST-PREFIX";
Expand All @@ -104,7 +103,6 @@ mod arg {
pub(crate) const NO_DEPS: &str = "NO-DEPS";
pub(crate) const NO_DOTENV: &str = "NO-DOTENV";
pub(crate) const NO_HIGHLIGHT: &str = "NO-HIGHLIGHT";
pub(crate) const NO_INLINE_ALIASES: &str = "NO-INLINE-ALIASES";
pub(crate) const ONE: &str = "ONE";
pub(crate) const QUIET: &str = "QUIET";
pub(crate) const SET: &str = "SET";
Expand Down Expand Up @@ -139,6 +137,16 @@ impl Config {
.placeholder(AnsiColor::Green.on_default())
.usage(AnsiColor::Yellow.on_default()),
)
.arg(
Arg::new(arg::ALIAS_STYLE)
.long("alias-style")
.env("JUST_ALIAS_STYLE")
.action(ArgAction::Set)
.value_parser(clap::value_parser!(AliasStyle))
.default_value("inline")
.help("Set the style that the list command will display aliases")
.conflicts_with(arg::NO_ALIASES),
)
.arg(
Arg::new(arg::CHECK)
.long("check")
Expand Down Expand Up @@ -238,15 +246,6 @@ impl Config {
.help("Highlight echoed recipe lines in bold")
.overrides_with(arg::NO_HIGHLIGHT),
)
.arg(
Arg::new(arg::INLINE_ALIASES_LEFT)
.long("inline-aliases-left")
.env("JUST_INLINE_ALIASES_LEFT")
.action(ArgAction::SetTrue)
.help("Display inlined recipe aliases to the left of their doc in listing")
.conflicts_with(arg::NO_ALIASES)
.conflicts_with(arg::NO_INLINE_ALIASES),
)
.arg(
Arg::new(arg::JUSTFILE)
.short('f')
Expand Down Expand Up @@ -289,14 +288,6 @@ impl Config {
.action(ArgAction::SetTrue)
.help("Don't show aliases in list"),
)
.arg(
Arg::new(arg::NO_INLINE_ALIASES)
.long("no-inline-aliases")
.env("JUST_NO_INLINE_ALIASES")
.action(ArgAction::SetTrue)
.help("Don't show aliases inline with recipe docs in list")
.conflicts_with(arg::NO_ALIASES),
)
.arg(
Arg::new(arg::NO_DEPS)
.long("no-deps")
Expand Down Expand Up @@ -727,6 +718,10 @@ impl Config {
let explain = matches.get_flag(arg::EXPLAIN);

Ok(Self {
alias_style: matches
.get_one::<AliasStyle>(arg::ALIAS_STYLE)
.unwrap()
.clone(),
check: matches.get_flag(arg::CHECK),
color: (*matches.get_one::<UseColor>(arg::COLOR).unwrap()).into(),
command_color: matches
Expand All @@ -744,14 +739,12 @@ impl Config {
.clone(),
explain,
highlight: !matches.get_flag(arg::NO_HIGHLIGHT),
inline_aliases_left: matches.get_flag(arg::INLINE_ALIASES_LEFT),
invocation_directory: env::current_dir().context(config_error::CurrentDirContext)?,
list_heading: matches.get_one::<String>(arg::LIST_HEADING).unwrap().into(),
list_prefix: matches.get_one::<String>(arg::LIST_PREFIX).unwrap().into(),
list_submodules: matches.get_flag(arg::LIST_SUBMODULES),
load_dotenv: !matches.get_flag(arg::NO_DOTENV),
no_aliases: matches.get_flag(arg::NO_ALIASES),
no_inline_aliases: matches.get_flag(arg::NO_INLINE_ALIASES),
no_dependencies: matches.get_flag(arg::NO_DEPS),
one: matches.get_flag(arg::ONE),
search_config,
Expand Down
21 changes: 11 additions & 10 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,16 @@
pub(crate) use {
crate::{
alias::Alias, analyzer::Analyzer, argument_parser::ArgumentParser, assignment::Assignment,
assignment_resolver::AssignmentResolver, ast::Ast, attribute::Attribute, binding::Binding,
color::Color, color_display::ColorDisplay, command_color::CommandColor,
command_ext::CommandExt, compilation::Compilation, compile_error::CompileError,
compile_error_kind::CompileErrorKind, compiler::Compiler, condition::Condition,
conditional_operator::ConditionalOperator, config::Config, config_error::ConfigError,
constants::constants, count::Count, delimiter::Delimiter, dependency::Dependency,
dump_format::DumpFormat, enclosure::Enclosure, error::Error, evaluator::Evaluator,
execution_context::ExecutionContext, executor::Executor, expression::Expression,
fragment::Fragment, function::Function, interpreter::Interpreter,
alias::Alias, alias_style::AliasStyle, analyzer::Analyzer, argument_parser::ArgumentParser,
assignment::Assignment, assignment_resolver::AssignmentResolver, ast::Ast,
attribute::Attribute, binding::Binding, color::Color, color_display::ColorDisplay,
command_color::CommandColor, command_ext::CommandExt, compilation::Compilation,
compile_error::CompileError, compile_error_kind::CompileErrorKind, compiler::Compiler,
condition::Condition, conditional_operator::ConditionalOperator, config::Config,
config_error::ConfigError, constants::constants, count::Count, delimiter::Delimiter,
dependency::Dependency, dump_format::DumpFormat, enclosure::Enclosure, error::Error,
evaluator::Evaluator, execution_context::ExecutionContext, executor::Executor,
expression::Expression, fragment::Fragment, function::Function, interpreter::Interpreter,
interrupt_guard::InterruptGuard, interrupt_handler::InterruptHandler, item::Item,
justfile::Justfile, keyed::Keyed, keyword::Keyword, lexer::Lexer, line::Line, list::List,
load_dotenv::load_dotenv, loader::Loader, module_path::ModulePath, name::Name,
Expand Down Expand Up @@ -107,6 +107,7 @@ pub mod fuzzing;
pub mod summary;

mod alias;
mod alias_style;
mod analyzer;
mod argument_parser;
mod assignment;
Expand Down
6 changes: 3 additions & 3 deletions src/subcommand.rs
Original file line number Diff line number Diff line change
Expand Up @@ -414,7 +414,7 @@ impl Subcommand {
) {
let doc = doc.unwrap_or_default();
let print_doc = !doc.is_empty() && doc.lines().count() <= 1;
let print_aliases = !config.no_inline_aliases && !aliases.is_empty();
let print_aliases = config.alias_style != AliasStyle::Recipe && !aliases.is_empty();

if print_doc || print_aliases {
print!(
Expand All @@ -435,7 +435,7 @@ impl Subcommand {
.paint(&format!("[aliases: {}]", aliases.join(", ")))
));

let (left, right) = if config.inline_aliases_left {
let (left, right) = if config.alias_style == AliasStyle::InlineLeft {
(aliases, doc)
} else {
(doc, aliases)
Expand Down Expand Up @@ -574,7 +574,7 @@ impl Subcommand {

if let Some(recipes) = recipe_groups.get(&group) {
for recipe in recipes {
let recipe_alias_entries = if config.no_inline_aliases {
let recipe_alias_entries = if config.alias_style == AliasStyle::Recipe {
aliases.get(recipe.name())
} else {
None
Expand Down
60 changes: 60 additions & 0 deletions tests/alias_style.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
use super::*;

#[test]
fn alias_style_inline() {
Test::new()
.justfile(
"
alias t := test1
# A test recipe
test1:
@echo 'test1'
test2:
@echo 'test2'
",
)
.args(["--alias-style=inline", "--list"])
.stdout("Available recipes:\n test1 # A test recipe [aliases: t]\n test2\n")
.run();
}

#[test]
fn alias_style_inline_left() {
Test::new()
.justfile(
"
alias t := test1
# A test recipe
test1:
@echo 'test1'
test2:
@echo 'test2'
",
)
.args(["--alias-style=inline-left", "--list"])
.stdout("Available recipes:\n test1 # [aliases: t] A test recipe\n test2\n")
.run();
}

#[test]
fn alias_style_recipe() {
Test::new()
.justfile(
"
alias t := test1
test1:
@echo 'test1'
test2:
@echo 'test2'
",
)
.args(["--alias-style=recipe", "--list"])
.stdout("Available recipes:\n test1\n t # alias for `test1`\n test2\n")
.run();
}
2 changes: 1 addition & 1 deletion tests/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ pub(crate) use {
#[macro_use]
mod test;

mod alias_style;
mod allow_duplicate_recipes;
mod allow_duplicate_variables;
mod assert_stdout;
Expand Down Expand Up @@ -82,7 +83,6 @@ mod no_aliases;
mod no_cd;
mod no_dependencies;
mod no_exit_message;
mod no_inline_aliases;
mod os_attributes;
mod parameters;
mod parser;
Expand Down
20 changes: 0 additions & 20 deletions tests/list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -438,23 +438,3 @@ fn no_space_before_submodules_not_following_groups() {
)
.run();
}

#[test]
fn inline_aliases_left_flag() {
Test::new()
.justfile(
"
alias t := test1
# I'm a recipe
test1:
@echo 'test1'
test2:
@echo 'test2'
",
)
.args(["--inline-aliases-left", "--list"])
.stdout("Available recipes:\n test1 # [aliases: t] I'm a recipe\n test2\n")
.run();
}
20 changes: 0 additions & 20 deletions tests/no_inline_aliases.rs

This file was deleted.

0 comments on commit 4505816

Please sign in to comment.