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
57c48adf
Commit
57c48adf
authored
Nov 18, 2014
by
Matt Bell
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
commands/http: Made MultiFileReader thread safe
parent
6681c503
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
6 additions
and
1 deletion
+6
-1
commands/http/multifilereader.go
commands/http/multifilereader.go
+6
-1
No files found.
commands/http/multifilereader.go
View file @
57c48adf
...
...
@@ -6,13 +6,13 @@ import (
"io"
"mime/multipart"
"net/textproto"
"sync"
cmds
"github.com/jbenet/go-ipfs/commands"
)
// MultiFileReader reads from a `commands.File` (which can be a directory of files
// or a regular file) as HTTP multipart encoded data.
// WARNING: Not thread-safe!
type
MultiFileReader
struct
{
io
.
Reader
...
...
@@ -21,6 +21,7 @@ type MultiFileReader struct {
buf
bytes
.
Buffer
mpWriter
*
multipart
.
Writer
closed
bool
mutex
*
sync
.
Mutex
// if true, the data will be type 'multipart/form-data'
// if false, the data will be type 'multipart/mixed'
...
...
@@ -34,6 +35,7 @@ func NewMultiFileReader(file cmds.File, form bool) *MultiFileReader {
mfr
:=
&
MultiFileReader
{
files
:
file
,
form
:
form
,
mutex
:
&
sync
.
Mutex
{},
}
mfr
.
mpWriter
=
multipart
.
NewWriter
(
&
mfr
.
buf
)
...
...
@@ -41,6 +43,9 @@ func NewMultiFileReader(file cmds.File, form bool) *MultiFileReader {
}
func
(
mfr
*
MultiFileReader
)
Read
(
buf
[]
byte
)
(
written
int
,
err
error
)
{
mfr
.
mutex
.
Lock
()
defer
mfr
.
mutex
.
Unlock
()
// if we are closed and the buffer is flushed, end reading
if
mfr
.
closed
&&
mfr
.
buf
.
Len
()
==
0
{
return
0
,
io
.
EOF
...
...
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