Files
metabuilder/workflow/plugins/go/string/string_split/string_split.go
johndoe6345789 7ce8b4ae8a refactor(workflow): convert all plugins to class/struct + factory pattern
- 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>
2026-01-22 14:53:04 +00:00

48 lines
1.1 KiB
Go

// Package string_split provides a workflow plugin for splitting strings.
package string_split
import (
"strings"
)
// StringSplit implements the NodeExecutor interface for splitting strings.
type StringSplit struct {
NodeType string
Category string
Description string
}
// NewStringSplit creates a new StringSplit instance.
func NewStringSplit() *StringSplit {
return &StringSplit{
NodeType: "string.split",
Category: "string",
Description: "Split a string by separator",
}
}
// Execute runs the plugin logic.
func (p *StringSplit) Execute(inputs map[string]interface{}, runtime interface{}) map[string]interface{} {
str, ok := inputs["string"].(string)
if !ok {
return map[string]interface{}{"result": []string{}, "error": "string is required"}
}
separator := ""
if sep, ok := inputs["separator"].(string); ok {
separator = sep
}
var result []string
if separator == "" {
// Split into characters
for _, r := range str {
result = append(result, string(r))
}
} else {
result = strings.Split(str, separator)
}
return map[string]interface{}{"result": result}
}