Copyright (C) 2019 Thomas W. Young, [email protected]
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file or its derivitaves except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
StreamWork - a flow based program(FBP) Go language 'backend' framework.
StreamWork is a proof-of-concept for a Go language flow-based system which will be able to read and execute a network definition consisting of Go processes and links passing information packets(IPs) between them. The IPs are designed as nil(empty) interfaces to be filled by the source components.
The backend provided here has a minimal set of components, but enough to create, test, and benchmark working programs.
The frontend(to be developed) will process the network definition.
Everything here(including the project name) is subject to change, until after the frontend has been developed. Versions will be backward compatible within the same major version. Ex. your code depending on v0.0.1 will still work on v0.8.7, but may fail on v1.0.0. Streamwork is developed using the Go module facility, so that dependencies are clear.
Contributors are encouraged. Comments are particularly welcome.
Please do not submit code before contacting the project by e-mailing [email protected].
Components are designed to be reentrant with a common interface. The same component may be invoked any number of times, but with a different, unique, process name each time. Component memory will be reused. Go creates a small stack for each process.
The current list of components include
1. Gen1(Generates N IPs),
2. Print1(sends input to the terminal),
3. Split(sends input to N output channels),
4. Concat(sends N inputs in order to its
output channel)
5. Collate(compares IPs from channels 0 and 1,
sends matches to channels 2 and 3 respectively,
and mismatches to channels 4 and 5 respectively.
Note that channels 2 and 3 may actually and usefully be the same channel.
Other combinations would not be so useful.
Each process runs as a separate goroutine, which may well invoke more goroutines.
In such cases, the component is responsible for waiting until all its goroutines are
finished, before returning.
* Download and install Go [v1.11.0 or better is best. 1.9.7 and up should also work.
Previous versions will need to run under $GOPATH/src without module/version support].
* Create a new directory in $GOPATH/mod.
* Change directory to $GOPATH/mod/foo.
* Create $GOPATH/mod/foo/main.go:
package main
import "fmt"
import "sync"
import "github.com/tyoung3/streamwork"
import "github.com/tyoung3/streamwork/strings"
func main() {
var cs []chan interface{}
var wg sync.WaitGroup
fmt.Println("foo Start")
cs = append(cs, make(chan interface{}))
fbp.Launch(&wg, []string{"TestPrint1"}, strings.Print1, cs)
fbp.Launch(&wg, []string{"TestGen1","11"}, strings.Gen1, cs)
wg.Wait()
fmt.Println("foo end")
}
* Run 'go mod init foo/foo'
This should create .../mod/foo/go.mod
* Run 'go run main.go'
Go should find and install
"github.com/tyoung3/streamwork/strings latest";
creating .../mod/foo/go.sum,
and compile and run the program, Foo.
* Run 'go build' to create the executable, foo (or foo.exe).
* Streamwork will eventually be able to interpret and run a program
generated from a network definition text file.
No other project seems to do this, so far.
* Streamwork defines a standard component
interface(currently subject to change), such that each
process knows its name; very useful for reporting errors, etc..
* Streamwork uses precompiled code(unless the source is changed or
recently imported). Compilation, when it is required, is
transparent unless errors occur.
Tom Young, [email protected]