imag/bin/core/imag-store/src/dump.rs

52 lines
1.7 KiB
Rust
Raw Normal View History

2017-06-18 16:57:15 +00:00
//
// imag - the personal information management suite for the commandline
// Copyright (C) 2015-2018 Matthias Beyer <mail@beyermatthias.de> and contributors
2017-06-18 16:57:15 +00:00
//
// 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
//
2017-06-18 18:00:47 +00:00
use std::process::exit;
use libimagrt::runtime::Runtime;
use libimagerror::trace::*;
2017-06-18 16:57:15 +00:00
pub fn dump(rt: &mut Runtime) {
2017-06-18 18:00:47 +00:00
let cachingres = rt
.store()
.entries()
.map_err_trace()
.map(|iter| {
for elem in iter {
debug!("Working on {:?}", elem);
if let Ok(_) = rt.store().get(elem.clone()).map_err_dbg_trace() {
info!("Loading entry at {:?} succeeded", elem);
} else {
error!("Loading entry at {:?} failed", elem);
}
}
});
if let Ok(_) = cachingres {
2017-06-20 18:57:18 +00:00
if let Err(_) = rt.store_backend_to_stdout().map_err_trace() {
2017-06-18 18:00:47 +00:00
error!("Loading Store IO backend failed");
exit(1);
}
} else {
error!("Loading entries failed");
exit(1);
}
2017-06-18 16:57:15 +00:00
}