cstea

Crates.iocstea
lib.rscstea
version2.0.1
sourcesrc
created_at2019-08-05 23:09:58.157347
updated_at2020-01-11 02:29:58.062775
descriptionAn Ingredient crate for working with csv files in rettle.
homepage
repositoryhttps://github.com/slaterb1/cstea
max_upload_size
id154416
size39,592
Benjamin Slater (slaterb1)

documentation

https://docs.rs/cstea

README

cstea

LICENSE License Build Status Crates.io Version Minimum rustc version

This is a generic csv file Fill and Pour Ingredient crate for use with the rettle ETL.

Data Structures

  • FillCsvArg: Ingredient params for FillCsTea
  • FillCsTea: Wrapper to simplifiy the creation of the Fill Ingredient to be used in the rettle Pot.
  • PourCsvArg: Ingredient params for PourCsTea
  • PourCsTea: Wrapper to simplifiy the creation of the Pour Ingredient to be used in the rettle Pot.

Example

#[derive(Default, Clone, Debug, Deserialize, Serialize)]
struct CsTea {
    id: i32,
    name: String,
    value: i32
}

impl Tea for CsTea {
    fn as_any(&self) -> &dyn Any {
        self
    }
}

fn main() {
    let test_csvarg = FillCsvArg::new("fixtures/test.csv", 50);
    let test_pour_csvarg = PourCsvArg::new("fixtures/pour.csv");

    let brewery = Brewery::new(4, Instant::now());
    let mut new_pot = Pot::new();
    let fill_cstea = FillCsTea::new::<CsTea>("csv_tea_source", "csv_fixture", test_csvarg);
    let pour_cstea = PourCsTea::new::<CsTea>("csv_pour_test", test_pour_csvarg);

    new_pot = new_pot.add_source(fill_cstea);

    // Steep operations of choice

    new_pot = new_pot.add_ingredient(pour_cstea);

    new_pot.brew(&brewery);
}
Commit count: 53

cargo fmt