Added OpenFile to get a *squashfs.File instead of fs.File
Added -e to extract only specific files/folders Only require the filename for -l, -ll, and -lln
This commit is contained in:
@@ -36,7 +36,7 @@ func groupName(gid int, numeric bool) string {
|
|||||||
return gs
|
return gs
|
||||||
}
|
}
|
||||||
|
|
||||||
func printEntry(root, path string, d fs.DirEntry, numeric bool) {
|
func printEntry(path string, d fs.DirEntry, numeric bool) {
|
||||||
fi, _ := d.Info()
|
fi, _ := d.Info()
|
||||||
sfi := fi.(squashfs.FileInfo)
|
sfi := fi.(squashfs.FileInfo)
|
||||||
owner := fmt.Sprintf("%s/%s",
|
owner := fmt.Sprintf("%s/%s",
|
||||||
@@ -50,7 +50,7 @@ func printEntry(root, path string, d fs.DirEntry, numeric bool) {
|
|||||||
strings.ToLower(fi.Mode().String()),
|
strings.ToLower(fi.Mode().String()),
|
||||||
owner, 26-len(owner), fi.Size(),
|
owner, 26-len(owner), fi.Size(),
|
||||||
fi.ModTime().Format("2006-01-02 15:04"),
|
fi.ModTime().Format("2006-01-02 15:04"),
|
||||||
filepath.Join(root, path), link)
|
filepath.Join(path), link)
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@@ -60,8 +60,12 @@ func main() {
|
|||||||
numeric := flag.Bool("lln", false, "List with attributes and numeric ids")
|
numeric := flag.Bool("lln", false, "List with attributes and numeric ids")
|
||||||
offset := flag.Int64("o", 0, "Offset")
|
offset := flag.Int64("o", 0, "Offset")
|
||||||
ignore := flag.Bool("ip", false, "Ignore Permissions and extract all files/folders with 0755")
|
ignore := flag.Bool("ip", false, "Ignore Permissions and extract all files/folders with 0755")
|
||||||
|
file := flag.String("e", "", "File or folder to extract")
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
if len(flag.Args()) < 2 {
|
if (*list || *long || *numeric) && flag.NArg() < 1 {
|
||||||
|
fmt.Println("Please provide a file name")
|
||||||
|
os.Exit(0)
|
||||||
|
} else if (!*list && !*long && !*numeric) && flag.NArg() < 2 {
|
||||||
fmt.Println("Please provide a file name and extraction path")
|
fmt.Println("Please provide a file name and extraction path")
|
||||||
os.Exit(0)
|
os.Exit(0)
|
||||||
}
|
}
|
||||||
@@ -73,26 +77,42 @@ func main() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
extractFil := r.File()
|
||||||
|
if *file != "" {
|
||||||
|
extractFil, err = r.OpenFile(*file)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
if *list || *long || *numeric {
|
if *list || *long || *numeric {
|
||||||
root := flag.Arg(1)
|
if extractFil.IsDir() {
|
||||||
fs.WalkDir(r, ".", func(path string, d fs.DirEntry, err error) error {
|
var filFs squashfs.FS
|
||||||
|
filFs, err = extractFil.FS()
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
err = fs.WalkDir(filFs, ".", func(path string, d fs.DirEntry, err error) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
if *long || *numeric {
|
if *long || *numeric {
|
||||||
printEntry(root, path, d, *numeric)
|
printEntry(path, d, *numeric)
|
||||||
} else {
|
} else {
|
||||||
fmt.Println(filepath.Join(root, path))
|
fmt.Println(filepath.Clean(path))
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
op := squashfs.DefaultOptions()
|
op := squashfs.DefaultOptions()
|
||||||
op.Verbose = *verbose
|
op.Verbose = *verbose
|
||||||
op.IgnorePerm = *ignore
|
op.IgnorePerm = *ignore
|
||||||
n := time.Now()
|
n := time.Now()
|
||||||
err = r.ExtractWithOptions(flag.Arg(1), op)
|
err = extractFil.ExtractWithOptions(flag.Arg(1), op)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -91,6 +91,10 @@ func (f *FS) Glob(pattern string) (out []string, err error) {
|
|||||||
|
|
||||||
// Opens the file at name. Returns a *File as an fs.File.
|
// Opens the file at name. Returns a *File as an fs.File.
|
||||||
func (f FS) Open(name string) (fs.File, error) {
|
func (f FS) Open(name string) (fs.File, error) {
|
||||||
|
return f.OpenFile(name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f FS) OpenFile(name string) (*File, error) {
|
||||||
name = filepath.Clean(name)
|
name = filepath.Clean(name)
|
||||||
if !fs.ValidPath(name) {
|
if !fs.ValidPath(name) {
|
||||||
return nil, &fs.PathError{
|
return nil, &fs.PathError{
|
||||||
@@ -111,7 +115,7 @@ func (f FS) Open(name string) (fs.File, error) {
|
|||||||
Err: fs.ErrNotExist,
|
Err: fs.ErrNotExist,
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return f.parent.Open(strings.Join(split[1:], "/"))
|
return f.parent.OpenFile(strings.Join(split[1:], "/"))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i, found := slices.BinarySearchFunc(f.d.Entries, split[0], func(e directory.Entry, name string) int {
|
i, found := slices.BinarySearchFunc(f.d.Entries, split[0], func(e directory.Entry, name string) int {
|
||||||
@@ -146,7 +150,7 @@ func (f FS) Open(name string) (fs.File, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return f.r.FSFromDirectory(d, f).Open(strings.Join(split[1:], "/"))
|
return f.r.FSFromDirectory(d, f).OpenFile(strings.Join(split[1:], "/"))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns all DirEntry's for the directory at name.
|
// Returns all DirEntry's for the directory at name.
|
||||||
|
|||||||
Reference in New Issue
Block a user