# TODO: Consider using numfmt instead of awk
tdu() {
du "$1" \
- | sort -n -k 1 \
- | tail -50 \
| awk '
{
size = $1
path = $0
sub("^" $1 "\t+", "", path)
- gb = size / 1024 / 1024
- printf("%f\t%s\n", gb, path)
- }'
+ paths[path] = size
+ if (size > max)
+ max = size
+ }
+
+ END {
+ for (path in paths) {
+ size = paths[path]
+ pct = 100 * (size / max)
+ gb = size / 1024 / 1024
+ printf("%6.2f %3d%% %s\n", gb, pct, path)
+ }
+ }
+ ' \
+ | sort -r -n -k 1 \
+ | head -50 \
+ | tac
+ # A slight optimization: head can exit before traversing the full input.
}
# Top Disk-Using Files
}
gh_fetch_repos() {
- curl "https://api.github.com/$1/$2/repos?page=1&per_page=10000"
+ local -r user_type="$1"
+ local -r user_name="$2"
+
+ curl "https://api.github.com/$user_type/$user_name/repos?page=1&per_page=10000"
}
gh_clone() {