-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path.functions
191 lines (165 loc) · 5.19 KB
/
.functions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
#!/bin/bash
# This line imports an OS specific functions file if one exists
# Not been tested on any OS other than Mac OSX
# TODO: find a better way than uname to distinguish between linux distros
[ -f ".functions.$( uname )" ] && source ".functions.$( uname )"
# Create a new directory and enter it
mkd() {
mkdir -p "$@"
cd "$@" || exit
}
# Make a temporary directory and enter it
tmpd() {
local dir
if [ $# -eq 0 ]; then
dir=$(mktemp -d)
else
dir=$(mktemp -d -t "${1}.XXXXXXXXXX")
fi
cd "$dir" || exit
}
# Create a .tar.gz archive, using `zopfli`, `pigz` or `gzip` for compression
targz() {
local tmpFile="${1%/}.tar"
tar -cvf "${tmpFile}" --exclude=".DS_Store" "${1}" || return 1
size=$(
stat -f"%z" "${tmpFile}" 2> /dev/null; # OS X `stat`
stat -c"%s" "${tmpFile}" 2> /dev/null # GNU `stat`
)
local cmd=""
if (( size < 52428800 )) && hash zopfli 2> /dev/null; then
# the .tar file is smaller than 50 MB and Zopfli is available; use it
cmd="zopfli"
else
if hash pigz 2> /dev/null; then
cmd="pigz"
else
cmd="gzip"
fi
fi
echo "Compressing .tar using \`${cmd}\`…"
"${cmd}" -v "${tmpFile}" || return 1
[ -f "${tmpFile}" ] && rm "${tmpFile}"
echo "${tmpFile}.gz created successfully."
}
# Determine size of a file or total size of a directory
fs() {
if du -b /dev/null > /dev/null 2>&1; then
local arg=-sbh
else
local arg=-sh
fi
# shellcheck disable=SC2199
if [[ -n "$@" ]]; then
du $arg -- "$@"
else
du $arg -- .[^.]* *
fi
}
# Use Git’s colored diff when available
if hash git &>/dev/null ; then
diff() {
git diff --no-index --color-words "$@"
}
fi
# Start an HTTP server from a directory, optionally specifying the port
server() {
local port="${1:-8000}"
sleep 1 && open "http://localhost:${port}/" &
# Set the default Content-Type to `text/plain` instead of `application/octet-stream`
# And serve everything as UTF-8 (although not technically correct, this doesn’t break anything for binary files)
python -c $'import SimpleHTTPServer;\nmap = SimpleHTTPServer.SimpleHTTPRequestHandler.extensions_map;\nmap[""] = "text/plain";\nfor key, value in map.items():\n\tmap[key] = value + ";charset=UTF-8";\nSimpleHTTPServer.test();' "$port"
}
# Compare original and gzipped file size
gz() {
local origsize
origsize=$(wc -c < "$1")
local gzipsize
gzipsize=$(gzip -c "$1" | wc -c)
local ratio
ratio=$(echo "$gzipsize * 100 / $origsize" | bc -l)
printf "orig: %d bytes\\n" "$origsize"
printf "gzip: %d bytes (%2.2f%%)\\n" "$gzipsize" "$ratio"
}
# Syntax-highlight JSON strings or files
# Usage: `json '{"foo":42}'` or `echo '{"foo":42}' | json`
json() {
if [ -t 0 ]; then # argument
python -mjson.tool <<< "$*" | pygmentize -l javascript
else # pipe
python -mjson.tool | pygmentize -l javascript
fi
}
# UTF-8-encode a string of Unicode symbols
escape() {
local args
mapfile -t args < <(printf "%s" "$*" | xxd -p -c1 -u)
printf "\\\\x%s" "${args[@]}"
# print a newline unless we’re piping the output to another program
if [ -t 1 ]; then
echo ""; # newline
fi
}
# Decode \x{ABCD}-style Unicode escape sequences
unidecode() {
perl -e "binmode(STDOUT, ':utf8'); print \"$*\""
# print a newline unless we’re piping the output to another program
if [ -t 1 ]; then
echo ""; # newline
fi
}
# Get a character’s Unicode code point
codepoint() {
perl -e "use utf8; print sprintf('U+%04X', ord(\"$*\"))"
# print a newline unless we’re piping the output to another program
if [ -t 1 ]; then
echo ""; # newline
fi
}
# Get colors in manual pages
man() {
env \
LESS_TERMCAP_mb="$(printf '\e[1;31m')" \
LESS_TERMCAP_md="$(printf '\e[1;31m')" \
LESS_TERMCAP_me="$(printf '\e[0m')" \
LESS_TERMCAP_se="$(printf '\e[0m')" \
LESS_TERMCAP_so="$(printf '\e[1;44;33m')" \
LESS_TERMCAP_ue="$(printf '\e[0m')" \
LESS_TERMCAP_us="$(printf '\e[1;32m')" \
man "$@"
}
# Use feh to nicely view images
openimage() {
local types='*.jpg *.JPG *.png *.PNG *.gif *.GIF *.jpeg *.JPEG'
cd "$(dirname "$1")" || exit
local file
file=$(basename "$1")
feh -q "$types" --auto-zoom \
--sort filename --borderless \
--scale-down --draw-filename \
--image-bg black \
--start-at "$file"
}
# Create a new project and cd into it, does NOT check if project already exists
project () {
# TODO : redirect io to /dev/null and write custom messages
if [ $# -lt 1 ] ; then
cd "$PATH_TO_PROJECTS" && echo 'In Projects'
fi
mkdir -p "$PATH_TO_PROJECTS/$1" && cd "$PATH_TO_PROJECTS/$1"
echo "In project $1"
}
dclean() {
processes=`docker ps -q -f status=exited`
if [ -n "$processes" ]; then
docker rm $processes
fi
images=`docker images -q -f dangling=true`
if [ -n "$images" ]; then
docker rmi $images
fi
}
# This should be the last line of the file
# For local changes
# Don't make edits below this
[ -f ".functions.local" ] && source ".functions.local"