From dad856ff2a1d9994c9b9762f0c8600d139721436 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sat, 5 Dec 2015 18:04:49 +0100 Subject: [PATCH 1/7] Move get_tags() from BM module to module utilities --- src/module/bm/commands.rs | 25 +++---------------------- src/module/helpers/mod.rs | 1 + src/module/helpers/utils.rs | 29 +++++++++++++++++++++++++++++ 3 files changed, 33 insertions(+), 22 deletions(-) create mode 100644 src/module/helpers/utils.rs diff --git a/src/module/bm/commands.rs b/src/module/bm/commands.rs index 87ba320f..2d6f8bad 100644 --- a/src/module/bm/commands.rs +++ b/src/module/bm/commands.rs @@ -14,6 +14,7 @@ use ui::file::{FilePrinter, TablePrinter}; pub fn add_command(module: &Module, env: CommandEnv) -> CommandResult { use url::Url; + use module::helpers::utils::cli::get_tags; let url = env.matches.value_of("url").unwrap(); @@ -123,6 +124,8 @@ fn get_filtered_files_from_backend<'a>(module: &'a Module, env: &CommandEnv) -> Result>, ModuleError> { + use module::helpers::utils::cli::get_tags; + fn check_tags(tags: &Vec, file: &File) -> bool { if tags.len() != 0 { debug!("Checking tags of: {:?}", file.id()); @@ -159,28 +162,6 @@ fn get_filtered_files_from_backend<'a>(module: &'a Module, }) } -fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Vec { - - fn reject_if_with_spaces(e: &String) -> bool { - if e.contains(" ") { - warn!("Tag contains spaces: '{}'", e); - false - } else { - true - } - } - - debug!("Fetching tags from commandline"); - sub.value_of("tags").and_then(|tags| { - Some(tags.split(",") - .into_iter() - .map(|s| s.to_string()) - .filter(|e| reject_if_with_spaces(e)) - .collect() - ) - }).or(Some(vec![])).unwrap() -} - fn get_matcher<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Option { debug!("Fetching matcher from commandline"); if let Some(s) = sub.value_of("match") { diff --git a/src/module/helpers/mod.rs b/src/module/helpers/mod.rs index f505d688..9ed1a0a2 100644 --- a/src/module/helpers/mod.rs +++ b/src/module/helpers/mod.rs @@ -1 +1,2 @@ pub mod header; +pub mod utils; diff --git a/src/module/helpers/utils.rs b/src/module/helpers/utils.rs new file mode 100644 index 00000000..9589aa2a --- /dev/null +++ b/src/module/helpers/utils.rs @@ -0,0 +1,29 @@ +pub mod cli { + use clap::ArgMatches; + use regex::Regex; + + use runtime::Runtime; + + pub fn get_tags<'a>(rt: &Runtime, sub: &ArgMatches<'a, 'a>) -> Vec { + + fn reject_if_with_spaces(e: &String) -> bool { + if e.contains(" ") { + warn!("Tag contains spaces: '{}'", e); + false + } else { + true + } + } + + debug!("Fetching tags from commandline"); + sub.value_of("tags").and_then(|tags| { + Some(tags.split(",") + .into_iter() + .map(|s| s.to_string()) + .filter(|e| reject_if_with_spaces(e)) + .collect() + ) + }).or(Some(vec![])).unwrap() + } + +} From 6e0d0058b09d43238ddc44cae5af3254144e4ff3 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sat, 5 Dec 2015 18:26:31 +0100 Subject: [PATCH 2/7] Move key generating to top-level spec helpers --- src/module/helpers/header/tags.rs | 9 +++------ src/module/helpers/mod.rs | 17 +++++++++++++++++ 2 files changed, 20 insertions(+), 6 deletions(-) diff --git a/src/module/helpers/header/tags.rs b/src/module/helpers/header/tags.rs index f9c22c33..970a07a5 100644 --- a/src/module/helpers/header/tags.rs +++ b/src/module/helpers/header/tags.rs @@ -4,17 +4,14 @@ pub mod spec { use storage::file::FileHeaderSpec as FHS; + use module::helpers::spec::{named_text, named_text_array}; pub fn url_key() -> FHS { - FHS::Key { name: String::from("URL"), value_type: Box::new(FHS::Text) } + named_text("URL") } pub fn tags_key() -> FHS { - FHS::Key { name: String::from("TAGS"), value_type: Box::new(text_array()) } - } - - pub fn text_array() -> FHS { - FHS::Array { allowed_types: vec![FHS::Text] } + named_text_array("TAGS") } } diff --git a/src/module/helpers/mod.rs b/src/module/helpers/mod.rs index 9ed1a0a2..e06a668b 100644 --- a/src/module/helpers/mod.rs +++ b/src/module/helpers/mod.rs @@ -1,2 +1,19 @@ pub mod header; pub mod utils; + +pub mod spec { + use storage::file::FileHeaderSpec as FHS; + + pub fn named_text(name: &str) -> FHS { + FHS::Key { name: String::from(name), value_type: Box::new(FHS::Text) } + } + + pub fn named_text_array(name: &str) -> FHS { + FHS::Key { name: String::from(name), value_type: Box::new(text_array()) } + } + + pub fn text_array() -> FHS { + FHS::Array { allowed_types: vec![FHS::Text] } + } + +} From ba78f2332803c49762c2cf21d45a7cb39c30022f Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sat, 5 Dec 2015 17:10:25 +0100 Subject: [PATCH 3/7] Remove debug/verbose args from modules. They are set globally --- etc/cli.yml | 85 ----------------------------------------------------- 1 file changed, 85 deletions(-) diff --git a/etc/cli.yml b/etc/cli.yml index 70c05007..4a6590d2 100644 --- a/etc/cli.yml +++ b/etc/cli.yml @@ -34,87 +34,26 @@ subcommands: about: Calendar module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - cont: about: Contact module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - mail: about: Mail module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - wiki: about: Wiki module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - bm: about: Bookmark module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - subcommands: - add: about: Add bookmark @@ -190,33 +129,9 @@ subcommands: about: Todo module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false - news: about: News module version: 0.1 author: Matthias Beyer - args: - - verbose: - short: v - long: verbose - help: Enable verbosity - required: false - - - debug: - short: d - long: debug - help: Sets the level of debugging information - required: false From 95f6f2e97ea9e8aa7de0ac40f2deaf3a894d87c6 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 6 Dec 2015 13:01:02 +0100 Subject: [PATCH 4/7] Move file.rs to subdirectory --- src/storage/{file.rs => file/mod.rs} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename src/storage/{file.rs => file/mod.rs} (100%) diff --git a/src/storage/file.rs b/src/storage/file/mod.rs similarity index 100% rename from src/storage/file.rs rename to src/storage/file/mod.rs From 3b89148cd0b2a716f2201d2cae3a350b6265ca14 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 6 Dec 2015 13:02:21 +0100 Subject: [PATCH 5/7] Move storage/file_id.rs -> storage/file/id.rs --- src/storage/{file_id.rs => file/id.rs} | 0 src/storage/file/mod.rs | 4 +++- src/storage/mod.rs | 3 +-- 3 files changed, 4 insertions(+), 3 deletions(-) rename src/storage/{file_id.rs => file/id.rs} (100%) diff --git a/src/storage/file_id.rs b/src/storage/file/id.rs similarity index 100% rename from src/storage/file_id.rs rename to src/storage/file/id.rs diff --git a/src/storage/file/mod.rs b/src/storage/file/mod.rs index 7a14bb5d..277f7869 100644 --- a/src/storage/file/mod.rs +++ b/src/storage/file/mod.rs @@ -4,8 +4,10 @@ use std::fmt; use regex::Regex; +pub mod id; + use module::Module; -use storage::file_id::*; +use storage::file::id::*; use super::parser::{FileHeaderParser, Parser, ParserError}; #[derive(Debug)] diff --git a/src/storage/mod.rs b/src/storage/mod.rs index 29bdda3a..1b4d3896 100644 --- a/src/storage/mod.rs +++ b/src/storage/mod.rs @@ -8,7 +8,6 @@ use std::path::Path; use std::vec::{Vec, IntoIter}; pub mod file; -pub mod file_id; pub mod parser; pub mod backend; pub mod json; @@ -19,7 +18,7 @@ use glob::Paths; use module::Module; use runtime::Runtime; use storage::file::File; -use storage::file_id::*; +use storage::file::id::*; use storage::parser::{FileHeaderParser, Parser}; pub type BackendOperationResult = Result; From 188aacad75d5e50ba136e9a9e5b0da527d52ed44 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 6 Dec 2015 13:09:51 +0100 Subject: [PATCH 6/7] Move FileHeader{Spec,Data} to own submodules --- src/module/bm/header.rs | 4 +- src/module/helpers/header/tags.rs | 4 +- src/module/helpers/mod.rs | 2 +- src/storage/file/header/data.rs | 37 ++++++ src/storage/file/header/mod.rs | 126 ++++++++++++++++++++ src/storage/file/header/spec.rs | 41 +++++++ src/storage/file/mod.rs | 192 +----------------------------- src/storage/json/parser.rs | 3 +- src/storage/parser.rs | 2 +- 9 files changed, 215 insertions(+), 196 deletions(-) create mode 100644 src/storage/file/header/data.rs create mode 100644 src/storage/file/header/mod.rs create mode 100644 src/storage/file/header/spec.rs diff --git a/src/module/bm/header.rs b/src/module/bm/header.rs index c25199aa..3cb4f75a 100644 --- a/src/module/bm/header.rs +++ b/src/module/bm/header.rs @@ -1,6 +1,6 @@ use module::helpers::header as headerhelpers; -use storage::file::FileHeaderData as FHD; -use storage::file::FileHeaderSpec as FHS; +use storage::file::header::data::FileHeaderData as FHD; +use storage::file::header::spec::FileHeaderSpec as FHS; pub fn get_spec() -> FHS { FHS::Map { diff --git a/src/module/helpers/header/tags.rs b/src/module/helpers/header/tags.rs index 970a07a5..2ad2e61b 100644 --- a/src/module/helpers/header/tags.rs +++ b/src/module/helpers/header/tags.rs @@ -3,7 +3,7 @@ */ pub mod spec { - use storage::file::FileHeaderSpec as FHS; + use storage::file::header::spec::FileHeaderSpec as FHS; use module::helpers::spec::{named_text, named_text_array}; pub fn url_key() -> FHS { @@ -18,7 +18,7 @@ pub mod spec { pub mod data { use std::ops::Deref; - use storage::file::FileHeaderData as FHD; + use storage::file::header::data::FileHeaderData as FHD; pub fn build_tag_array(tags: &Vec) -> FHD { let texttags = tags.into_iter().map(|t| FHD::Text(t.clone())).collect(); diff --git a/src/module/helpers/mod.rs b/src/module/helpers/mod.rs index e06a668b..8b501b4a 100644 --- a/src/module/helpers/mod.rs +++ b/src/module/helpers/mod.rs @@ -2,7 +2,7 @@ pub mod header; pub mod utils; pub mod spec { - use storage::file::FileHeaderSpec as FHS; + use storage::file::header::spec::FileHeaderSpec as FHS; pub fn named_text(name: &str) -> FHS { FHS::Key { name: String::from(name), value_type: Box::new(FHS::Text) } diff --git a/src/storage/file/header/data.rs b/src/storage/file/header/data.rs new file mode 100644 index 00000000..f94a4b26 --- /dev/null +++ b/src/storage/file/header/data.rs @@ -0,0 +1,37 @@ +use regex::Regex; + +#[derive(Debug)] +#[derive(Clone)] +pub enum FileHeaderData { + Null, + Bool(bool), + Integer(i64), + UInteger(u64), + Float(f64), + Text(String), + Key { name: String, value: Box }, + Map { keys: Vec }, + Array { values: Box> }, +} + +impl FileHeaderData { + + pub fn matches_with(&self, r: &Regex) -> bool { + match self { + &FileHeaderData::Text(ref t) => r.is_match(&t[..]), + &FileHeaderData::Key{name: ref n, value: ref val} => { + r.is_match(n) || val.matches_with(r) + }, + + &FileHeaderData::Map{keys: ref dks} => { + dks.iter().any(|x| x.matches_with(r)) + }, + + &FileHeaderData::Array{values: ref vs} => { + vs.iter().any(|x| x.matches_with(r)) + } + + _ => false, + } + } +} diff --git a/src/storage/file/header/mod.rs b/src/storage/file/header/mod.rs new file mode 100644 index 00000000..8725d40d --- /dev/null +++ b/src/storage/file/header/mod.rs @@ -0,0 +1,126 @@ +use std::error::Error; +use std::fmt::{Debug, Display, Formatter}; +use std::fmt; + +pub mod spec; +pub mod data; + +use self::data::*; +use self::spec::*; + +pub struct MatchError<'a> { + summary: String, + expected: &'a FileHeaderSpec, + found: &'a FileHeaderData +} + +impl<'a> MatchError<'a> { + + pub fn new(s: String, + ex: &'a FileHeaderSpec, + found: &'a FileHeaderData) -> MatchError<'a> { + MatchError { + summary: s, + expected: ex, + found: found, + } + } + + pub fn format(&self) -> String { + format!("MatchError: {:?}\nExpected: {:?}\nFound: {:?}\n", + self.summary, self.expected, self.found) + } +} + +impl<'a> Error for MatchError<'a> { + + fn description(&self) -> &str { + &self.summary[..] + } + + fn cause(&self) -> Option<&Error> { + None + } + +} + +impl<'a> Debug for MatchError<'a> { + + fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { + write!(fmt, "{}", self.format()); + Ok(()) + } + +} + +impl<'a> Display for MatchError<'a> { + + fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { + write!(fmt, "{}", self.format()); + Ok(()) + } + +} + +pub fn match_header_spec<'a>(spec: &'a FileHeaderSpec, data: &'a FileHeaderData) + -> Option> +{ + debug!("Start matching:\n'{:?}'\non\n{:?}", spec, data); + match (spec, data) { + (&FileHeaderSpec::Null, &FileHeaderData::Null) => { } + (&FileHeaderSpec::Bool, &FileHeaderData::Bool(_)) => { } + (&FileHeaderSpec::Integer, &FileHeaderData::Integer(_)) => { } + (&FileHeaderSpec::UInteger, &FileHeaderData::UInteger(_)) => { } + (&FileHeaderSpec::Float, &FileHeaderData::Float(_)) => { } + (&FileHeaderSpec::Text, &FileHeaderData::Text(_)) => { } + + ( + &FileHeaderSpec::Key{name: ref kname, value_type: ref vtype}, + &FileHeaderData::Key{name: ref n, value: ref val} + ) => { + debug!("Matching Key: '{:?}' == '{:?}', Value: '{:?}' == '{:?}'", + kname, n, + vtype, val); + if kname != n { + debug!("Keys not matching"); + unimplemented!(); + } + return match_header_spec(&*vtype, &*val); + } + + ( + &FileHeaderSpec::Map{keys: ref sks}, + &FileHeaderData::Map{keys: ref dks} + ) => { + debug!("Matching Map: '{:?}' == '{:?}'", sks, dks); + + for (s, d) in sks.iter().zip(dks.iter()) { + let res = match_header_spec(s, d); + if res.is_some() { + return res; + } + } + } + + ( + &FileHeaderSpec::Array{allowed_types: ref vtypes}, + &FileHeaderData::Array{values: ref vs} + ) => { + debug!("Matching Array: '{:?}' == '{:?}'", vtypes, vs); + for (t, v) in vtypes.iter().zip(vs.iter()) { + let res = match_header_spec(t, v); + if res.is_some() { + return res; + } + } + } + + (k, v) => { + return Some(MatchError::new(String::from("Expected type does not match found type"), + k, v + )) + } + } + None +} + diff --git a/src/storage/file/header/spec.rs b/src/storage/file/header/spec.rs new file mode 100644 index 00000000..bcec162e --- /dev/null +++ b/src/storage/file/header/spec.rs @@ -0,0 +1,41 @@ +use std::fmt::{Debug, Display, Formatter}; +use std::fmt; + +#[derive(Debug)] +#[derive(Clone)] +pub enum FileHeaderSpec { + Null, + Bool, + Integer, + UInteger, + Float, + Text, + Key { name: String, value_type: Box }, + Map { keys: Vec }, + Array { allowed_types: Vec }, +} + +impl Display for FileHeaderSpec { + + fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { + match self { + &FileHeaderSpec::Null => write!(fmt, "NULL"), + &FileHeaderSpec::Bool => write!(fmt, "Bool"), + &FileHeaderSpec::Integer => write!(fmt, "Integer"), + &FileHeaderSpec::UInteger => write!(fmt, "UInteger"), + &FileHeaderSpec::Float => write!(fmt, "Float"), + &FileHeaderSpec::Text => write!(fmt, "Text"), + &FileHeaderSpec::Key{name: ref n, value_type: ref vt} => { + write!(fmt, "Key({:?}) -> {:?}", n, vt) + } + &FileHeaderSpec::Map{keys: ref ks} => { + write!(fmt, "Map -> {:?}", ks) + } + &FileHeaderSpec::Array{allowed_types: ref at} => { + write!(fmt, "Array({:?})", at) + } + } + } + +} + diff --git a/src/storage/file/mod.rs b/src/storage/file/mod.rs index 277f7869..baa40002 100644 --- a/src/storage/file/mod.rs +++ b/src/storage/file/mod.rs @@ -5,200 +5,14 @@ use std::fmt; use regex::Regex; pub mod id; +pub mod header; use module::Module; use storage::file::id::*; use super::parser::{FileHeaderParser, Parser, ParserError}; -#[derive(Debug)] -#[derive(Clone)] -pub enum FileHeaderSpec { - Null, - Bool, - Integer, - UInteger, - Float, - Text, - Key { name: String, value_type: Box }, - Map { keys: Vec }, - Array { allowed_types: Vec }, -} - -#[derive(Debug)] -#[derive(Clone)] -pub enum FileHeaderData { - Null, - Bool(bool), - Integer(i64), - UInteger(u64), - Float(f64), - Text(String), - Key { name: String, value: Box }, - Map { keys: Vec }, - Array { values: Box> }, -} - -impl Display for FileHeaderSpec { - - fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { - match self { - &FileHeaderSpec::Null => write!(fmt, "NULL"), - &FileHeaderSpec::Bool => write!(fmt, "Bool"), - &FileHeaderSpec::Integer => write!(fmt, "Integer"), - &FileHeaderSpec::UInteger => write!(fmt, "UInteger"), - &FileHeaderSpec::Float => write!(fmt, "Float"), - &FileHeaderSpec::Text => write!(fmt, "Text"), - &FileHeaderSpec::Key{name: ref n, value_type: ref vt} => { - write!(fmt, "Key({:?}) -> {:?}", n, vt) - } - &FileHeaderSpec::Map{keys: ref ks} => { - write!(fmt, "Map -> {:?}", ks) - } - &FileHeaderSpec::Array{allowed_types: ref at} => { - write!(fmt, "Array({:?})", at) - } - } - } - -} - -impl FileHeaderData { - - pub fn matches_with(&self, r: &Regex) -> bool { - match self { - &FileHeaderData::Text(ref t) => r.is_match(&t[..]), - &FileHeaderData::Key{name: ref n, value: ref val} => { - r.is_match(n) || val.matches_with(r) - }, - - &FileHeaderData::Map{keys: ref dks} => { - dks.iter().any(|x| x.matches_with(r)) - }, - - &FileHeaderData::Array{values: ref vs} => { - vs.iter().any(|x| x.matches_with(r)) - } - - _ => false, - } - } -} - -pub struct MatchError<'a> { - summary: String, - expected: &'a FileHeaderSpec, - found: &'a FileHeaderData -} - -impl<'a> MatchError<'a> { - - pub fn new(s: String, - ex: &'a FileHeaderSpec, - found: &'a FileHeaderData) -> MatchError<'a> { - MatchError { - summary: s, - expected: ex, - found: found, - } - } - - pub fn format(&self) -> String { - format!("MatchError: {:?}\nExpected: {:?}\nFound: {:?}\n", - self.summary, self.expected, self.found) - } -} - -impl<'a> Error for MatchError<'a> { - - fn description(&self) -> &str { - &self.summary[..] - } - - fn cause(&self) -> Option<&Error> { - None - } - -} - -impl<'a> Debug for MatchError<'a> { - - fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { - write!(fmt, "{}", self.format()); - Ok(()) - } - -} - -impl<'a> Display for MatchError<'a> { - - fn fmt(&self, fmt: &mut Formatter) -> fmt::Result { - write!(fmt, "{}", self.format()); - Ok(()) - } - -} - -pub fn match_header_spec<'a>(spec: &'a FileHeaderSpec, data: &'a FileHeaderData) - -> Option> -{ - debug!("Start matching:\n'{:?}'\non\n{:?}", spec, data); - match (spec, data) { - (&FileHeaderSpec::Null, &FileHeaderData::Null) => { } - (&FileHeaderSpec::Bool, &FileHeaderData::Bool(_)) => { } - (&FileHeaderSpec::Integer, &FileHeaderData::Integer(_)) => { } - (&FileHeaderSpec::UInteger, &FileHeaderData::UInteger(_)) => { } - (&FileHeaderSpec::Float, &FileHeaderData::Float(_)) => { } - (&FileHeaderSpec::Text, &FileHeaderData::Text(_)) => { } - - ( - &FileHeaderSpec::Key{name: ref kname, value_type: ref vtype}, - &FileHeaderData::Key{name: ref n, value: ref val} - ) => { - debug!("Matching Key: '{:?}' == '{:?}', Value: '{:?}' == '{:?}'", - kname, n, - vtype, val); - if kname != n { - debug!("Keys not matching"); - unimplemented!(); - } - return match_header_spec(&*vtype, &*val); - } - - ( - &FileHeaderSpec::Map{keys: ref sks}, - &FileHeaderData::Map{keys: ref dks} - ) => { - debug!("Matching Map: '{:?}' == '{:?}'", sks, dks); - - for (s, d) in sks.iter().zip(dks.iter()) { - let res = match_header_spec(s, d); - if res.is_some() { - return res; - } - } - } - - ( - &FileHeaderSpec::Array{allowed_types: ref vtypes}, - &FileHeaderData::Array{values: ref vs} - ) => { - debug!("Matching Array: '{:?}' == '{:?}'", vtypes, vs); - for (t, v) in vtypes.iter().zip(vs.iter()) { - let res = match_header_spec(t, v); - if res.is_some() { - return res; - } - } - } - - (k, v) => { - return Some(MatchError::new(String::from("Expected type does not match found type"), - k, v - )) - } - } - None -} +use self::header::spec::*; +use self::header::data::*; /* * Internal abstract view on a file. Does not exist on the FS and is just kept diff --git a/src/storage/json/parser.rs b/src/storage/json/parser.rs index 39b6ad58..c752e20a 100644 --- a/src/storage/json/parser.rs +++ b/src/storage/json/parser.rs @@ -8,7 +8,8 @@ use serde::ser::Serialize; use serde::ser::Serializer as Ser; use storage::parser::{FileHeaderParser, ParserError}; -use storage::file::{FileHeaderSpec, FileHeaderData}; +use storage::file::header::spec::FileHeaderSpec; +use storage::file::header::data::FileHeaderData; pub struct JsonHeaderParser { spec: Option, diff --git a/src/storage/parser.rs b/src/storage/parser.rs index 0f30f04b..c627e56a 100644 --- a/src/storage/parser.rs +++ b/src/storage/parser.rs @@ -4,7 +4,7 @@ use std::fmt; use regex::Regex; -use super::file::FileHeaderData; +use super::file::header::data::FileHeaderData; pub struct ParserError { summary: String, From ee78c249f060b72a9a5be53f0ed6a1735bf48a37 Mon Sep 17 00:00:00 2001 From: Matthias Beyer Date: Sun, 6 Dec 2015 12:55:26 +0100 Subject: [PATCH 7/7] Remove leftover file from storage backend moving --- src/storage/backend.rs | 0 src/storage/mod.rs | 1 - 2 files changed, 1 deletion(-) delete mode 100644 src/storage/backend.rs diff --git a/src/storage/backend.rs b/src/storage/backend.rs deleted file mode 100644 index e69de29b..00000000 diff --git a/src/storage/mod.rs b/src/storage/mod.rs index 1b4d3896..96fe6968 100644 --- a/src/storage/mod.rs +++ b/src/storage/mod.rs @@ -9,7 +9,6 @@ use std::vec::{Vec, IntoIter}; pub mod file; pub mod parser; -pub mod backend; pub mod json; use glob::glob;