mirror of
https://github.com/johndoe6345789/metabuilder.git
synced 2026-05-01 17:24:57 +00:00
- Python: class extending NodeExecutor + factory.py (80+ plugins) - TypeScript: class implements NodeExecutor + factory.ts (7 groups, 116 classes) - Go: struct with methods + factory.go (36 plugins) - Rust: struct impl NodeExecutor trait + factory.rs (54 plugins) - Mojo: struct + factory.mojo (11 plugins) All package.json files now include: - files array listing source files - metadata.class/struct field - metadata.entrypoint field This enables a unified plugin loading system across all languages with no import side effects (Spring-style DI pattern). Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
99 lines
2.7 KiB
Rust
99 lines
2.7 KiB
Rust
//! Workflow plugin: clear all variables.
|
|
|
|
use serde_json::Value;
|
|
use std::any::Any;
|
|
use std::collections::HashMap;
|
|
|
|
/// Trait for workflow node executors.
|
|
pub trait NodeExecutor {
|
|
/// Execute the node with given inputs and optional runtime context.
|
|
fn execute(&self, inputs: HashMap<String, Value>, runtime: Option<&dyn Any>) -> HashMap<String, Value>;
|
|
}
|
|
|
|
/// VarClear implements the NodeExecutor trait for clearing all variables.
|
|
pub struct VarClear {
|
|
pub node_type: &'static str,
|
|
pub category: &'static str,
|
|
pub description: &'static str,
|
|
}
|
|
|
|
impl VarClear {
|
|
/// Creates a new VarClear instance.
|
|
pub fn new() -> Self {
|
|
Self {
|
|
node_type: "var.clear",
|
|
category: "var",
|
|
description: "Clear all variables from workflow store",
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Default for VarClear {
|
|
fn default() -> Self {
|
|
Self::new()
|
|
}
|
|
}
|
|
|
|
impl NodeExecutor for VarClear {
|
|
fn execute(&self, _inputs: HashMap<String, Value>, runtime: Option<&dyn Any>) -> HashMap<String, Value> {
|
|
// Count variables before clearing (actual clearing handled by executor)
|
|
let count = if let Some(rt) = runtime {
|
|
if let Some(store) = rt.downcast_ref::<HashMap<String, Value>>() {
|
|
store.len()
|
|
} else {
|
|
0
|
|
}
|
|
} else {
|
|
0
|
|
};
|
|
|
|
let mut output = HashMap::new();
|
|
output.insert("success".to_string(), serde_json::json!(true));
|
|
output.insert("cleared".to_string(), serde_json::json!(count));
|
|
output
|
|
}
|
|
}
|
|
|
|
/// Creates a new VarClear instance.
|
|
pub fn create() -> VarClear {
|
|
VarClear::new()
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::*;
|
|
|
|
#[test]
|
|
fn test_clear() {
|
|
let executor = VarClear::new();
|
|
let mut store: HashMap<String, Value> = HashMap::new();
|
|
store.insert("foo".to_string(), serde_json::json!("bar"));
|
|
store.insert("baz".to_string(), serde_json::json!("qux"));
|
|
|
|
let inputs = HashMap::new();
|
|
let result = executor.execute(inputs, Some(&store));
|
|
|
|
assert_eq!(result.get("success"), Some(&serde_json::json!(true)));
|
|
assert_eq!(result.get("cleared"), Some(&serde_json::json!(2)));
|
|
}
|
|
|
|
#[test]
|
|
fn test_clear_empty() {
|
|
let executor = VarClear::new();
|
|
let store: HashMap<String, Value> = HashMap::new();
|
|
|
|
let inputs = HashMap::new();
|
|
let result = executor.execute(inputs, Some(&store));
|
|
|
|
assert_eq!(result.get("success"), Some(&serde_json::json!(true)));
|
|
assert_eq!(result.get("cleared"), Some(&serde_json::json!(0)));
|
|
}
|
|
|
|
#[test]
|
|
fn test_factory() {
|
|
let executor = create();
|
|
assert_eq!(executor.node_type, "var.clear");
|
|
assert_eq!(executor.category, "var");
|
|
}
|
|
}
|