diff options
| author | Luke Smith <luke@lukesmith.xyz> | 2021-09-23 15:47:59 -0400 | 
|---|---|---|
| committer | Luke Smith <luke@lukesmith.xyz> | 2021-09-23 15:47:59 -0400 | 
| commit | fcf4ba52c357ed05a2b6494c25ef3bab4d4e1c0e (patch) | |
| tree | 67bc79e662d39c44daf3c6385afb59de27a28424 /bin | |
| parent | 8e66fcb58afcea67256ae809be7b66dd0242556f (diff) | |
id numbers removed from filenames
Diffstat (limited to 'bin')
| -rwxr-xr-x | bin/mw | 28 | 
1 files changed, 16 insertions, 12 deletions
| @@ -34,7 +34,7 @@ checkbasics() { command -V gpg >/dev/null 2>&1 && GPG="gpg" || GPG="gpg2"  	echo "(If you don't already have a GPG key pair, first run \`$GPG --full-generate-key\`.)"         	exit 1 ;} ;} -getaccounts() { accounts="$(find -L "$accdir" -type f 2>/dev/null | grep -o "[0-9]-.*.muttrc" | sed "s/-/: /;s/\.muttrc$//" | sort -n)" ;} +getaccounts() { accounts="$(find -L "$accdir" -type f 2>/dev/null | grep -o "\S*.muttrc" | sed "s|.*/\([0-9]-\)*||;s/\.muttrc$//" | nl)" ;}  list() { getaccounts && [ -n "$accounts" ] && echo "$accounts" || exit 1 ;} @@ -104,12 +104,12 @@ set hostname = \"$hostname\"  source $muttshare/unbind.muttrc  $extra  $synccmd -" > "$accdir/$idnum-$fulladdr.muttrc" +" > "$accdir/$fulladdr.muttrc"  	[ ! -f "$muttrc" ] && echo "# vim: filetype=neomuttrc" > "$muttrc"  	! grep -q "^source.*mutt-wizard.muttrc" "$muttrc" && echo "source $muttshare/mutt-wizard.muttrc" >> "$muttrc" -	! grep "^source.*.muttrc" "$muttrc" | grep -qv "$muttshare/mutt-wizard.muttrc" && echo "source $accdir/$idnum-$fulladdr.muttrc" >> "$muttrc" -	echo "macro index,pager i$idnum '<sync-mailbox><enter-command>source $accdir/$idnum-$fulladdr.muttrc<enter><change-folder>!<enter>;<check-stats>' \"switch to $fulladdr\"" >> "$muttrc" +	! grep "^source.*.muttrc" "$muttrc" | grep -qv "$muttshare/mutt-wizard.muttrc" && echo "source $accdir/$fulladdr.muttrc" >> "$muttrc" +	echo "macro index,pager i$idnum '<sync-mailbox><enter-command>source $accdir/$fulladdr.muttrc<enter><change-folder>!<enter>;<check-stats>' \"switch to $fulladdr\"" >> "$muttrc"  }  getprofiles() { \ @@ -156,18 +156,18 @@ delete() { if [ -z "${fulladdr+x}" ]; then  		echo "Select the account you would like to delete (by number):"  		list || exit 1  		read -r input -		match="^$input:" +		match="^\s*$input\s\+"  	else -		match=" $fulladdr$" +		match="\s\+$fulladdr$"  		getaccounts  	fi -	fulladdr="$(echo "$accounts" | grep "$match" | cut -f2 -d' ')" +	fulladdr="$(echo "$accounts" | grep "$match" | grep -o "\S*@\S*")"  	[ -z "$fulladdr" ] && echo "$fulladdr is not a valid account name." && return 1  	sed -ibu "/IMAPStore $fulladdr-remote$/,/# End profile/d" "$mbsyncrc" 2>/dev/null ; rm -f "$mbsyncrc"bu -	rm -rf "${cachedir:?}/${fulladdr:?}" "$accdir/"[1-9]"-$fulladdr.muttrc" +	rm -rf "${cachedir:?}/${fulladdr:?}" "$accdir/$fulladdr.muttrc"  "$accdir/"[0-9]-"$fulladdr.muttrc"  	sed -ibu "/[0-9]-$fulladdr.muttrc/d" "$muttrc" 2>/dev/null; rm -f "$muttrc"bu  	sed -ibu "/account $fulladdr$/,/^\(\s*$\|account\)/d" "$msmtprc" 2>/dev/null; rm -f "$msmtprc"bu  	sed -ibu "/account $fulladdr$/,/^\(\s*$\|account\)/d" "$mpoprc" 2>/dev/null; rm -f "$mpoprc"bu @@ -224,11 +224,15 @@ getboxes() { if [ -n "${force+x}" ] ; then  	else  		info="$(curl --location-trusted -s -m 5 --user "$login:$(pass "$fulladdr")" --url "${protocol:-imaps}://$imap:${iport:-993}")"  		[ -z "$info" ] && echo "Log-on not successful." && return 1 -		mailboxes="$(echo "$info" | grep -v HasChildren | sed "s/.*\" //;s/\"//g" | tr -d ' -')" +		mailboxes="$(echo "$info" | grep -v HasChildren | sed "s/.*\" //;s/\"//g" | tr -d '\r')"  	fi  	[ "$type" = "pop" ] && mailboxes="INBOX" -	getaccounts; for x in 1 2 3 4 5 6 7 8 9; do echo "$accounts" | grep -q "^$x:" || { export idnum="$x"; break ;}; done +	getaccounts +	usednums="$(grep -o "^macro.* i[0-9]\+ " "$muttrc" | grep -o "[0-9]" | sort -u)" +	for x in 1 2 3 4 5 6 7 8 9; do +		echo "$usednums" | grep -q "$x" || +			{ export idnum="$x"; break ;} +	done  	toappend="mailboxes \`mdir=$maildir/$fulladdr/; find \$mdir -mindepth 1 -type d -name cur | sed -e 's:/cur\$:\":' -e \"s:\$mdir:\\\"=:\" | sort | tr '\\\n' ' '\`"  	IFS='  ' @@ -246,7 +250,7 @@ getboxes() { if [ -n "${force+x}" ] ; then  	unset IFS  } -finalize() { echo "$toappend" >> "$accdir/$idnum-$fulladdr.muttrc" +finalize() { echo "$toappend" >> "$accdir/$fulladdr.muttrc"  	[ "$type" != "online" ] && echo "$mailboxes" | xargs -I {} mkdir -p "$maildir/$fulladdr/{}/cur" "$maildir/$fulladdr/{}/tmp" "$maildir/$fulladdr/{}/new"  	echo "$fulladdr (account #$idnum) added successfully."  	command -V urlview >/dev/null 2>&1 && [ ! -f "$HOME/.urlview" ] && echo "COMMAND \$BROWSER" > "$HOME/.urlview" | 
