Compare commits
No commits in common. "master" and "v1.2.0" have entirely different histories.
4 changed files with 6 additions and 21 deletions
2
.gitattributes
vendored
2
.gitattributes
vendored
|
@ -1,2 +0,0 @@
|
|||
tests/index.html -linguist-detectable
|
||||
tests/index.html linguist-vendored
|
|
@ -1,8 +1,7 @@
|
|||
# jsStreams
|
||||
|
||||
Go library to communicate with the JS Stream API by bridging the JS ReadableStream and WritableStream objects to a Go io.ReaderCloser and io.WriterCloser.
|
||||
It also works vice versa, and with pipe readers/writers.
|
||||
Go library to communicate with the JS Stream API by bridging the JS ReadableStream object to a Go io.ReaderCloser.
|
||||
|
||||
[](https://goreportcard.com/report/git.ailur.dev/ailur/jsStreams) [](https://pkg.go.dev/git.ailur.dev/ailur/jsStreams)
|
||||
|
||||
The API is pretty self-explanatory, see the Go Reference badge above for the full documentation.
|
||||
The API is pretty self-explanatory - it provides a function to create an io.ReaderCloser from a JS ReadableStream object.
|
12
main.go
12
main.go
|
@ -67,10 +67,8 @@ func (r *ReadableStream) Close() (err error) {
|
|||
defer func() {
|
||||
// We don't want any errors to be thrown if the stream is already closed.
|
||||
recovery := recover()
|
||||
if !strings.Contains(fmt.Sprint(recovery), "Can not close stream after closing or error") {
|
||||
if recovery != nil {
|
||||
err = fmt.Errorf("panic: %v", recovery)
|
||||
}
|
||||
if !strings.Contains(recovery.(string), "Can not close stream after closing or error") {
|
||||
err = fmt.Errorf("panic: %v", recovery)
|
||||
}
|
||||
}()
|
||||
|
||||
|
@ -143,10 +141,8 @@ func (w *WritableStream) Close() (err error) {
|
|||
defer func() {
|
||||
// We don't want any errors to be thrown if the stream is already closed.
|
||||
recovery := recover()
|
||||
if !strings.Contains(fmt.Sprint(recovery), "Can not close stream after closing or error") {
|
||||
if recovery != nil {
|
||||
err = fmt.Errorf("panic: %v", recovery)
|
||||
}
|
||||
if !strings.Contains(recovery.(string), "Can not close stream after closing or error") {
|
||||
err = fmt.Errorf("panic: %v", recovery)
|
||||
}
|
||||
}()
|
||||
|
||||
|
|
|
@ -21,10 +21,6 @@ func main() {
|
|||
return
|
||||
}
|
||||
fmt.Println(string(buffer))
|
||||
err = readStream.Close()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
}()
|
||||
|
||||
return nil
|
||||
|
@ -38,10 +34,6 @@ func main() {
|
|||
fmt.Println(err)
|
||||
return
|
||||
}
|
||||
err = writeStream.Close()
|
||||
if err != nil {
|
||||
fmt.Println(err)
|
||||
}
|
||||
}()
|
||||
|
||||
return nil
|
||||
|
|
Loading…
Add table
Reference in a new issue