mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-18 02:04:19 +00:00
cli: use reverse-alphabet hex for branch name in jj git push --change
This commit is contained in:
parent
9887d2c3d6
commit
331ebf4cef
3 changed files with 15 additions and 13 deletions
11
CHANGELOG.md
11
CHANGELOG.md
|
@ -50,12 +50,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||
* The builtin `jj update` and `jj up` aliases for `jj checkout` have been
|
||||
deleted.
|
||||
|
||||
* Change IDs are now in rendered using letters from the end of the alphabet
|
||||
(backwards from 'z' through 'k') instead of the usual hex digits ('0' through
|
||||
'9' and 'a' through 'f'). This is to clarify the distinction between change
|
||||
IDs and commit IDs, and to allow more efficient lookup of unique prefixes.
|
||||
This change doesn't affect the storage format; existing repositories will
|
||||
remain usable.
|
||||
* Change IDs are now rendered using letters from the end of the alphabet (from
|
||||
'z' through 'k') instead of the usual hex digits ('0' through '9' and 'a'
|
||||
through 'f'). This is to clarify the distinction between change IDs and commit
|
||||
IDs, and to allow more efficient lookup of unique prefixes. This change
|
||||
doesn't affect the storage format; existing repositories will remain usable.
|
||||
|
||||
### New features
|
||||
|
||||
|
|
|
@ -32,6 +32,7 @@ use jujutsu_lib::backend::{BackendError, ChangeId, CommitId, ObjectId, TreeId};
|
|||
use jujutsu_lib::commit::Commit;
|
||||
use jujutsu_lib::git::{GitExportError, GitImportError};
|
||||
use jujutsu_lib::gitignore::GitIgnoreFile;
|
||||
use jujutsu_lib::hex_util::to_reverse_hex;
|
||||
use jujutsu_lib::matchers::{EverythingMatcher, Matcher, PrefixMatcher, Visit};
|
||||
use jujutsu_lib::op_heads_store::{self, OpHeadResolutionError, OpHeadsStore};
|
||||
use jujutsu_lib::op_store::{OpStore, OpStoreError, OperationId, RefTarget, WorkspaceId};
|
||||
|
@ -1619,7 +1620,9 @@ pub fn short_commit_hash(commit_id: &CommitId) -> String {
|
|||
}
|
||||
|
||||
pub fn short_change_hash(change_id: &ChangeId) -> String {
|
||||
change_id.hex()[0..12].to_string()
|
||||
// TODO: We could avoid the unwrap() and make this more efficient by converting
|
||||
// straight from binary.
|
||||
to_reverse_hex(&change_id.hex()[0..12]).unwrap()
|
||||
}
|
||||
|
||||
pub fn short_operation_hash(operation_id: &OperationId) -> String {
|
||||
|
|
|
@ -221,9 +221,9 @@ fn test_git_push_changes() {
|
|||
|
||||
let stdout = test_env.jj_cmd_success(&workspace_root, &["git", "push", "--change", "@"]);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
Creating branch push-1b76972398e6 for revision @
|
||||
Creating branch push-yostqsxwqrlt for revision @
|
||||
Branch changes to push to origin:
|
||||
Add branch push-1b76972398e6 to 28d7620ea63a
|
||||
Add branch push-yostqsxwqrlt to 28d7620ea63a
|
||||
"###);
|
||||
// test pushing two changes at once
|
||||
std::fs::write(workspace_root.join("file"), "modified2").unwrap();
|
||||
|
@ -232,10 +232,10 @@ fn test_git_push_changes() {
|
|||
&["git", "push", "--change", "@", "--change", "@-"],
|
||||
);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
Creating branch push-19b790168e73 for revision @-
|
||||
Creating branch push-yqosqzytrlsw for revision @-
|
||||
Branch changes to push to origin:
|
||||
Force branch push-1b76972398e6 from 28d7620ea63a to 48d8c7948133
|
||||
Add branch push-19b790168e73 to fa16a14170fb
|
||||
Force branch push-yostqsxwqrlt from 28d7620ea63a to 48d8c7948133
|
||||
Add branch push-yqosqzytrlsw to fa16a14170fb
|
||||
"###);
|
||||
// specifying the same change twice doesn't break things
|
||||
std::fs::write(workspace_root.join("file"), "modified3").unwrap();
|
||||
|
@ -245,7 +245,7 @@ fn test_git_push_changes() {
|
|||
);
|
||||
insta::assert_snapshot!(stdout, @r###"
|
||||
Branch changes to push to origin:
|
||||
Force branch push-1b76972398e6 from 48d8c7948133 to b5f030322b1d
|
||||
Force branch push-yostqsxwqrlt from 48d8c7948133 to b5f030322b1d
|
||||
"###);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue