From 86bf4b98eac7f9b03cbee650ad95d13f7cda53e3 Mon Sep 17 00:00:00 2001 From: Vincent Batts Date: Fri, 27 Feb 2015 16:54:04 -0500 Subject: [PATCH] tar/asm: more interface for (dis)assembly --- tar/asm/getter.go | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/tar/asm/getter.go b/tar/asm/getter.go index c875d94..372aea2 100644 --- a/tar/asm/getter.go +++ b/tar/asm/getter.go @@ -11,6 +11,16 @@ type FileGetter interface { Get(string) (io.ReadCloser, error) } +type FilePutter interface { + // Put returns a stream for the provided file path + Put(string, io.Writer) error +} + +type FileGetPutter interface { + FileGetter + FilePutter +} + // NewPathFileGetter returns a FileGetter that is for files relative to path relpath. func NewPathFileGetter(relpath string) FileGetter { return &pathFileGetter{root: relpath} @@ -24,3 +34,22 @@ func (pfg pathFileGetter) Get(filename string) (io.ReadCloser, error) { // FIXME might should have a check for '../../../../etc/passwd' attempts? return os.Open(path.Join(pfg.root, filename)) } + +type bufferFileGetPutter struct { + files map[string][]byte +} + +func (bfgp bufferFileGetPutter) Get(name string) (io.ReadCloser, error) { + +} + +type writeCloserWrapper struct { + io.Writer + closer func() error +} + +func (w *nopWriteCloser) Close() error { return nil } + +func NewBufferFileGetPutter() FileGetPutter { + return &bufferFileGetPutter{} +}