Remove iterator types
With this patch, libimagentryannotation does not have special iterator types anymore. This makes the whole thing more comfortable to use. In imag-annotate, the parameter for the functioncall was removed. Signed-off-by: Matthias Beyer <mail@beyermatthias.de>
This commit is contained in:
parent
c84258da3d
commit
d8cd10a384
4 changed files with 9 additions and 84 deletions
|
@ -194,7 +194,7 @@ fn list(rt: &Runtime) {
|
|||
.ok_or_else(|| EM::EntryNotFound(id.local_display_string()))
|
||||
.map_err(Error::from)
|
||||
.map_err_trace_exit_unwrap(1)
|
||||
.annotations(rt.store())
|
||||
.annotations()
|
||||
.map_err_trace_exit_unwrap(1)
|
||||
.into_get_iter(rt.store())
|
||||
.trace_unwrap_exit(1)
|
||||
|
|
|
@ -36,13 +36,12 @@ use failure::ResultExt;
|
|||
use failure::Error;
|
||||
use failure::err_msg;
|
||||
|
||||
use iter::*;
|
||||
use module_path::ModuleEntryPath;
|
||||
|
||||
pub trait Annotateable {
|
||||
fn annotate<'a>(&mut self, store: &'a Store) -> Result<FileLockEntry<'a>>;
|
||||
fn denotate<'a>(&mut self, store: &'a Store, ann_name: &str) -> Result<Option<FileLockEntry<'a>>>;
|
||||
fn annotations<'a>(&self, store: &'a Store) -> Result<AnnotationIter<'a>>;
|
||||
fn annotations(&self) -> Result<StoreIdIterator>;
|
||||
fn is_annotation(&self) -> Result<bool>;
|
||||
}
|
||||
|
||||
|
@ -87,10 +86,14 @@ impl Annotateable for Entry {
|
|||
}
|
||||
|
||||
/// Get all annotations of an entry
|
||||
fn annotations<'a>(&self, store: &'a Store) -> Result<AnnotationIter<'a>> {
|
||||
fn annotations(&self) -> Result<StoreIdIterator> {
|
||||
self.get_internal_links()
|
||||
.map(|iter| StoreIdIterator::new(Box::new(iter.map(|e| e.get_store_id().clone()).map(Ok))))
|
||||
.map(|i| AnnotationIter::new(i, store))
|
||||
.map(|it| {
|
||||
it.filter(|link| link.get_store_id().is_in_collection(&["annotation"]))
|
||||
.map(|link| Ok(link.get_store_id().clone()))
|
||||
})
|
||||
.map(Box::new)
|
||||
.map(|inner| StoreIdIterator::new(inner))
|
||||
}
|
||||
|
||||
fn is_annotation(&self) -> Result<bool> {
|
||||
|
|
|
@ -1,77 +0,0 @@
|
|||
//
|
||||
// imag - the personal information management suite for the commandline
|
||||
// Copyright (C) 2015-2019 Matthias Beyer <mail@beyermatthias.de> and contributors
|
||||
//
|
||||
// This library is free software; you can redistribute it and/or
|
||||
// modify it under the terms of the GNU Lesser General Public
|
||||
// License as published by the Free Software Foundation; version
|
||||
// 2.1 of the License.
|
||||
//
|
||||
// This library is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
// Lesser General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Lesser General Public
|
||||
// License along with this library; if not, write to the Free Software
|
||||
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
//
|
||||
|
||||
use toml_query::read::TomlValueReadTypeExt;
|
||||
|
||||
use libimagstore::store::Store;
|
||||
use libimagstore::store::FileLockEntry;
|
||||
use libimagstore::storeid::StoreIdIterator;
|
||||
use libimagerror::errors::ErrorMsg as EM;
|
||||
|
||||
use failure::Fallible as Result;
|
||||
use failure::ResultExt;
|
||||
use failure::Error;
|
||||
use failure::err_msg;
|
||||
|
||||
#[derive(Debug)]
|
||||
pub struct AnnotationIter<'a>(StoreIdIterator, &'a Store);
|
||||
|
||||
impl<'a> AnnotationIter<'a> {
|
||||
|
||||
pub fn new(iter: StoreIdIterator, store: &'a Store) -> AnnotationIter<'a> {
|
||||
AnnotationIter(iter, store)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
impl<'a> Iterator for AnnotationIter<'a> {
|
||||
type Item = Result<FileLockEntry<'a>>;
|
||||
|
||||
fn next(&mut self) -> Option<Self::Item> {
|
||||
loop {
|
||||
match self.0.next() {
|
||||
None => return None, // iterator consumed
|
||||
Some(Err(e)) => return Some(Err(e).map_err(Error::from)),
|
||||
Some(Ok(id)) => match self.1.get(id) {
|
||||
Err(e) => {
|
||||
return Some(Err(e)
|
||||
.context(err_msg("Store read error"))
|
||||
.map_err(Error::from))
|
||||
},
|
||||
Ok(Some(entry)) => {
|
||||
match entry
|
||||
.get_header()
|
||||
.read_bool("annotation.is_annotation")
|
||||
.context(EM::EntryHeaderReadError)
|
||||
.map_err(Error::from)
|
||||
{
|
||||
Ok(None) => continue, // not an annotation
|
||||
Ok(Some(false)) => continue,
|
||||
Ok(Some(true)) => return Some(Ok(entry)),
|
||||
Err(e) => return Some(Err(e)),
|
||||
}
|
||||
},
|
||||
Ok(None) => continue,
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -52,5 +52,4 @@ module_entry_path_mod!("annotations");
|
|||
|
||||
pub mod annotateable;
|
||||
pub mod annotation_fetcher;
|
||||
pub mod iter;
|
||||
|
||||
|
|
Loading…
Reference in a new issue