X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=ll-function;h=51f72ffec1a093571ffd6b139e1bfcf6e1c96b52;hb=37486f336ef8991fa7d943207cced637f0711f71;hp=415202fcc85362bf560435f0c8fc1f6508c29a33;hpb=9ac7fc349717b42342c78a006ccae62d96317322;p=small-misc-bash diff --git a/ll-function b/ll-function index 415202f..51f72ff 100644 --- a/ll-function +++ b/ll-function @@ -21,15 +21,13 @@ ll() { usage: ll [ARGS_TO_LS] ls -lA with enhanced output -octal permissions -omited acl type specifier -better hard link count: number of subdirectories or the +* octal permissions +* omited acl type specifier +* better hard link count: number of subdirectories or the number of linked files or omitted if it is 0 -better human readable size -more natural date/time format for my American raised eyes -remove first line size summary - -/bin/ls output is below: +* better human readable size +* more natural date/time format for my American raised eyes +* remove first line size summary EOF ;; @@ -84,35 +82,36 @@ EOF for index in "${!lines[@]}"; do line=${lines[index]} hardlinks=${hl[index]} - if ! [[ $line == [-dscbl][-r][-w][-xsS][-r][-w][-xsS][-r][-w][-xtT]* ]]; then + if [[ $line != [-a-zA-Z][-r][-w][-xsS][-r][-w][-xsS][-r][-w][-xtT]* ]]; then + # line we don't understand printf "%s\n" "$line" - else - perm=0 - for (( x=0; x<=8; x++ )); do - y=${line:$(( -1*x + 9 )):1} - [[ $y == [tT] ]] && perm=$(( perm + 512 )) - if [[ $y == [sS] ]]; then - [[ $x == 3 ]] && perm=$(( perm + 1024 )) - [[ $x == 6 ]] && perm=$(( perm + 2048 )) - fi - [[ $y != [-ST] ]] && perm=$(( perm + 2**x )) - done - if $aclchar; then - y="${line:11}" - else - y="${line:10}" - fi - middle=${y#*[^ ]* } - size=${middle#*[^ ]* *[^ ]* } - middle=${middle%"$size"} - tail=${size#*[^ ]* } - size=${size%"$tail"} - declare -i sizePadding="${#size} - 1" - size=( $size ) # remove spaces - size=${size/.?/} - - printf "%s%4o%${hardlink_spacing}s%s%${sizePadding}s%s\n" \ - "${line:0:1}" $perm "$hardlinks" " $middle" "$size" " $tail" + continue fi + perm=0 + for (( x=0; x<=8; x++ )); do + y=${line:$(( -1*x + 9 )):1} + [[ $y == [tT] ]] && perm=$(( perm + 512 )) + if [[ $y == [sS] ]]; then + [[ $x == 3 ]] && perm=$(( perm + 1024 )) + [[ $x == 6 ]] && perm=$(( perm + 2048 )) + fi + [[ $y != [-ST] ]] && perm=$(( perm + 2**x )) + done + if $aclchar; then + y="${line:11}" + else + y="${line:10}" + fi + middle=${y#*[^ ]* } + size=${middle#*[^ ]* *[^ ]* } + middle=${middle%"$size"} + tail=${size#*[^ ]* } + size=${size%"$tail"} + declare -i sizePadding="${#size} - 1" + size=( $size ) # remove spaces + size=${size/.?/} + + printf "%s%4o%${hardlink_spacing}s%s%${sizePadding}s%s\n" \ + "${line:0:1}" $perm "$hardlinks" " $middle" "$size" " $tail" done }