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
a9d784cb
Commit
a9d784cb
authored
Nov 17, 2014
by
Matt Bell
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
commands: Documented File and implementations
parent
bfdf7951
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
20 additions
and
0 deletions
+20
-0
commands/file.go
commands/file.go
+20
-0
No files found.
commands/file.go
View file @
a9d784cb
...
@@ -20,13 +20,28 @@ var (
...
@@ -20,13 +20,28 @@ var (
ErrNotReader
=
errors
.
New
(
"This file is a directory, can't use Reader functions"
)
ErrNotReader
=
errors
.
New
(
"This file is a directory, can't use Reader functions"
)
)
)
// File is an interface that provides functionality for handling files/directories
// as values that can be supplied to commands. For directories, child files are
// accessed serially by calling `NextFile()`.
type
File
interface
{
type
File
interface
{
// Files implement ReadCloser, but can only be read from or closed if they are not directories
io
.
ReadCloser
io
.
ReadCloser
// FileName returns a full filename path associated with this file
FileName
()
string
FileName
()
string
// IsDirectory returns true if the File is a directory (and therefore supports calling `NextFile`)
// and false if the File is a normal file (and therefor supports calling `Read` and `Close`)
IsDirectory
()
bool
IsDirectory
()
bool
// NextFile returns the next child file available (if the File is a directory).
// It will return (nil, io.EOF) if no more files are available.
// If the file is a regular file (not a directory), NextFile will return a non-nil error.
NextFile
()
(
File
,
error
)
NextFile
()
(
File
,
error
)
}
}
// MultipartFile implements File, and is created from a `multipart.Part`.
// It can be either a directory or file (checked by calling `IsDirectory()`).
type
MultipartFile
struct
{
type
MultipartFile
struct
{
File
File
...
@@ -96,6 +111,9 @@ func (f *MultipartFile) Close() error {
...
@@ -96,6 +111,9 @@ func (f *MultipartFile) Close() error {
return
f
.
Part
.
Close
()
return
f
.
Part
.
Close
()
}
}
// SliceFile implements File, and provides simple directory handling.
// It contains children files, and is created from a `[]File`.
// SliceFiles are always directories, and can't be read from or closed.
type
SliceFile
struct
{
type
SliceFile
struct
{
Filename
string
Filename
string
Files
[]
File
Files
[]
File
...
@@ -126,6 +144,8 @@ func (f *SliceFile) Close() error {
...
@@ -126,6 +144,8 @@ func (f *SliceFile) Close() error {
return
ErrNotReader
return
ErrNotReader
}
}
// ReaderFile is a implementation of File created from an `io.Reader`.
// ReaderFiles are never directories, and can be read from and closed.
type
ReaderFile
struct
{
type
ReaderFile
struct
{
Filename
string
Filename
string
Reader
io
.
Reader
Reader
io
.
Reader
...
...
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