| Crates.io | fluent_pipeline |
| lib.rs | fluent_pipeline |
| version | 0.1.0 |
| created_at | 2025-02-03 13:39:11.332698+00 |
| updated_at | 2025-02-03 13:39:11.332698+00 |
| description | A lightweight pipeline system for Rust. |
| homepage | |
| repository | https://github.com/m1guelpf/pipeline-rs |
| max_upload_size | |
| id | 1540627 |
| size | 5,635 |
A convenient way to "pipe" a given input through a series of invokable classes, closures, or callables, giving each class the opportunity to inspect or modify the input and invoke the next callable in the pipeline.
To get started, create a new pipeline with the send method, passing the input you want to pipe through the pipeline. Then, use the through method to add a series of pipes (either classes implenting the Pipe trait, or closures) to the pipeline. Finally, call the then method to transform and get the final output.
You can also append Pipes to an existing pipeline using the pipe method, or use thenReturn to get the final output without transforming it.
use fluent_pipeline::Pipeline;
Pipeline::send(project).through(&[
PipeType::Pipe(BuildProject()),
PipeType::Pipe(UploadProject()),
PipeType::Pipe(DeployProject()),
PipeType::Fn(|project| {
// ...
return project
})
]).run()
This project is licensed under the MIT License - see the LICENSE file for details.