Merge pull request #1142 from matthiasbeyer/libimagentryref/abbrev-hash
libimagentryref: abbrev hash
This commit is contained in:
commit
494327e109
2 changed files with 53 additions and 20 deletions
|
@ -47,10 +47,12 @@ mod ui;
|
||||||
use ui::build_ui;
|
use ui::build_ui;
|
||||||
|
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
|
use std::process::exit;
|
||||||
|
|
||||||
use libimagentryref::refstore::RefStore;
|
use libimagentryref::refstore::RefStore;
|
||||||
use libimagentryref::flags::RefFlags;
|
use libimagentryref::flags::RefFlags;
|
||||||
use libimagerror::trace::trace_error;
|
use libimagerror::trace::trace_error;
|
||||||
|
use libimagerror::trace::MapErrTrace;
|
||||||
use libimagrt::setup::generate_runtime_setup;
|
use libimagrt::setup::generate_runtime_setup;
|
||||||
use libimagrt::runtime::Runtime;
|
use libimagrt::runtime::Runtime;
|
||||||
|
|
||||||
|
@ -101,14 +103,20 @@ fn remove(rt: &Runtime) {
|
||||||
let hash = cmd.value_of("hash").map(String::from).unwrap(); // saved by clap
|
let hash = cmd.value_of("hash").map(String::from).unwrap(); // saved by clap
|
||||||
let yes = cmd.is_present("yes");
|
let yes = cmd.is_present("yes");
|
||||||
|
|
||||||
|
match rt.store().find_storeid_by_partial_hash(&hash).map_err_trace_exit_unwrap(1) {
|
||||||
|
Some(sid) => {
|
||||||
if yes || ask_bool(&format!("Delete Ref with hash '{}'", hash)[..], None) {
|
if yes || ask_bool(&format!("Delete Ref with hash '{}'", hash)[..], None) {
|
||||||
match rt.store().delete_by_hash(hash) {
|
debug!("Found for hash '{}' -> {:?}", hash, sid);
|
||||||
Err(e) => trace_error(&e),
|
rt.store().delete(sid).map_err_trace_exit_unwrap(1)
|
||||||
Ok(_) => info!("Ok"),
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
info!("Aborted");
|
info!("Aborted");
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
None => {
|
||||||
|
error!("Not id for hash '{}' found", hash);
|
||||||
|
exit(1)
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,8 +22,8 @@ use std::collections::BTreeMap;
|
||||||
use std::fs::File;
|
use std::fs::File;
|
||||||
|
|
||||||
use libimagstore::store::FileLockEntry;
|
use libimagstore::store::FileLockEntry;
|
||||||
use libimagstore::storeid::StoreId;
|
|
||||||
use libimagstore::storeid::IntoStoreId;
|
use libimagstore::storeid::IntoStoreId;
|
||||||
|
use libimagstore::storeid::StoreId;
|
||||||
use libimagstore::storeid::StoreIdIterator;
|
use libimagstore::storeid::StoreIdIterator;
|
||||||
use libimagstore::store::Store;
|
use libimagstore::store::Store;
|
||||||
|
|
||||||
|
@ -43,14 +43,21 @@ pub trait RefStore {
|
||||||
/// Check whether there is a reference to the file at `pb`
|
/// Check whether there is a reference to the file at `pb`
|
||||||
fn exists(&self, pb: PathBuf) -> Result<bool>;
|
fn exists(&self, pb: PathBuf) -> Result<bool>;
|
||||||
|
|
||||||
/// Try to get `si` as Ref object from the store
|
|
||||||
fn get<'a>(&'a self, si: StoreId) -> Result<FileLockEntry<'a>>;
|
|
||||||
|
|
||||||
/// Get a Ref object from the store by hash.
|
/// Get a Ref object from the store by hash.
|
||||||
///
|
///
|
||||||
/// Returns None if the hash cannot be found.
|
/// Returns None if the hash cannot be found.
|
||||||
fn get_by_hash<'a>(&'a self, hash: String) -> Result<Option<FileLockEntry<'a>>>;
|
fn get_by_hash<'a>(&'a self, hash: String) -> Result<Option<FileLockEntry<'a>>>;
|
||||||
|
|
||||||
|
/// Find a store id by partial ref (also see documentation for
|
||||||
|
/// `RefStore::get_by_partitial_hash()`.
|
||||||
|
fn find_storeid_by_partial_hash(&self, hash: &String) -> Result<Option<StoreId>>;
|
||||||
|
|
||||||
|
/// Get a Ref object from the store by (eventually partial) hash.
|
||||||
|
///
|
||||||
|
/// If the hash is complete, `RefStore::get_by_hash()` should be used as it is cheaper.
|
||||||
|
/// If the hash comes from user input and thus might be abbreviated, this function can be used.
|
||||||
|
fn get_by_partitial_hash<'a>(&'a self, hash: &String) -> Result<Option<FileLockEntry<'a>>>;
|
||||||
|
|
||||||
/// Delete a ref by hash
|
/// Delete a ref by hash
|
||||||
///
|
///
|
||||||
/// If the returned Result contains an error, the ref might not be deleted.
|
/// If the returned Result contains an error, the ref might not be deleted.
|
||||||
|
@ -111,14 +118,6 @@ impl RefStore for Store {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Try to get `si` as Ref object from the store
|
|
||||||
fn get<'a>(&'a self, si: StoreId) -> Result<FileLockEntry<'a>> {
|
|
||||||
match self.get(si)? {
|
|
||||||
None => return Err(RE::from_kind(REK::RefNotInStore)),
|
|
||||||
Some(fle) => Ok(fle),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get a Ref object from the store by hash.
|
/// Get a Ref object from the store by hash.
|
||||||
///
|
///
|
||||||
/// Returns None if the hash cannot be found.
|
/// Returns None if the hash cannot be found.
|
||||||
|
@ -129,6 +128,32 @@ impl RefStore for Store {
|
||||||
.map_err(From::from)
|
.map_err(From::from)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn find_storeid_by_partial_hash(&self, hash: &String) -> Result<Option<StoreId>> {
|
||||||
|
debug!("Trying to find '{}' in store...", hash);
|
||||||
|
for id in self.retrieve_for_module("ref")? {
|
||||||
|
let components_have_hash = id
|
||||||
|
.components()
|
||||||
|
.any(|c| c.as_os_str().to_str().map(|s| s.contains(hash)).unwrap_or(false));
|
||||||
|
|
||||||
|
if components_have_hash {
|
||||||
|
debug!("Found hash '{}' in {:?}", hash, id);
|
||||||
|
return Ok(Some(id))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Ok(None)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Get a Ref object from the store by (eventually partial) hash.
|
||||||
|
///
|
||||||
|
/// If the hash is complete, `RefStore::get_by_hash()` should be used as it is cheaper.
|
||||||
|
/// If the hash comes from user input and thus might be abbreviated, this function can be used.
|
||||||
|
fn get_by_partitial_hash<'a>(&'a self, hash: &String) -> Result<Option<FileLockEntry<'a>>> {
|
||||||
|
match self.find_storeid_by_partial_hash(hash)? {
|
||||||
|
Some(id) => self.get(id).map_err(From::from),
|
||||||
|
None => Ok(None),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Delete a ref by hash
|
/// Delete a ref by hash
|
||||||
///
|
///
|
||||||
/// If the returned Result contains an error, the ref might not be deleted.
|
/// If the returned Result contains an error, the ref might not be deleted.
|
||||||
|
|
Loading…
Reference in a new issue