mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-15 16:53:25 +00:00
repo: add RepoLoader::merge_operations
This commit is contained in:
parent
87ea9102f0
commit
58a813cb18
1 changed files with 36 additions and 10 deletions
|
@ -700,21 +700,47 @@ impl RepoLoader {
|
||||||
Arc::new(repo)
|
Arc::new(repo)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Merges the given `operations` into a single operation.
|
||||||
|
/// Assumes that there is at least one operation.
|
||||||
|
pub fn merge_operations(
|
||||||
|
&self,
|
||||||
|
settings: &UserSettings,
|
||||||
|
operations: Vec<Operation>,
|
||||||
|
tx_description: Option<&str>,
|
||||||
|
) -> Result<Operation, RepoLoaderError> {
|
||||||
|
let num_operations = operations.len();
|
||||||
|
let mut operations = operations.into_iter();
|
||||||
|
let base_op = operations.next().unwrap();
|
||||||
|
let final_op = if num_operations > 1 {
|
||||||
|
let base_repo = self.load_at(&base_op)?;
|
||||||
|
let mut tx = base_repo.start_transaction(settings);
|
||||||
|
for other_op in operations {
|
||||||
|
tx.merge_operation(other_op)?;
|
||||||
|
tx.mut_repo().rebase_descendants(settings)?;
|
||||||
|
}
|
||||||
|
let tx_description = tx_description.map_or_else(
|
||||||
|
|| format!("merge {} operations", num_operations),
|
||||||
|
|tx_description| tx_description.to_string(),
|
||||||
|
);
|
||||||
|
let merged_repo = tx.write(tx_description).leave_unpublished();
|
||||||
|
merged_repo.operation().clone()
|
||||||
|
} else {
|
||||||
|
base_op
|
||||||
|
};
|
||||||
|
|
||||||
|
Ok(final_op)
|
||||||
|
}
|
||||||
|
|
||||||
fn _resolve_op_heads(
|
fn _resolve_op_heads(
|
||||||
&self,
|
&self,
|
||||||
op_heads: Vec<Operation>,
|
op_heads: Vec<Operation>,
|
||||||
user_settings: &UserSettings,
|
user_settings: &UserSettings,
|
||||||
) -> Result<Operation, RepoLoaderError> {
|
) -> Result<Operation, RepoLoaderError> {
|
||||||
let base_repo = self.load_at(&op_heads[0])?;
|
self.merge_operations(
|
||||||
let mut tx = base_repo.start_transaction(user_settings);
|
user_settings,
|
||||||
for other_op_head in op_heads.into_iter().skip(1) {
|
op_heads,
|
||||||
tx.merge_operation(other_op_head)?;
|
Some("resolve concurrent operations"),
|
||||||
tx.mut_repo().rebase_descendants(user_settings)?;
|
)
|
||||||
}
|
|
||||||
let merged_repo = tx
|
|
||||||
.write("resolve concurrent operations")
|
|
||||||
.leave_unpublished();
|
|
||||||
Ok(merged_repo.operation().clone())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn _finish_load(&self, operation: Operation, view: View) -> Arc<ReadonlyRepo> {
|
fn _finish_load(&self, operation: Operation, view: View) -> Arc<ReadonlyRepo> {
|
||||||
|
|
Loading…
Reference in a new issue