From d6c6cdb45c7081ad63eb93f5cfb5dbba2408e88c Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Thu, 19 Jan 2023 13:25:18 +0900 Subject: [PATCH] templater: store type-erased version of commit/change id It's unlikely we'll need to discriminate commit/change id types while templating, so let's unify them. Since ObjectId trait isn't object safe, I decided to simply store bytes instead of Box. --- src/templater.rs | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/src/templater.rs b/src/templater.rs index d48dbe2ce..3910bc8ac 100644 --- a/src/templater.rs +++ b/src/templater.rs @@ -18,7 +18,7 @@ use std::io; use std::ops::AddAssign; use itertools::Itertools; -use jujutsu_lib::backend::{ChangeId, CommitId, ObjectId, Signature, Timestamp}; +use jujutsu_lib::backend::{ChangeId, ObjectId, Signature, Timestamp}; use jujutsu_lib::commit::Commit; use jujutsu_lib::op_store::WorkspaceId; use jujutsu_lib::repo::RepoRef; @@ -407,18 +407,13 @@ impl<'a, C, I, O> TemplateProperty for TemplateFunction<'a, C, I, O> { } } +/// Type-erased `CommitId`/`ChangeId`. #[derive(Debug, Clone)] -pub enum CommitOrChangeId { - CommitId(CommitId), - ChangeId(ChangeId), -} +pub struct CommitOrChangeId(Vec); impl CommitOrChangeId { pub fn hex(&self) -> String { - match self { - CommitOrChangeId::CommitId(id) => id.hex(), - CommitOrChangeId::ChangeId(id) => id.hex(), - } + hex::encode(&self.0) } pub fn short(&self) -> String { @@ -470,7 +465,7 @@ pub struct CommitIdProperty; impl TemplateProperty for CommitIdProperty { fn extract(&self, context: &Commit) -> CommitOrChangeId { - CommitOrChangeId::CommitId(context.id().clone()) + CommitOrChangeId(context.id().to_bytes()) } } @@ -478,7 +473,7 @@ pub struct ChangeIdProperty; impl TemplateProperty for ChangeIdProperty { fn extract(&self, context: &Commit) -> CommitOrChangeId { - CommitOrChangeId::ChangeId(context.change_id().clone()) + CommitOrChangeId(context.change_id().to_bytes()) } }