mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 10:07:28 +00:00
author
/committer
templates: add a username
method
I haven't used a proper email address parser as I'm not really sure if it's worth the extra dependency and effort -- thoughts?
This commit is contained in:
parent
3744ae4508
commit
aacdcf629b
3 changed files with 83 additions and 0 deletions
|
@ -142,6 +142,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
* `jj new --insert-after` inserts the new commit between the target commit and
|
* `jj new --insert-after` inserts the new commit between the target commit and
|
||||||
its children.
|
its children.
|
||||||
|
|
||||||
|
* `author`/`committer` templates now support `.username()`, which leaves out the
|
||||||
|
domain information of `.email()`.
|
||||||
|
|
||||||
### Fixed bugs
|
### Fixed bugs
|
||||||
|
|
||||||
* When sharing the working copy with a Git repo, we used to forget to export
|
* When sharing the working copy with a Git repo, we used to forget to export
|
||||||
|
|
|
@ -360,6 +360,14 @@ fn expect_arguments<const N: usize, const M: usize>(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn split_email(email: &str) -> (&str, Option<&str>) {
|
||||||
|
if let Some((username, rest)) = email.split_once('@') {
|
||||||
|
(username, Some(rest))
|
||||||
|
} else {
|
||||||
|
(email, None)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn parse_method_chain<'a, I: 'a>(
|
fn parse_method_chain<'a, I: 'a>(
|
||||||
input_property: PropertyAndLabels<'a, I>,
|
input_property: PropertyAndLabels<'a, I>,
|
||||||
method_pairs: Pairs<Rule>,
|
method_pairs: Pairs<Rule>,
|
||||||
|
@ -556,6 +564,16 @@ fn parse_signature_method<'a, I: 'a>(
|
||||||
TemplatePropertyFn(|signature: &Signature| signature.email.clone()),
|
TemplatePropertyFn(|signature: &Signature| signature.email.clone()),
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
"username" => {
|
||||||
|
expect_no_arguments(args_pair)?;
|
||||||
|
Property::String(chain_properties(
|
||||||
|
self_property,
|
||||||
|
TemplatePropertyFn(|signature: &Signature| {
|
||||||
|
let (username, _) = split_email(&signature.email);
|
||||||
|
username.to_owned()
|
||||||
|
}),
|
||||||
|
))
|
||||||
|
}
|
||||||
"timestamp" => {
|
"timestamp" => {
|
||||||
expect_no_arguments(args_pair)?;
|
expect_no_arguments(args_pair)?;
|
||||||
Property::Timestamp(chain_properties(
|
Property::Timestamp(chain_properties(
|
||||||
|
|
|
@ -257,6 +257,68 @@ fn test_templater_string_method() {
|
||||||
insta::assert_snapshot!(render(r#""foo\nbar".first_line()"#), @"foo");
|
insta::assert_snapshot!(render(r#""foo\nbar".first_line()"#), @"foo");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_templater_signature() {
|
||||||
|
let test_env = TestEnvironment::default();
|
||||||
|
test_env.jj_cmd_success(test_env.env_root(), &["init", "repo", "--git"]);
|
||||||
|
let repo_path = test_env.env_root().join("repo");
|
||||||
|
let render = |template| get_template_output(&test_env, &repo_path, "@", template);
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(&repo_path, &["new"]);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Test User <test.user@example.com>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.name()"#), @"Test User");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"test.user@example.com");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"test.user");
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(
|
||||||
|
&repo_path,
|
||||||
|
&["--config-toml=user.name='Another Test User'", "new"],
|
||||||
|
);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Another Test User <test.user@example.com>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.name()"#), @"Another Test User");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"test.user@example.com");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"test.user");
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(
|
||||||
|
&repo_path,
|
||||||
|
&[
|
||||||
|
"--config-toml=user.email='test.user@invalid@example.com'",
|
||||||
|
"new",
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Test User <test.user@invalid@example.com>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.name()"#), @"Test User");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"test.user@invalid@example.com");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"test.user");
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(&repo_path, &["--config-toml=user.email='test.user'", "new"]);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Test User <test.user>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"test.user");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"test.user");
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(
|
||||||
|
&repo_path,
|
||||||
|
&[
|
||||||
|
"--config-toml=user.email='test.user+tag@example.com'",
|
||||||
|
"new",
|
||||||
|
],
|
||||||
|
);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Test User <test.user+tag@example.com>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"test.user+tag@example.com");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"test.user+tag");
|
||||||
|
|
||||||
|
test_env.jj_cmd_success(&repo_path, &["--config-toml=user.email='x@y'", "new"]);
|
||||||
|
|
||||||
|
insta::assert_snapshot!(render(r#"author"#), @"Test User <x@y>");
|
||||||
|
insta::assert_snapshot!(render(r#"author.email()"#), @"x@y");
|
||||||
|
insta::assert_snapshot!(render(r#"author.username()"#), @"x");
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_templater_label_function() {
|
fn test_templater_label_function() {
|
||||||
let test_env = TestEnvironment::default();
|
let test_env = TestEnvironment::default();
|
||||||
|
|
Loading…
Reference in a new issue