Adding Unzip utility Adding Download options to DOCS.md Signed-off-by: Jonas Franz <info@jonasfranz.de>development
parent
45c74000a1
commit
e5ca1a26c0
@ -0,0 +1,67 @@ |
||||
package utils |
||||
|
||||
import ( |
||||
"archive/zip" |
||||
"io" |
||||
"os" |
||||
"path/filepath" |
||||
) |
||||
|
||||
func Unzip(src, dest string) error { |
||||
r, err := zip.OpenReader(src) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
defer func() { |
||||
if err := r.Close(); err != nil { |
||||
panic(err) |
||||
} |
||||
}() |
||||
|
||||
os.MkdirAll(dest, 0755) |
||||
|
||||
// Closure to address file descriptors issue with all the deferred .Close() methods
|
||||
extractAndWriteFile := func(f *zip.File) error { |
||||
rc, err := f.Open() |
||||
if err != nil { |
||||
return err |
||||
} |
||||
defer func() { |
||||
if err := rc.Close(); err != nil { |
||||
panic(err) |
||||
} |
||||
}() |
||||
|
||||
path := filepath.Join(dest, f.Name) |
||||
|
||||
if f.FileInfo().IsDir() { |
||||
os.MkdirAll(path, f.Mode()) |
||||
} else { |
||||
os.MkdirAll(filepath.Dir(path), f.Mode()) |
||||
f, err := os.OpenFile(path, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, f.Mode()) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
defer func() { |
||||
if err := f.Close(); err != nil { |
||||
panic(err) |
||||
} |
||||
}() |
||||
|
||||
_, err = io.Copy(f, rc) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} |
||||
return nil |
||||
} |
||||
|
||||
for _, f := range r.File { |
||||
err := extractAndWriteFile(f) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
} |
||||
|
||||
return nil |
||||
} |
Loading…
Reference in new issue