mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-16 00:56:23 +00:00
templater: add local/remote_branches keywords
This commit is contained in:
parent
5486d72f99
commit
0e14a1f04d
4 changed files with 51 additions and 4 deletions
|
@ -66,6 +66,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
* The `branches`/`tags`/`git_refs`/`git_head` template keywords now return a
|
||||
list of `RefName`s. They were previously pre-formatted strings.
|
||||
|
||||
* The new template keywords `local_branches`/`remote_branches` are added to show
|
||||
only local/remote branches.
|
||||
|
||||
### Fixed bugs
|
||||
|
||||
* Updating the working copy to a commit where a file that's currently ignored
|
||||
|
|
|
@ -320,6 +320,28 @@ fn build_commit_keyword_opt<'repo>(
|
|||
.collect()
|
||||
}))
|
||||
}
|
||||
"local_branches" => {
|
||||
let index = cache.branches_index(repo).clone();
|
||||
language.wrap_ref_name_list(wrap_fn(property, move |commit| {
|
||||
index
|
||||
.get(commit.id())
|
||||
.iter()
|
||||
.filter(|ref_name| ref_name.is_local())
|
||||
.cloned()
|
||||
.collect()
|
||||
}))
|
||||
}
|
||||
"remote_branches" => {
|
||||
let index = cache.branches_index(repo).clone();
|
||||
language.wrap_ref_name_list(wrap_fn(property, move |commit| {
|
||||
index
|
||||
.get(commit.id())
|
||||
.iter()
|
||||
.filter(|ref_name| ref_name.is_remote())
|
||||
.cloned()
|
||||
.collect()
|
||||
}))
|
||||
}
|
||||
"tags" => {
|
||||
let index = cache.tags_index(repo).clone();
|
||||
language.wrap_ref_name_list(wrap_fn(property, move |commit| {
|
||||
|
@ -393,6 +415,10 @@ impl RefName {
|
|||
fn is_local(&self) -> bool {
|
||||
self.remote.is_none()
|
||||
}
|
||||
|
||||
fn is_remote(&self) -> bool {
|
||||
self.remote.is_some()
|
||||
}
|
||||
}
|
||||
|
||||
impl Template<()> for RefName {
|
||||
|
|
|
@ -379,7 +379,7 @@ fn test_log_branches() {
|
|||
test_env.jj_cmd_ok(&origin_path, &["describe", "-m=description 1"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["branch", "create", "branch1"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["new", "root()", "-m=description 2"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["branch", "create", "branch2"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["branch", "create", "branch2", "unchanged"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["new", "root()", "-m=description 3"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["branch", "create", "branch3"]);
|
||||
test_env.jj_cmd_ok(&origin_path, &["git", "export"]);
|
||||
|
@ -417,7 +417,7 @@ fn test_log_branches() {
|
|||
│ ◉ 21c33875443e branch1*
|
||||
├─╯
|
||||
│ @ a5b4d15489cc branch2* new-branch
|
||||
│ ◉ 8476341eb395 branch2@origin
|
||||
│ ◉ 8476341eb395 branch2@origin unchanged
|
||||
├─╯
|
||||
◉ 000000000000 (no branches)
|
||||
"###);
|
||||
|
@ -431,10 +431,24 @@ fn test_log_branches() {
|
|||
│ ◉ branch1
|
||||
├─╯
|
||||
│ @ branch2, new-branch
|
||||
│ ◉ origin/branch2
|
||||
│ ◉ origin/branch2, unchanged
|
||||
├─╯
|
||||
◉
|
||||
"###);
|
||||
|
||||
let template = r#"separate(" ", "L:", local_branches, "R:", remote_branches)"#;
|
||||
let output = test_env.jj_cmd_success(&workspace_root, &["log", "-T", template]);
|
||||
insta::assert_snapshot!(output, @r###"
|
||||
◉ L: branch3?? R: branch3@origin
|
||||
│ ◉ L: branch3?? R:
|
||||
├─╯
|
||||
│ ◉ L: branch1* R:
|
||||
├─╯
|
||||
│ @ L: branch2* new-branch R:
|
||||
│ ◉ L: unchanged R: branch2@origin unchanged@origin
|
||||
├─╯
|
||||
◉ L: R:
|
||||
"###);
|
||||
}
|
||||
|
||||
#[test]
|
||||
|
|
|
@ -25,7 +25,11 @@ The following keywords can be used in `jj log`/`jj obslog` templates.
|
|||
working-copy commit as `<workspace name>@`.
|
||||
* `current_working_copy: Boolean`: True for the working-copy commit of the
|
||||
current workspace.
|
||||
* `branches: List<RefName>`
|
||||
* `branches: List<RefName>`: Local and remote branches pointing to the commit.
|
||||
A tracking remote branch will be included only if its target is different
|
||||
from the local one.
|
||||
* `local_branches: List<RefName>`: All local branches pointing to the commit.
|
||||
* `remote_branches: List<RefName>`: All remote branches pointing to the commit.
|
||||
* `tags: List<RefName>`
|
||||
* `git_refs: List<RefName>`
|
||||
* `git_head: List<RefName>`
|
||||
|
|
Loading…
Reference in a new issue