diff options
author | Luke Shumaker <lukeshu@sbcglobal.net> | 2015-09-12 10:35:52 -0600 |
---|---|---|
committer | Luke Shumaker <lukeshu@sbcglobal.net> | 2015-09-12 10:35:52 -0600 |
commit | e8199ec88c7ca8107c4fb9238e383a4a9eb981ee (patch) | |
tree | 250c514c0cb4ec2b8bd442f4e80e916fb8ad6f2c /src/nslcd_proto/func_handlerequest.go.sh | |
parent | f0302e1ac1a12711a9f49c3d7a62bcdfcaca7eed (diff) |
Derp, channels and goroutines are enumerators
Diffstat (limited to 'src/nslcd_proto/func_handlerequest.go.sh')
-rwxr-xr-x | src/nslcd_proto/func_handlerequest.go.sh | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/src/nslcd_proto/func_handlerequest.go.sh b/src/nslcd_proto/func_handlerequest.go.sh index 45e0ed6..de9a6b7 100755 --- a/src/nslcd_proto/func_handlerequest.go.sh +++ b/src/nslcd_proto/func_handlerequest.go.sh @@ -9,10 +9,6 @@ import ( "io" ) -type enumerator interface { - GenericGetNext() (n *interface{}, err error) -} - func handleRequest(backend Backend, in io.Reader, out io.Writer, cred Ucred) { var version int32 read(in, &version) @@ -22,7 +18,7 @@ func handleRequest(backend Backend, in io.Reader, out io.Writer, cred Ucred) { var action int32 read(in, &action) - var res enumerator = nil + res := make(chan interface{}) switch action { $( while read -r request; do @@ -31,7 +27,15 @@ while read -r request; do var req Request_${request} read(in, &req) fmt.Printf("request: %#v\n", req) - res = backend.${request}(cred, req) + _res := backend.${request}(cred, req) + go func() { + o, ok := <-_res + if ok { + res <- o + } else { + close(res) + } + }() EOT done < "$requests" ) @@ -44,14 +48,9 @@ done < "$requests" write(out, NSLCD_VERSION) write(out, action) - var result *interface{} - var err error - for result, err = res.GenericGetNext(); (result != nil) && (err == nil); result, err = res.GenericGetNext() { + for result, ok := <-res; ok; result, ok = <-res { write(out, NSLCD_RESULT_BEGIN) - write(out, *result) - } - if err != nil { - panic(err) + write(out, result) } write(out, NSLCD_RESULT_END) } |