Simplify FileContentFlag.

This commit is contained in:
Alec Thomas
2018-10-25 12:53:55 -07:00
parent 119a0d115b
commit c0df056b14
2 changed files with 3 additions and 8 deletions
+2 -6
View File
@@ -474,10 +474,7 @@ func JoinEscaped(s []string, sep rune) string {
}
// FileContentFlag is a flag value that loads a file's contents into its value.
type FileContentFlag struct {
Path string
Data []byte
}
type FileContentFlag []byte
func (f *FileContentFlag) Decode(ctx *DecodeContext) error { // nolint: golint
filename := ctx.Scan.PopValue("filename")
@@ -485,7 +482,6 @@ func (f *FileContentFlag) Decode(ctx *DecodeContext) error { // nolint: golint
if err != nil {
return fmt.Errorf("failed to open %q: %s", filename, err)
}
f.Path = filename
f.Data = data
*f = data
return nil
}
+1 -2
View File
@@ -164,6 +164,5 @@ func TestFileContentFlag(t *testing.T) {
f.Close()
_, err = mustNew(t, &cli).Parse([]string{"--file", f.Name()})
require.NoError(t, err)
require.Equal(t, []byte("hello world"), cli.File.Data)
require.Equal(t, f.Name(), cli.File.Path)
require.Equal(t, []byte("hello world"), []byte(cli.File))
}