Add support for symlinks

This commit is contained in:
Anders F Björklund
2025-03-15 17:43:55 +01:00
parent 24a9457c6b
commit cef9090210
2 changed files with 36 additions and 2 deletions
+25 -2
View File
@@ -6,14 +6,33 @@ import (
"io/fs" "io/fs"
"os" "os"
"path/filepath" "path/filepath"
"strings"
"time" "time"
"github.com/CalebQ42/squashfs" "github.com/CalebQ42/squashfs"
) )
func printEntry(root, path string, d fs.DirEntry) {
fi, _ := d.Info()
sfi := fi.(squashfs.FileInfo)
owner := fmt.Sprintf("%d/%d",
sfi.Uid(),
sfi.Gid())
link := ""
if sfi.IsSymlink() {
link = " -> " + sfi.SymlinkPath()
}
fmt.Printf("%s %s %*d %s %s%s\n",
strings.ToLower(fi.Mode().String()),
owner, 26-len(owner), fi.Size(),
fi.ModTime().Format("2006-01-02 15:04"),
filepath.Join(root, path), link)
}
func main() { func main() {
verbose := flag.Bool("v", false, "Verbose") verbose := flag.Bool("v", false, "Verbose")
list := flag.Bool("l", false, "List") list := flag.Bool("l", false, "List")
long := flag.Bool("ll", false, "List with attributes")
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")
flag.Parse() flag.Parse()
if len(flag.Args()) < 2 { if len(flag.Args()) < 2 {
@@ -28,13 +47,17 @@ func main() {
if err != nil { if err != nil {
panic(err) panic(err)
} }
if *list { if *list || *long {
root := flag.Arg(1) root := flag.Arg(1)
fs.WalkDir(r, ".", func(path string, d fs.DirEntry, err error) error { fs.WalkDir(r, ".", func(path string, d fs.DirEntry, err error) error {
if err != nil { if err != nil {
panic(err) panic(err)
} }
fmt.Println(filepath.Join(root, path)) if *long {
printEntry(root, path, d)
} else {
fmt.Println(filepath.Join(root, path))
}
return nil return nil
}) })
return return
+11
View File
@@ -11,6 +11,7 @@ import (
type FileInfo struct { type FileInfo struct {
name string name string
size int64 size int64
target string
perm uint32 perm uint32
modTime uint32 modTime uint32
fileType uint16 fileType uint16
@@ -26,15 +27,21 @@ func (r Reader) newFileInfo(e directory.Entry) (FileInfo, error) {
func newFileInfo(name string, i *inode.Inode) FileInfo { func newFileInfo(name string, i *inode.Inode) FileInfo {
var size int64 var size int64
var target string
switch i.Type { switch i.Type {
case inode.Fil: case inode.Fil:
size = int64(i.Data.(inode.File).Size) size = int64(i.Data.(inode.File).Size)
case inode.EFil: case inode.EFil:
size = int64(i.Data.(inode.EFile).Size) size = int64(i.Data.(inode.EFile).Size)
case inode.Sym:
target = string(i.Data.(inode.Symlink).Target)
case inode.ESym:
target = string(i.Data.(inode.ESymlink).Target)
} }
return FileInfo{ return FileInfo{
name: name, name: name,
size: size, size: size,
target: target,
perm: uint32(i.Perm), perm: uint32(i.Perm),
modTime: i.ModTime, modTime: i.ModTime,
fileType: i.Type, fileType: i.Type,
@@ -49,6 +56,10 @@ func (f FileInfo) Size() int64 {
return f.size return f.size
} }
func (f FileInfo) SymlinkPath() string {
return f.target
}
func (f FileInfo) Mode() fs.FileMode { func (f FileInfo) Mode() fs.FileMode {
switch f.fileType { switch f.fileType {
case inode.Dir, inode.EDir: case inode.Dir, inode.EDir: