Skip to content

Commit

Permalink
List modules in source order with --unsorted (casey#2085)
Browse files Browse the repository at this point in the history
  • Loading branch information
casey authored May 25, 2024
1 parent ed0dc20 commit d7059f8
Show file tree
Hide file tree
Showing 6 changed files with 75 additions and 25 deletions.
21 changes: 9 additions & 12 deletions src/analyzer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,9 @@ impl<'src> Analyzer<'src> {
paths: &HashMap<PathBuf, PathBuf>,
asts: &HashMap<PathBuf, Ast<'src>>,
root: &Path,
name: Option<Name<'src>>,
) -> CompileResult<'src, Justfile<'src>> {
Self::default().justfile(loaded, paths, asts, root)
Self::default().justfile(loaded, paths, asts, root, name)
}

fn justfile(
Expand All @@ -23,6 +24,7 @@ impl<'src> Analyzer<'src> {
paths: &HashMap<PathBuf, PathBuf>,
asts: &HashMap<PathBuf, Ast<'src>>,
root: &Path,
name: Option<Name<'src>>,
) -> CompileResult<'src, Justfile<'src>> {
let mut recipes = Vec::new();

Expand All @@ -33,7 +35,7 @@ impl<'src> Analyzer<'src> {

let mut warnings = Vec::new();

let mut modules: BTreeMap<String, (Name, Justfile)> = BTreeMap::new();
let mut modules: Table<Justfile> = Table::new();

let mut definitions: HashMap<&str, (&'static str, Name)> = HashMap::new();

Expand Down Expand Up @@ -83,10 +85,7 @@ impl<'src> Analyzer<'src> {
Item::Module { absolute, name, .. } => {
if let Some(absolute) = absolute {
define(*name, "module", false)?;
modules.insert(
name.lexeme().into(),
(*name, Self::analyze(loaded, paths, asts, absolute)?),
);
modules.insert(Self::analyze(loaded, paths, asts, absolute, Some(*name))?);
}
}
Item::Recipe(recipe) => {
Expand Down Expand Up @@ -149,6 +148,8 @@ impl<'src> Analyzer<'src> {
let root = paths.get(root).unwrap();

Ok(Justfile {
aliases,
assignments: self.assignments,
default: recipes
.values()
.filter(|recipe| recipe.name.path == root)
Expand All @@ -160,16 +161,12 @@ impl<'src> Analyzer<'src> {
Rc::clone(next)
}),
}),
aliases,
assignments: self.assignments,
loaded: loaded.into(),
modules,
name,
recipes,
settings,
warnings,
modules: modules
.into_iter()
.map(|(name, (_name, justfile))| (name, justfile))
.collect(),
})
}

Expand Down
4 changes: 2 additions & 2 deletions src/compiler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,7 @@ impl Compiler {
asts.insert(current.path, ast.clone());
}

let justfile = Analyzer::analyze(&loaded, &paths, &asts, root)?;
let justfile = Analyzer::analyze(&loaded, &paths, &asts, root, None)?;

Ok(Compilation {
asts,
Expand Down Expand Up @@ -182,7 +182,7 @@ impl Compiler {
asts.insert(root.clone(), ast);
let mut paths: HashMap<PathBuf, PathBuf> = HashMap::new();
paths.insert(root.clone(), root.clone());
Analyzer::analyze(&[], &paths, &asts, &root)
Analyzer::analyze(&[], &paths, &asts, &root, None)
}
}

Expand Down
33 changes: 30 additions & 3 deletions src/justfile.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,9 @@ pub(crate) struct Justfile<'src> {
pub(crate) default: Option<Rc<Recipe<'src>>>,
#[serde(skip)]
pub(crate) loaded: Vec<PathBuf>,
pub(crate) modules: BTreeMap<String, Justfile<'src>>,
pub(crate) modules: Table<'src, Justfile<'src>>,
#[serde(skip)]
pub(crate) name: Option<Name<'src>>,
pub(crate) recipes: Table<'src, Rc<Recipe<'src>>>,
pub(crate) settings: Settings<'src>,
pub(crate) warnings: Vec<Warning>,
Expand Down Expand Up @@ -401,6 +403,10 @@ impl<'src> Justfile<'src> {
}
}

pub(crate) fn name(&self) -> &'src str {
self.name.map(|name| name.lexeme()).unwrap_or_default()
}

fn run_recipe(
arguments: &[String],
context: &RecipeContext<'src, '_>,
Expand Down Expand Up @@ -465,15 +471,30 @@ impl<'src> Justfile<'src> {
Ok(())
}

pub(crate) fn public_recipes(&self, source_order: bool) -> Vec<&Recipe<'src, Dependency>> {
pub(crate) fn modules(&self, config: &Config) -> Vec<&Justfile> {
let mut modules = self.modules.values().collect::<Vec<&Justfile>>();

if config.unsorted {
modules.sort_by_key(|module| {
module
.name
.map(|name| name.token.offset)
.unwrap_or_default()
});
}

modules
}

pub(crate) fn public_recipes(&self, config: &Config) -> Vec<&Recipe<'src, Dependency>> {
let mut recipes = self
.recipes
.values()
.map(AsRef::as_ref)
.filter(|recipe| recipe.is_public())
.collect::<Vec<&Recipe<Dependency>>>();

if source_order {
if config.unsorted {
recipes.sort_by_key(|recipe| {
(
self
Expand Down Expand Up @@ -531,6 +552,12 @@ impl<'src> ColorDisplay for Justfile<'src> {
}
}

impl<'src> Keyed<'src> for Justfile<'src> {
fn key(&self) -> &'src str {
self.name()
}
}

#[cfg(test)]
mod tests {
use super::*;
Expand Down
10 changes: 5 additions & 5 deletions src/subcommand.rs
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ impl Subcommand {
while let Some(module) = stack.pop() {
recipes.extend(
module
.public_recipes(config.unsorted)
.public_recipes(config)
.iter()
.filter(|recipe| recipe.min_arguments() == 0),
);
Expand Down Expand Up @@ -532,7 +532,7 @@ impl Subcommand {

let groups = {
let mut groups = BTreeMap::<Option<String>, Vec<&Recipe>>::new();
for recipe in justfile.public_recipes(config.unsorted) {
for recipe in justfile.public_recipes(config) {
let recipe_groups = recipe.groups();
if recipe_groups.is_empty() {
groups.entry(None).or_default().push(recipe);
Expand Down Expand Up @@ -592,12 +592,12 @@ impl Subcommand {
}
}

for (i, (name, module)) in justfile.modules.iter().enumerate() {
for (i, module) in justfile.modules(config).into_iter().enumerate() {
if i + groups.len() > 0 {
println!();
}

println!("{}{name}:", config.list_prefix.repeat(level + 1));
println!("{}{}:", config.list_prefix.repeat(level + 1), module.name());
Self::list(config, level + 1, module);
}
}
Expand Down Expand Up @@ -637,7 +637,7 @@ impl Subcommand {
) {
let path = components.join("::");

for recipe in justfile.public_recipes(config.unsorted) {
for recipe in justfile.public_recipes(config) {
if *printed > 0 {
print!(" ");
}
Expand Down
2 changes: 1 addition & 1 deletion src/testing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ pub(crate) fn analysis_error(
let mut paths: HashMap<PathBuf, PathBuf> = HashMap::new();
paths.insert("justfile".into(), "justfile".into());

match Analyzer::analyze(&[], &paths, &asts, &root) {
match Analyzer::analyze(&[], &paths, &asts, &root, None) {
Ok(_) => panic!("Analysis unexpectedly succeeded"),
Err(have) => {
let want = CompileError {
Expand Down
30 changes: 28 additions & 2 deletions tests/list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,7 @@ fn modules_are_space_separated_in_output() {
",
)
.test_round_trip(false)
.arg("--unstable")
.arg("--list")
.args(["--unstable", "--list"])
.stdout(
"
Available recipes:
Expand All @@ -50,6 +49,33 @@ fn modules_are_space_separated_in_output() {
.run();
}

#[test]
fn modules_unsorted() {
Test::new()
.write("foo.just", "foo:")
.write("bar.just", "bar:")
.justfile(
"
mod foo
mod bar
",
)
.test_round_trip(false)
.args(["--unstable", "--list", "--unsorted"])
.stdout(
"
Available recipes:
foo:
foo
bar:
bar
",
)
.run();
}

#[test]
fn module_recipe_list_alignment_ignores_private_recipes() {
Test::new()
Expand Down

0 comments on commit d7059f8

Please sign in to comment.