14 Commits
1.0 ... 1.1

Author SHA1 Message Date
fbt
b8640997ee merge 2015-02-20 11:24:00 +03:00
fbt
b0d56bc0ea argv 2015-02-20 11:23:26 +03:00
fbt
f940ec6905 Redundant quoting 2015-02-10 16:58:36 +03:00
fbt
85cf56afc5 Use printf instead of echo. exclude was unused. 2015-02-10 16:54:55 +03:00
fbt
795078cb2b use declare instead of local 2015-02-10 16:51:20 +03:00
fbt
30ff0776d6 $# 2015-02-10 16:50:10 +03:00
fbt
d0c5fdfcae resolve a conflict 2015-02-10 16:47:11 +03:00
fbt
71f6a3e256 Better argument handling; cleanup 2015-02-10 16:45:15 +03:00
fbt
9695ac5418 Fail if no file is available 2015-02-01 17:34:26 +03:00
fbt
909fc31f46 new argument parser 2015-02-01 17:33:10 +03:00
fbt
fcb4c6bdb0 Code cleanup, thx to http://www.shellcheck.net 2015-01-17 16:44:04 +03:00
fbt
94a38ffd73 curl options fix 2014-11-12 18:30:23 +03:00
fbt
03d29593f5 which is not a builtin 2014-10-20 11:50:10 +04:00
fbt
a1f8c5b55f license 2014-10-16 13:27:28 +04:00
2 changed files with 60 additions and 41 deletions

View File

@@ -1,4 +1,4 @@
Copyright (c) 2014, Jack L. Frost <fbt@fleshless.org> Copyright (c) 2012-2014, Jack L. Frost <fbt@fleshless.org>
Permission to use, copy, modify, and/or distribute this software for any purpose with or without Permission to use, copy, modify, and/or distribute this software for any purpose with or without

99
sup
View File

