mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-12 07:14:38 +00:00
local_backend: allow storing legacy trees
Unlike the git backend, we don't need to support path-level conflicts for existing repos because we don't care about compatibility with existing repos using the native backend. However, we still need to support both formats until all code paths are able to handle tree-level conflicts.
This commit is contained in:
parent
589e0db3c5
commit
e3d67d5e45
3 changed files with 7 additions and 1 deletions
|
@ -279,6 +279,7 @@ pub fn commit_to_proto(commit: &Commit) -> crate::protos::local_store::Commit {
|
||||||
for predecessor in &commit.predecessors {
|
for predecessor in &commit.predecessors {
|
||||||
proto.predecessors.push(predecessor.to_bytes());
|
proto.predecessors.push(predecessor.to_bytes());
|
||||||
}
|
}
|
||||||
|
proto.uses_tree_conflict_format = commit.uses_tree_conflict_format;
|
||||||
let conflict = crate::protos::local_store::TreeConflict {
|
let conflict = crate::protos::local_store::TreeConflict {
|
||||||
removes: commit
|
removes: commit
|
||||||
.root_tree
|
.root_tree
|
||||||
|
@ -314,7 +315,7 @@ fn commit_from_proto(proto: crate::protos::local_store::Commit) -> Commit {
|
||||||
parents,
|
parents,
|
||||||
predecessors,
|
predecessors,
|
||||||
root_tree,
|
root_tree,
|
||||||
uses_tree_conflict_format: true,
|
uses_tree_conflict_format: proto.uses_tree_conflict_format,
|
||||||
change_id,
|
change_id,
|
||||||
description: proto.description,
|
description: proto.description,
|
||||||
author: signature_from_proto(proto.author.unwrap_or_default()),
|
author: signature_from_proto(proto.author.unwrap_or_default()),
|
||||||
|
|
|
@ -48,6 +48,8 @@ message Commit {
|
||||||
repeated bytes parents = 1;
|
repeated bytes parents = 1;
|
||||||
repeated bytes predecessors = 2;
|
repeated bytes predecessors = 2;
|
||||||
TreeConflict root_tree = 3;
|
TreeConflict root_tree = 3;
|
||||||
|
// TODO(#1624): delete when all code paths can handle this format
|
||||||
|
bool uses_tree_conflict_format = 8;
|
||||||
bytes change_id = 4;
|
bytes change_id = 4;
|
||||||
string description = 5;
|
string description = 5;
|
||||||
|
|
||||||
|
|
|
@ -61,6 +61,9 @@ pub struct Commit {
|
||||||
pub predecessors: ::prost::alloc::vec::Vec<::prost::alloc::vec::Vec<u8>>,
|
pub predecessors: ::prost::alloc::vec::Vec<::prost::alloc::vec::Vec<u8>>,
|
||||||
#[prost(message, optional, tag = "3")]
|
#[prost(message, optional, tag = "3")]
|
||||||
pub root_tree: ::core::option::Option<TreeConflict>,
|
pub root_tree: ::core::option::Option<TreeConflict>,
|
||||||
|
/// TODO(#1624): delete when all code paths can handle this format
|
||||||
|
#[prost(bool, tag = "8")]
|
||||||
|
pub uses_tree_conflict_format: bool,
|
||||||
#[prost(bytes = "vec", tag = "4")]
|
#[prost(bytes = "vec", tag = "4")]
|
||||||
pub change_id: ::prost::alloc::vec::Vec<u8>,
|
pub change_id: ::prost::alloc::vec::Vec<u8>,
|
||||||
#[prost(string, tag = "5")]
|
#[prost(string, tag = "5")]
|
||||||
|
|
Loading…
Reference in a new issue