bb/tool/ls/ls.go

180 lines
2.8 KiB
Go
Raw Normal View History

2020-03-08 03:24:41 +03:00
package ls
import(
"os"
"fmt"
"strings"
"regexp"
2020-11-25 02:00:35 +03:00
"path"
2024-05-15 21:07:35 +03:00
"surdeus.su/core/cli/mtool"
2020-11-25 02:00:35 +03:00
)
var(
listHidden bool
args []string
2020-03-08 03:24:41 +03:00
)
var slashRegexp = regexp.MustCompile("/+")
2020-03-08 03:24:41 +03:00
func IsDir(p string) (bool, error) {
finfo, e := os.Stat(p)
if e != nil {
return false, e
}
return finfo.IsDir(), e
}
func ReadDir(p string) ([]os.FileInfo, error) {
f, e := os.Open(p)
if e != nil {
return nil, e
}
l, e := f.Readdir(-1)
if e != nil {
return nil, e
}
f.Close()
return l, nil
}
func
Stat(p string) (os.FileInfo, error) {
2020-03-08 03:24:41 +03:00
f, e := os.Open(p)
if e != nil {
return nil, e
}
s, e := f.Stat()
f.Close()
return s, nil
}
func findString(slice []string, val string) (int, bool) {
for i, v := range slice {
if v == val {
return i, true
}
}
return -1, false
}
func
isHidden(p string) bool {
if path.Base(p)[0] == '.' {
return true
}
return false
}
2020-11-25 02:00:35 +03:00
func shouldList(p string) bool {
if _, found := findString(args, p) ; found {
return true
}
if !listHidden && isHidden(p) {
2020-11-25 02:00:35 +03:00
return false
}
return true
}
func
deleteExceedSlashes(p string) string {
p = slashRegexp.ReplaceAllString(p, "/")
if p != "/" { // Do not trim if it is root dir.
p = strings.TrimRight(p, "/")
}
return p
}
func
ls(p string, fold int) error {
2020-11-25 02:00:35 +03:00
if !shouldList(p) {
return nil
}
p = deleteExceedSlashes(p)
2020-03-08 03:24:41 +03:00
isDir, e := IsDir(p)
if e != nil {
return e
}
if !isDir {
fmt.Println(p)
return nil
}
if fold>0 {
/* It's a directory and it can be ls-ed. */
l, e := ReadDir(p)
2020-04-23 10:41:19 +03:00
if e!=nil {
2020-03-08 03:24:41 +03:00
return e
}
for _, f := range l {
s := p+"/"+f.Name()
if b, _ := IsDir(s) ; b && fold!=1 {
fmt.Println(s)
2020-04-23 10:41:19 +03:00
}
ls(s, fold-1)
2020-03-08 03:24:41 +03:00
}
} else {
/* It's finish directory. Fold==0 or fold<0. */
fmt.Println(p)
2020-03-08 03:24:41 +03:00
}
2020-04-23 10:41:19 +03:00
2020-03-08 03:24:41 +03:00
return nil
}
2023-03-24 16:54:51 +03:00
func Run(flagSet *mtool.Flags) {
var foldLvl int
2024-01-24 20:34:01 +03:00
var rFlag bool
flagSet.BoolVar(&rFlag, "R", false, "set the '-r' flags value to the max depth (overrides the '-r')")
flagSet.IntVar(&foldLvl, "r", 1, "list recursively with choosing deepness, can't be negative or zero.")
flagSet.BoolVar(&listHidden, "a", false, "list hidden files.")
2023-03-24 16:54:51 +03:00
flagSet.Parse()
args = flagSet.Args()
2024-01-24 20:34:01 +03:00
if rFlag {
foldLvl = 9999999
}
if foldLvl<0 {
2020-04-01 22:25:52 +03:00
flagSet.Usage()
2024-01-24 20:34:01 +03:00
os.Exit(1)
2020-04-01 22:25:52 +03:00
}
if foldLvl==0 && len(args)==0 {
2020-04-01 22:25:52 +03:00
flagSet.Usage()
2024-01-24 20:34:01 +03:00
os.Exit(1)
2020-04-01 22:25:52 +03:00
}
2020-03-08 03:24:41 +03:00
if len(args) == 0 {
foldLvl -= 1
if l, e := ReadDir(".") ; e != nil {
2023-03-24 16:54:51 +03:00
fmt.Fprintf(os.Stderr, "%s.\n", e)
2020-03-08 03:24:41 +03:00
} else {
for _, f := range l {
2020-11-25 02:00:35 +03:00
if !shouldList(f.Name()) {
continue
}
isDir, _ := IsDir(f.Name())
fmt.Println(f.Name())
if isDir && foldLvl>0 {
e := ls(f.Name(), foldLvl)
if e!=nil {
fmt.Fprintf(os.Stderr,
2023-03-24 16:54:51 +03:00
"%s\n", e)
}
}
2020-03-08 03:24:41 +03:00
}
}
} else {
for _, p := range args {
e := ls(p, foldLvl)
if e != nil {
2023-03-24 16:54:51 +03:00
fmt.Fprintf(os.Stderr, "%s\n", e)
2020-03-08 03:24:41 +03:00
}
}
}
}