mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-16 09:11:55 +00:00
cli: inline parse_commit_summary_template(), cache template text instead
This will help deduplicate template parsing functions. We don't care about the cost of config.get_string(), but I don't want to copy the config key to every caller.
This commit is contained in:
parent
101e48d4a2
commit
e82527857d
1 changed files with 18 additions and 52 deletions
|
@ -367,6 +367,8 @@ pub struct WorkspaceCommandHelper {
|
||||||
settings: UserSettings,
|
settings: UserSettings,
|
||||||
workspace: Workspace,
|
workspace: Workspace,
|
||||||
user_repo: ReadonlyUserRepo,
|
user_repo: ReadonlyUserRepo,
|
||||||
|
// TODO: Parsed template can be cached if it doesn't capture 'repo lifetime
|
||||||
|
commit_summary_template_text: String,
|
||||||
commit_template_extension: Option<Arc<dyn CommitTemplateLanguageExtension>>,
|
commit_template_extension: Option<Arc<dyn CommitTemplateLanguageExtension>>,
|
||||||
revset_aliases_map: RevsetAliasesMap,
|
revset_aliases_map: RevsetAliasesMap,
|
||||||
template_aliases_map: TemplateAliasesMap,
|
template_aliases_map: TemplateAliasesMap,
|
||||||
|
@ -382,20 +384,11 @@ impl WorkspaceCommandHelper {
|
||||||
workspace: Workspace,
|
workspace: Workspace,
|
||||||
repo: Arc<ReadonlyRepo>,
|
repo: Arc<ReadonlyRepo>,
|
||||||
) -> Result<Self, CommandError> {
|
) -> Result<Self, CommandError> {
|
||||||
|
let settings = command.settings.clone();
|
||||||
|
let commit_summary_template_text =
|
||||||
|
settings.config().get_string("templates.commit_summary")?;
|
||||||
let revset_aliases_map = load_revset_aliases(ui, &command.layered_configs)?;
|
let revset_aliases_map = load_revset_aliases(ui, &command.layered_configs)?;
|
||||||
let template_aliases_map = command.load_template_aliases(ui)?;
|
let template_aliases_map = command.load_template_aliases(ui)?;
|
||||||
// Parse commit_summary template early to report error before starting mutable
|
|
||||||
// operation.
|
|
||||||
// TODO: Parsed template can be cached if it doesn't capture repo
|
|
||||||
let id_prefix_context = IdPrefixContext::default();
|
|
||||||
parse_commit_summary_template(
|
|
||||||
repo.as_ref(),
|
|
||||||
workspace.workspace_id(),
|
|
||||||
&id_prefix_context,
|
|
||||||
command.commit_template_extension.as_deref(),
|
|
||||||
&template_aliases_map,
|
|
||||||
&command.settings,
|
|
||||||
)?;
|
|
||||||
let loaded_at_head = command.global_args.at_operation == "@";
|
let loaded_at_head = command.global_args.at_operation == "@";
|
||||||
let may_update_working_copy = loaded_at_head && !command.global_args.ignore_working_copy;
|
let may_update_working_copy = loaded_at_head && !command.global_args.ignore_working_copy;
|
||||||
let working_copy_shared_with_git = is_colocated_git_workspace(&workspace, &repo);
|
let working_copy_shared_with_git = is_colocated_git_workspace(&workspace, &repo);
|
||||||
|
@ -403,18 +396,19 @@ impl WorkspaceCommandHelper {
|
||||||
cwd: command.cwd.clone(),
|
cwd: command.cwd.clone(),
|
||||||
string_args: command.string_args.clone(),
|
string_args: command.string_args.clone(),
|
||||||
global_args: command.global_args.clone(),
|
global_args: command.global_args.clone(),
|
||||||
settings: command.settings.clone(),
|
settings,
|
||||||
workspace,
|
workspace,
|
||||||
user_repo: ReadonlyUserRepo::new(repo),
|
user_repo: ReadonlyUserRepo::new(repo),
|
||||||
|
commit_summary_template_text,
|
||||||
commit_template_extension: command.commit_template_extension.clone(),
|
commit_template_extension: command.commit_template_extension.clone(),
|
||||||
revset_aliases_map,
|
revset_aliases_map,
|
||||||
template_aliases_map,
|
template_aliases_map,
|
||||||
may_update_working_copy,
|
may_update_working_copy,
|
||||||
working_copy_shared_with_git,
|
working_copy_shared_with_git,
|
||||||
};
|
};
|
||||||
// Parse short-prefixes revset early to report error before starting mutable
|
// Parse commit_summary template (and short-prefixes revset) early to
|
||||||
// operation.
|
// report error before starting mutable operation.
|
||||||
helper.id_prefix_context()?;
|
helper.parse_commit_template(&helper.commit_summary_template_text)?;
|
||||||
Ok(helper)
|
Ok(helper)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -888,6 +882,11 @@ Set which revision the branch points to with `jj branch set {branch_name} -r <RE
|
||||||
Ok(template)
|
Ok(template)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn commit_summary_template(&self) -> Box<dyn Template<Commit> + '_> {
|
||||||
|
self.parse_commit_template(&self.commit_summary_template_text)
|
||||||
|
.expect("parse error should be confined by WorkspaceCommandHelper::new()")
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns one-line summary of the given `commit`.
|
/// Returns one-line summary of the given `commit`.
|
||||||
pub fn format_commit_summary(&self, commit: &Commit) -> String {
|
pub fn format_commit_summary(&self, commit: &Commit) -> String {
|
||||||
let mut output = Vec::new();
|
let mut output = Vec::new();
|
||||||
|
@ -903,20 +902,7 @@ Set which revision the branch points to with `jj branch set {branch_name} -r <RE
|
||||||
formatter: &mut dyn Formatter,
|
formatter: &mut dyn Formatter,
|
||||||
commit: &Commit,
|
commit: &Commit,
|
||||||
) -> std::io::Result<()> {
|
) -> std::io::Result<()> {
|
||||||
let id_prefix_context = self
|
self.commit_summary_template().format(commit, formatter)
|
||||||
.id_prefix_context()
|
|
||||||
.expect("parse error should be confined by WorkspaceCommandHelper::new()");
|
|
||||||
let template = parse_commit_summary_template(
|
|
||||||
self.repo().as_ref(),
|
|
||||||
self.workspace_id(),
|
|
||||||
id_prefix_context,
|
|
||||||
self.commit_template_extension.as_deref(),
|
|
||||||
&self.template_aliases_map,
|
|
||||||
&self.settings,
|
|
||||||
)
|
|
||||||
.expect("parse error should be confined by WorkspaceCommandHelper::new()");
|
|
||||||
template.format(commit, formatter)?;
|
|
||||||
Ok(())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn check_rewritable<'a>(
|
pub fn check_rewritable<'a>(
|
||||||
|
@ -1364,13 +1350,13 @@ impl WorkspaceCommandTransaction<'_> {
|
||||||
) -> std::io::Result<()> {
|
) -> std::io::Result<()> {
|
||||||
// TODO: Use the disambiguation revset
|
// TODO: Use the disambiguation revset
|
||||||
let id_prefix_context = IdPrefixContext::default();
|
let id_prefix_context = IdPrefixContext::default();
|
||||||
let template = parse_commit_summary_template(
|
let template = commit_templater::parse(
|
||||||
self.tx.repo(),
|
self.tx.repo(),
|
||||||
self.helper.workspace_id(),
|
self.helper.workspace_id(),
|
||||||
&id_prefix_context,
|
&id_prefix_context,
|
||||||
self.helper.commit_template_extension.as_deref(),
|
self.helper.commit_template_extension.as_deref(),
|
||||||
|
&self.helper.commit_summary_template_text,
|
||||||
&self.helper.template_aliases_map,
|
&self.helper.template_aliases_map,
|
||||||
&self.helper.settings,
|
|
||||||
)
|
)
|
||||||
.expect("parse error should be confined by WorkspaceCommandHelper::new()");
|
.expect("parse error should be confined by WorkspaceCommandHelper::new()");
|
||||||
template.format(commit, formatter)
|
template.format(commit, formatter)
|
||||||
|
@ -1728,26 +1714,6 @@ fn load_template_aliases(
|
||||||
Ok(aliases_map)
|
Ok(aliases_map)
|
||||||
}
|
}
|
||||||
|
|
||||||
#[instrument(skip_all)]
|
|
||||||
fn parse_commit_summary_template<'a>(
|
|
||||||
repo: &'a dyn Repo,
|
|
||||||
workspace_id: &WorkspaceId,
|
|
||||||
id_prefix_context: &'a IdPrefixContext,
|
|
||||||
extension: Option<&dyn CommitTemplateLanguageExtension>,
|
|
||||||
aliases_map: &TemplateAliasesMap,
|
|
||||||
settings: &UserSettings,
|
|
||||||
) -> Result<Box<dyn Template<Commit> + 'a>, CommandError> {
|
|
||||||
let template_text = settings.config().get_string("templates.commit_summary")?;
|
|
||||||
Ok(commit_templater::parse(
|
|
||||||
repo,
|
|
||||||
workspace_id,
|
|
||||||
id_prefix_context,
|
|
||||||
extension,
|
|
||||||
&template_text,
|
|
||||||
aliases_map,
|
|
||||||
)?)
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Helper to reformat content of log-like commands.
|
/// Helper to reformat content of log-like commands.
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub enum LogContentFormat {
|
pub enum LogContentFormat {
|
||||||
|
|
Loading…
Reference in a new issue