Files
metabuilder/workflow/plugins/go/string/string_concat.go
T
git 48135c81e6 feat: Propagate workflow plugins to Go, Rust, C++, and Mojo
Multi-language workflow plugin system following Python's structure:
- Each plugin in its own directory with implementation + package.json
- Category-level package.json manifests listing all plugins
- Consistent interface: run(runtime, inputs) -> outputs

Languages added:
- Go: math, string, logic, list, dict, var, convert (25+ plugins)
- Rust: math, string, logic, list, convert, var (50+ functions)
- C++: header-only math, string, logic, var, convert (30+ plugins)
- Mojo: math, string, list with systems programming features

Python structure fixed:
- Reorganized flat files into plugin subdirectories
- Added package.json metadata to all 120+ plugins
- Added missing backend category (15 plugins)
- Category manifests with plugin lists

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-21 18:42:14 +00:00

30 lines
745 B
Go

// Package string provides string manipulation workflow plugins.
package string
import (
"fmt"
"strings"
plugin "metabuilder/workflow/plugins/go"
)
// Concat concatenates multiple strings with optional separator.
func Concat(runtime *plugin.Runtime, inputs map[string]interface{}) (map[string]interface{}, error) {
strs, ok := inputs["strings"].([]interface{})
if !ok {
return map[string]interface{}{"result": "", "error": "strings must be an array"}, nil
}
separator := ""
if sep, ok := inputs["separator"].(string); ok {
separator = sep
}
strList := make([]string, len(strs))
for i, s := range strs {
strList[i] = fmt.Sprintf("%v", s)
}
return map[string]interface{}{"result": strings.Join(strList, separator)}, nil
}