@@ -4,18 +4,20 @@
# About: # About:
# A simple upload script for ZFH (http://zerofiles.org) # A simple upload script for ZFH (http://zerofiles.org)
_self="${0##*/}"
cfg_url_regex='^[A-Za-z]([A-Za-z0-9+.-]+)?://.+' cfg_url_regex='^[A-Za-z]([A-Za-z0-9+.-]+)?://.+'
cfg_tmp_dir="/tmp/$USER/sup"; TEMPDIR="$cfg_tmp_dir" cfg_tmp_dir="/tmp/$USER/sup"; TEMPDIR="$cfg_tmp_dir"
cfg_script_url='https://zfh.so/upload' cfg_script_url='https://zfh.so/upload'
cfg_screenshot_ext='png' cfg_screenshot_ext='png'
[[ -f $HOME/.suprc ]] && { source $HOME/.suprc; } [[ -f $HOME/.suprc ]] && { source "$HOME/.suprc"; }
sup.msg() { echo "[sup] $1"; } sup.msg() { printf '%s\n' "[sup] $1"; }
sup.err() { sup.msg "(error) $1" >&2; } sup.err() { sup.msg "(error) $1" >&2; }
sup.usage() { sup.usage() {
echo "Usage: `basename $0` [-RsF] [-D num] [file/url]" printf '%s\n' "Usage: ${_self} [-RsF] [-D num] [file/url]"
} }
sup.env() { sup.env() {
@@ -32,7 +34,7 @@ sup.upload() {
-F submit="" \ -F submit="" \
"$cfg_script_url" -sL -A 'zerofiles.org upload script' || { return 1; } "$cfg_script_url" -sL -A 'zerofiles.org upload script' || { return 1; }
[[ "$flag_rm" ]] && { rm "$file"; } (( "$flag_rm" )) && { rm "$file"; }
return 0 return 0
} }
@@ -43,19 +45,19 @@ sup.mktemp() {
return 1 return 1
} }
echo "$1" printf '%s\n' "$1"
} }
sup.scrot() { sup.scrot() {
local tmp_file declare tmp_file
[[ "$scrot_exec" ]] || { scrot_exec=`which scrot`; } [[ "$scrot_exec" ]] || { scrot_exec=$(type -P scrot); }
[[ "$scrot_exec" ]] || { [[ "$scrot_exec" ]] || {
sup.err "Please install scrot to use this function" sup.err "Please install scrot to use this function"
return 1 return 1
} }
[[ "$flag_scrot_fullscreen" ]] || { scrot_args+=( '-s' ); } (( "$flag_scrot_fullscreen" )) || { scrot_args+=( '-s' ); }
[[ "$cfg_scrot_delay" ]] && { scrot_args+=( "-d $cfg_scrot_delay" ); } [[ "$cfg_scrot_delay" ]] && { scrot_args+=( "-d $cfg_scrot_delay" ); }
tmp_file="$(sup.mktemp "${cfg_tmp_dir}" ".${cfg_screenshot_ext}")" tmp_file="$(sup.mktemp "${cfg_tmp_dir}" ".${cfg_screenshot_ext}")"
@@ -65,18 +67,13 @@ sup.scrot() {
return 1 return 1
} }
echo "$tmp_file" printf '%s\n' "$tmp_file"
} }
sup.exclude() { sup.if_url() { printf '%s\n' "$1" | grep -oE "$cfg_url_regex" &>/dev/null; }
[[ "$2" ]] && { echo "$1"; return 1; }
return 0
}
sup.if_url() { echo "$1" | grep -oE "$cfg_url_regex" &>/dev/null; }
sup.mktemp() { sup.mktemp() {
local tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1" declare tmp_file_name tmp_file_name_extra="$2" tmp_dir="$1"
[[ -d "$tmp_dir" ]] || { [[ -d "$tmp_dir" ]] || {
sup.err "${tmp_dir} does not exist or is not a directory." sup.err "${tmp_dir} does not exist or is not a directory."
@@ -87,35 +84,46 @@ sup.mktemp() {
tmp_file_name="${RANDOM}${RANDOM}${tmp_file_name_extra}" tmp_file_name="${RANDOM}${RANDOM}${tmp_file_name_extra}"
done done
echo "${tmp_dir}/${tmp_file_name}" printf '%s\n' "${tmp_dir}/${tmp_file_name}"
} }
sup.getopt() { sup.set_argv() {
local keys declare arg opt c
declare -g argv
for i in "$@"; do while (( $# )); do
case "$i" in unset -v arg opt c
--*) echo "$i";;
-*) case "$1" in
keys=( `echo "${i##*-}" | fold -w1` ) (--) argv+=( "$1" ); break;;
[[ "${#keys[@]}" -gt 1 ]] && { (--*)
for k in ${keys[@]}; do IFS='=' read arg opt <<< "$1"
echo "-${k}" argv+=( "$arg" )
done
} || { [[ "$opt" ]] && {
echo "$i" argv+=( "$opt" )
} }
;; ;;
*) echo "$i";; (-*)
while read -n1 c
do
case "$c" in
-|'') :;;
*) argv+=( "-$c" );;
esac esac
done <<< "$1"
;;
(*) argv+=( "$1" );;
esac
shift
done done
} }
main() { main() {
local args file target flag_private flag_rm flag_scrot flag_scrot_fullscreen cfg_scrot_delay declare args file target flag_private flag_rm flag_scrot flag_scrot_fullscreen cfg_scrot_delay
while [[ "$1" ]]; do while [[ "$1" ]]; do
case "$1" in case "$1" in
@@ -128,33 +136,44 @@ main() {
-h|--help|--usage) sup.usage; return;; -h|--help|--usage) sup.usage; return;;
--) break;; --) shift; break;;
*) args+=( "$1" );; *) break;;
esac esac
shift shift
done done
sup.env sup.env
if [[ "$flag_scrot" ]]; then if (( flag_scrot )); then
file="$(sup.scrot)" || { return 1; } file=$(sup.scrot) || { return 1; }
else else
target="${args[0]}"; [[ "$target" ]] || { sup.usage; exit 1; } (( $# )) || {
sup.usage
return 1
}
target="$1"
if sup.if_url "$target"; then if sup.if_url "$target"; then
file=`sup.mktemp "$cfg_tmp_dir"` file=$(sup.mktemp "$cfg_tmp_dir")
curl -s "$target" > "$file" || { curl -skL "$target" > "$file" || {
sup.err "Could not download file." sup.err "Could not download file."
return 1 return 1
} }
else else
file="$target" file="$target"
[[ -f "$file" ]] || {
sup.err "No such file: ${file}"
return 1
}
fi fi
fi fi
sup.upload sup.upload
} }
main $(sup.getopt "$@") sup.set_argv "$@"
main "${argv[@]}"