mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-26 06:01:48 +00:00
index: load index file eagerly in Index::load() now that Repo::index() is lazy
This commit is contained in:
parent
2d9aa08334
commit
af1760b02e
2 changed files with 20 additions and 43 deletions
|
@ -20,7 +20,7 @@ use std::fs::File;
|
||||||
use std::io;
|
use std::io;
|
||||||
use std::io::{Cursor, Read, Write};
|
use std::io::{Cursor, Read, Write};
|
||||||
use std::path::{Path, PathBuf};
|
use std::path::{Path, PathBuf};
|
||||||
use std::sync::{Arc, Mutex};
|
use std::sync::Arc;
|
||||||
|
|
||||||
use blake2::{Blake2b, Digest};
|
use blake2::{Blake2b, Digest};
|
||||||
use byteorder::{LittleEndian, ReadBytesExt, WriteBytesExt};
|
use byteorder::{LittleEndian, ReadBytesExt, WriteBytesExt};
|
||||||
|
@ -1103,14 +1103,11 @@ impl IndexFile {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct Index<'r> {
|
pub struct Index {
|
||||||
repo: &'r ReadonlyRepo,
|
index_file: Arc<IndexFile>,
|
||||||
dir: PathBuf,
|
|
||||||
op_id: Mutex<OperationId>,
|
|
||||||
index_file: Mutex<Option<Arc<IndexFile>>>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Index<'_> {
|
impl Index {
|
||||||
pub fn init(dir: PathBuf) {
|
pub fn init(dir: PathBuf) {
|
||||||
std::fs::create_dir(dir.join("operations")).unwrap();
|
std::fs::create_dir(dir.join("operations")).unwrap();
|
||||||
}
|
}
|
||||||
|
@ -1121,39 +1118,25 @@ impl Index<'_> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn load(repo: &ReadonlyRepo, dir: PathBuf, op_id: OperationId) -> Index {
|
pub fn load(repo: &ReadonlyRepo, dir: PathBuf, op_id: OperationId) -> Index {
|
||||||
|
let op_id_hex = op_id.hex();
|
||||||
|
let op_id_file = dir.join("operations").join(&op_id_hex);
|
||||||
|
let index_file = if op_id_file.exists() {
|
||||||
|
let op_id = OperationId(hex::decode(op_id_hex).unwrap());
|
||||||
|
IndexFile::load_at_operation(&dir, repo.store().hash_length(), &op_id).unwrap()
|
||||||
|
} else {
|
||||||
|
let op = repo.view().get_operation(&op_id).unwrap();
|
||||||
|
IndexFile::index(repo.store(), &dir, &op).unwrap()
|
||||||
|
};
|
||||||
|
|
||||||
Index {
|
Index {
|
||||||
repo,
|
index_file: Arc::new(index_file),
|
||||||
dir,
|
|
||||||
op_id: Mutex::new(op_id),
|
|
||||||
index_file: Mutex::new(None),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Maybe just call this data() or something? We should also hide the
|
// TODO: Maybe just call this data() or something? We should also hide the
|
||||||
// IndexFile type from the API.
|
// IndexFile type from the API.
|
||||||
pub fn index_file(&self) -> Arc<IndexFile> {
|
pub fn index_file(&self) -> Arc<IndexFile> {
|
||||||
let mut locked_index_file = self.index_file.lock().unwrap();
|
self.index_file.clone()
|
||||||
if locked_index_file.is_none() {
|
|
||||||
locked_index_file.replace(Arc::new(self.do_load()));
|
|
||||||
}
|
|
||||||
locked_index_file.as_ref().unwrap().clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
fn do_load(&self) -> IndexFile {
|
|
||||||
let op_id_hex = self.op_id.lock().unwrap().hex();
|
|
||||||
let op_id_file = self.dir.join("operations").join(&op_id_hex);
|
|
||||||
if op_id_file.exists() {
|
|
||||||
let op_id = OperationId(hex::decode(op_id_hex).unwrap());
|
|
||||||
IndexFile::load_at_operation(&self.dir, self.repo.store().hash_length(), &op_id)
|
|
||||||
.unwrap()
|
|
||||||
} else {
|
|
||||||
let op = self
|
|
||||||
.repo
|
|
||||||
.view()
|
|
||||||
.get_operation(&self.op_id.lock().unwrap())
|
|
||||||
.unwrap();
|
|
||||||
IndexFile::index(self.repo.store(), &self.dir, &op).unwrap()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,7 +65,7 @@ pub struct ReadonlyRepo {
|
||||||
wc_path: PathBuf,
|
wc_path: PathBuf,
|
||||||
store: Arc<StoreWrapper>,
|
store: Arc<StoreWrapper>,
|
||||||
settings: RepoSettings,
|
settings: RepoSettings,
|
||||||
index: Mutex<Option<Arc<Index<'static>>>>,
|
index: Mutex<Option<Arc<Index>>>,
|
||||||
working_copy: Arc<Mutex<WorkingCopy>>,
|
working_copy: Arc<Mutex<WorkingCopy>>,
|
||||||
view: ReadonlyView,
|
view: ReadonlyView,
|
||||||
evolution: Option<ReadonlyEvolution<'static>>,
|
evolution: Option<ReadonlyEvolution<'static>>,
|
||||||
|
@ -217,23 +217,17 @@ impl ReadonlyRepo {
|
||||||
&self.wc_path
|
&self.wc_path
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn index<'r>(&'r self) -> Arc<Index<'r>> {
|
pub fn index(&self) -> Arc<Index> {
|
||||||
let mut locked_index = self.index.lock().unwrap();
|
let mut locked_index = self.index.lock().unwrap();
|
||||||
if locked_index.is_none() {
|
if locked_index.is_none() {
|
||||||
let repo_ref: &ReadonlyRepo = self;
|
|
||||||
let op_id = self.view.base_op_head_id().clone();
|
let op_id = self.view.base_op_head_id().clone();
|
||||||
let static_lifetime_repo: &'static ReadonlyRepo =
|
|
||||||
unsafe { std::mem::transmute(repo_ref) };
|
|
||||||
locked_index.replace(Arc::new(Index::load(
|
locked_index.replace(Arc::new(Index::load(
|
||||||
static_lifetime_repo,
|
self,
|
||||||
self.repo_path.join("index"),
|
self.repo_path.join("index"),
|
||||||
op_id,
|
op_id,
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
let index: Arc<Index<'static>> = locked_index.as_ref().unwrap().clone();
|
locked_index.as_ref().unwrap().clone()
|
||||||
// cast to lifetime of self
|
|
||||||
let index: Arc<Index<'r>> = unsafe { std::mem::transmute(index) };
|
|
||||||
index
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn reindex(&mut self) -> Arc<Index> {
|
pub fn reindex(&mut self) -> Arc<Index> {
|
||||||
|
|
Loading…
Reference in a new issue