#![allow(unknown_lints)]
#![deny(
clippy::await_holding_lock,
clippy::borrow_as_ptr,
clippy::branches_sharing_code,
clippy::cast_lossless,
clippy::clippy::collection_is_never_read,
clippy::cloned_instead_of_copied,
clippy::cognitive_complexity,
clippy::create_dir,
clippy::deref_by_slicing,
clippy::derivable_impls,
clippy::derive_partial_eq_without_eq,
clippy::equatable_if_let,
clippy::exhaustive_structs,
clippy::expect_used,
clippy::expl_impl_clone_on_copy,
clippy::explicit_deref_methods,
clippy::explicit_into_iter_loop,
clippy::explicit_iter_loop,
clippy::filetype_is_file,
clippy::flat_map_option,
clippy::format_push_string,
clippy::fn_params_excessive_bools,
clippy::future_not_send,
clippy::get_unwrap,
clippy::implicit_clone,
clippy::if_then_some_else_none,
clippy::impl_trait_in_params,
clippy::implicit_clone,
clippy::inefficient_to_string,
clippy::inherent_to_string,
clippy::iter_not_returning_iterator,
clippy::large_types_passed_by_value,
clippy::large_include_file,
clippy::let_and_return,
clippy::manual_assert,
clippy::manual_ok_or,
clippy::manual_split_once,
clippy::manual_let_else,
clippy::manual_string_new,
clippy::map_flatten,
clippy::map_unwrap_or,
clippy::missing_enforced_import_renames,
clippy::missing_assert_message,
clippy::missing_const_for_fn,
clippy::must_use_candidate,
clippy::mut_mut,
clippy::needless_for_each,
clippy::needless_option_as_deref,
clippy::needless_pass_by_value,
clippy::needless_collect,
clippy::needless_continue,
clippy::non_send_fields_in_send_ty,
clippy::nonstandard_macro_braces,
clippy::option_if_let_else,
clippy::option_option,
clippy::rc_mutex,
clippy::redundant_else,
clippy::same_name_method,
clippy::semicolon_if_nothing_returned,
clippy::str_to_string,
clippy::string_to_string,
clippy::too_many_lines,
clippy::trivially_copy_pass_by_ref,
clippy::trivial_regex,
clippy::try_err,
clippy::unnested_or_patterns,
clippy::unused_async,
clippy::unwrap_or_else_default,
clippy::useless_let_if_seq,
bad_style,
clashing_extern_declarations,
dead_code,
deprecated,
explicit_outlives_requirements,
improper_ctypes,
invalid_value,
missing_copy_implementations,
missing_debug_implementations,
mutable_transmutes,
no_mangle_generic_items,
non_shorthand_field_patterns,
overflowing_literals,
path_statements,
patterns_in_fns_without_body,
private_in_public,
trivial_bounds,
trivial_casts,
trivial_numeric_casts,
type_alias_bounds,
unconditional_recursion,
unreachable_pub,
unsafe_code,
unstable_features,
unused,
unused_allocation,
unused_comparisons,
unused_import_braces,
unused_parens,
unused_qualifications,
while_true,
missing_docs
)]
#![warn(clippy::exhaustive_enums)]
#![allow(unused_attributes, clippy::derive_partial_eq_without_eq, clippy::box_default)]
#![allow(missing_docs)]
mod macros;
mod operations;
use flow_component::{Component, RuntimeCallback};
use seeded_random::Seed;
use wick_interface_types::{component, ComponentSignature};
use wick_packet::{Invocation, PacketStream, RuntimeConfig};
use wick_rpc::dispatch;
#[macro_use]
extern crate tracing;
#[derive(Clone, Debug, Copy)]
#[non_exhaustive]
pub struct Context {}
#[derive(Debug)]
#[must_use]
pub struct Collection {
#[allow(unused)]
seed: Seed,
signature: ComponentSignature,
}
impl Collection {
pub fn new(seed: Seed) -> Self {
let sig = component! {
name: "wick-stdlib",
version: Some("0.1.0"),
operations: {
"core::error" => {
inputs: { "input" => "string" },
outputs: { "output" => "string" },
},
"core::log" => {
inputs: { "input" => "string" },
outputs: { "output" => "string" },
},
"core::panic" => {
inputs: { "input" => "string" },
outputs: { "output" => "string" },
},
"math::add" => {
inputs: { "left" => "u64", "right" => "u64" },
outputs: { "output" => "u64" },
},
"math::subtract" => {
inputs: { "left" => "u64", "right" => "u64" },
outputs: { "output" => "u64" },
},
"rand::bytes" => {
inputs: { "seed" => "u64", "length" => "u32" },
outputs: { "output" => "bytes" },
},
"rand::string" => {
inputs: { "seed" => "u64", "length" => "u32" },
outputs: { "output" => "string" },
},
"rand::uuid" => {
inputs: { "seed" => "u64" },
outputs: { "output" => "string" },
},
"string::concat" => {
inputs: { "left" => "string", "right" => "string" },
outputs: { "output" => "string" },
}
}
};
Self { seed, signature: sig }
}
}
impl Component for Collection {
fn handle(
&self,
invocation: Invocation,
_data: Option<RuntimeConfig>,
_callback: std::sync::Arc<RuntimeCallback>,
) -> flow_component::BoxFuture<Result<PacketStream, flow_component::ComponentError>> {
let target = invocation.target().url();
trace!("stdlib invoke: {}", target);
Box::pin(async move {
let stream = dispatch!(invocation, {
"core::error" => operations::core::error::job,
"core::log" => operations::core::log::job,
"core::panic" => operations::core::panic::job,
"math::add" => operations::math::add::job,
"math::subtract" => operations::math::subtract::job,
"rand::bytes" => operations::rand::bytes::job,
"rand::string" => operations::rand::string::job,
"rand::uuid" => operations::rand::uuid::job,
"string::concat" => operations::string::concat::job,
});
Ok(stream)
})
}
fn signature(&self) -> &ComponentSignature {
&self.signature
}
}