Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-unixfs
Commits
31ae1780
Commit
31ae1780
authored
Jan 20, 2015
by
Matt Bell
Committed by
Jeromy
Jan 21, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
commands: Support outputting <-chan interface{}
parent
9adcfe7b
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
18 additions
and
4 deletions
+18
-4
commands/command.go
commands/command.go
+9
-0
commands/http/client.go
commands/http/client.go
+1
-1
commands/http/handler.go
commands/http/handler.go
+4
-0
commands/response.go
commands/response.go
+2
-1
core/commands/add.go
core/commands/add.go
+1
-1
core/commands/ping.go
core/commands/ping.go
+1
-1
No files found.
commands/command.go
View file @
31ae1780
...
...
@@ -125,6 +125,15 @@ func (c *Command) Call(req Request) Response {
isChan
=
actualType
.
Kind
()
==
reflect
.
Chan
}
if
isChan
{
if
ch
,
ok
:=
output
.
(
<-
chan
interface
{});
ok
{
output
=
ch
}
else
if
ch
,
ok
:=
output
.
(
chan
interface
{});
ok
{
output
=
(
<-
chan
interface
{})(
ch
)
}
}
// If the command specified an output type, ensure the actual value returned is of that type
if
cmd
.
Type
!=
nil
&&
!
isChan
{
expectedType
:=
reflect
.
TypeOf
(
cmd
.
Type
)
...
...
commands/http/client.go
View file @
31ae1780
...
...
@@ -167,7 +167,7 @@ func getResponse(httpRes *http.Response, req cmds.Request) (cmds.Response, error
}
}()
res
.
SetOutput
(
outChan
)
res
.
SetOutput
(
(
<-
chan
interface
{})(
outChan
)
)
return
res
,
nil
}
...
...
commands/http/handler.go
View file @
31ae1780
...
...
@@ -112,6 +112,10 @@ func (i Handler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
// if output is a channel and user requested streaming channels,
// use chunk copier for the output
_
,
isChan
:=
res
.
Output
()
.
(
chan
interface
{})
if
!
isChan
{
_
,
isChan
=
res
.
Output
()
.
(
<-
chan
interface
{})
}
streamChans
,
_
,
_
:=
req
.
Option
(
"stream-channels"
)
.
Bool
()
if
isChan
&&
streamChans
{
// w.WriteString(transferEncodingHeader + ": chunked\r\n")
...
...
commands/response.go
View file @
31ae1780
...
...
@@ -50,7 +50,8 @@ func marshalJson(value interface{}) (io.Reader, error) {
var
marshallers
=
map
[
EncodingType
]
Marshaler
{
JSON
:
func
(
res
Response
)
(
io
.
Reader
,
error
)
{
if
ch
,
ok
:=
res
.
Output
()
.
(
chan
interface
{});
ok
{
ch
,
ok
:=
res
.
Output
()
.
(
<-
chan
interface
{})
if
ok
{
return
&
ChannelMarshaler
{
Channel
:
ch
,
Marshaler
:
marshalJson
,
...
...
core/commands/add.go
View file @
31ae1780
...
...
@@ -72,7 +72,7 @@ remains to be implemented.
},
Marshalers
:
cmds
.
MarshalerMap
{
cmds
.
Text
:
func
(
res
cmds
.
Response
)
(
io
.
Reader
,
error
)
{
outChan
,
ok
:=
res
.
Output
()
.
(
chan
interface
{})
outChan
,
ok
:=
res
.
Output
()
.
(
<-
chan
interface
{})
if
!
ok
{
return
nil
,
u
.
ErrCast
()
}
...
...
core/commands/ping.go
View file @
31ae1780
...
...
@@ -44,7 +44,7 @@ trip latency information.
},
Marshalers
:
cmds
.
MarshalerMap
{
cmds
.
Text
:
func
(
res
cmds
.
Response
)
(
io
.
Reader
,
error
)
{
outChan
,
ok
:=
res
.
Output
()
.
(
chan
interface
{})
outChan
,
ok
:=
res
.
Output
()
.
(
<-
chan
interface
{})
if
!
ok
{
return
nil
,
u
.
ErrCast
()
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment