forked from mirrors/jj
view: make root commit public
This commit is contained in:
parent
b52cfc156c
commit
64fcf90c68
4 changed files with 16 additions and 10 deletions
|
@ -22,7 +22,7 @@ use crate::lock::FileLock;
|
||||||
use crate::op_store::{OpStore, OperationId, OperationMetadata};
|
use crate::op_store::{OpStore, OperationId, OperationMetadata};
|
||||||
use crate::operation::Operation;
|
use crate::operation::Operation;
|
||||||
use crate::repo::RepoLoader;
|
use crate::repo::RepoLoader;
|
||||||
use crate::store::{CommitId, Timestamp};
|
use crate::store::Timestamp;
|
||||||
use crate::transaction::UnpublishedOperation;
|
use crate::transaction::UnpublishedOperation;
|
||||||
use crate::{dag_walk, op_store};
|
use crate::{dag_walk, op_store};
|
||||||
|
|
||||||
|
@ -43,10 +43,8 @@ impl OpHeadsStore {
|
||||||
pub fn init(
|
pub fn init(
|
||||||
dir: PathBuf,
|
dir: PathBuf,
|
||||||
op_store: &Arc<dyn OpStore>,
|
op_store: &Arc<dyn OpStore>,
|
||||||
checkout: CommitId,
|
root_view: &op_store::View,
|
||||||
) -> (Self, OperationId, op_store::View) {
|
) -> (Self, OperationId) {
|
||||||
let mut root_view = op_store::View::new(checkout.clone());
|
|
||||||
root_view.head_ids.insert(checkout);
|
|
||||||
let root_view_id = op_store.write_view(&root_view).unwrap();
|
let root_view_id = op_store.write_view(&root_view).unwrap();
|
||||||
let operation_metadata =
|
let operation_metadata =
|
||||||
OperationMetadata::new("initialize repo".to_string(), Timestamp::now());
|
OperationMetadata::new("initialize repo".to_string(), Timestamp::now());
|
||||||
|
@ -59,7 +57,7 @@ impl OpHeadsStore {
|
||||||
|
|
||||||
let op_heads_store = OpHeadsStore { dir };
|
let op_heads_store = OpHeadsStore { dir };
|
||||||
op_heads_store.add_op_head(&init_operation_id);
|
op_heads_store.add_op_head(&init_operation_id);
|
||||||
(op_heads_store, init_operation_id, root_view)
|
(op_heads_store, init_operation_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn load(dir: PathBuf) -> OpHeadsStore {
|
pub fn load(dir: PathBuf) -> OpHeadsStore {
|
||||||
|
|
|
@ -215,8 +215,12 @@ impl ReadonlyRepo {
|
||||||
|
|
||||||
let op_heads_dir = repo_path.join("op_heads");
|
let op_heads_dir = repo_path.join("op_heads");
|
||||||
std::fs::create_dir(&op_heads_dir).unwrap();
|
std::fs::create_dir(&op_heads_dir).unwrap();
|
||||||
let (op_heads_store, init_op_id, root_view) =
|
let mut root_view = op_store::View::new(checkout_commit.id().clone());
|
||||||
OpHeadsStore::init(op_heads_dir, &op_store, checkout_commit.id().clone());
|
root_view.head_ids.insert(checkout_commit.id().clone());
|
||||||
|
root_view
|
||||||
|
.public_head_ids
|
||||||
|
.insert(store.root_commit_id().clone());
|
||||||
|
let (op_heads_store, init_op_id) = OpHeadsStore::init(op_heads_dir, &op_store, &root_view);
|
||||||
let op_heads_store = Arc::new(op_heads_store);
|
let op_heads_store = Arc::new(op_heads_store);
|
||||||
|
|
||||||
fs::create_dir(repo_path.join("index")).unwrap();
|
fs::create_dir(repo_path.join("index")).unwrap();
|
||||||
|
|
|
@ -528,14 +528,14 @@ fn test_evaluate_expression_public_heads(use_git: bool) {
|
||||||
let mut tx = repo.start_transaction("test");
|
let mut tx = repo.start_transaction("test");
|
||||||
let mut_repo = tx.mut_repo();
|
let mut_repo = tx.mut_repo();
|
||||||
|
|
||||||
|
let root_commit = repo.store().root_commit();
|
||||||
let commit1 = testutils::create_random_commit(&settings, &repo).write_to_repo(mut_repo);
|
let commit1 = testutils::create_random_commit(&settings, &repo).write_to_repo(mut_repo);
|
||||||
let commit2 = testutils::create_random_commit(&settings, &repo).write_to_repo(mut_repo);
|
let commit2 = testutils::create_random_commit(&settings, &repo).write_to_repo(mut_repo);
|
||||||
|
|
||||||
// Can get public heads with root commit as only public head
|
// Can get public heads with root commit as only public head
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
resolve_commit_ids(mut_repo.as_repo_ref(), "public_heads()"),
|
resolve_commit_ids(mut_repo.as_repo_ref(), "public_heads()"),
|
||||||
// TODO: This should include the root commit
|
vec![root_commit.id().clone()]
|
||||||
vec![]
|
|
||||||
);
|
);
|
||||||
// Can get public heads with a single public head
|
// Can get public heads with a single public head
|
||||||
mut_repo.add_public_head(&commit1);
|
mut_repo.add_public_head(&commit1);
|
||||||
|
|
|
@ -24,6 +24,10 @@ fn test_heads_empty(use_git: bool) {
|
||||||
|
|
||||||
let wc = repo.working_copy_locked();
|
let wc = repo.working_copy_locked();
|
||||||
assert_eq!(*repo.view().heads(), hashset! {wc.current_commit_id()});
|
assert_eq!(*repo.view().heads(), hashset! {wc.current_commit_id()});
|
||||||
|
assert_eq!(
|
||||||
|
*repo.view().public_heads(),
|
||||||
|
hashset! {repo.store().root_commit_id().clone()}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test_case(false ; "local store")]
|
#[test_case(false ; "local store")]
|
||||||
|
|
Loading…
Reference in a new issue