From 57fe8d716f9bae2674f34dc8d11e882391922398 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Moritz=20Mei=C3=9Felbach?= Date: Mon, 14 Oct 2019 16:40:28 +0200 Subject: Make shellcheck happy --- sway-launcher-desktop.sh | 35 +++++++++++++++++------------------ 1 file changed, 17 insertions(+), 18 deletions(-) mode change 100644 => 100755 sway-launcher-desktop.sh diff --git a/sway-launcher-desktop.sh b/sway-launcher-desktop.sh old mode 100644 new mode 100755 index 8ceec7d..2ed6c02 --- a/sway-launcher-desktop.sh +++ b/sway-launcher-desktop.sh @@ -1,4 +1,4 @@ -#!/bin/sh +#!/usr/bin/env bash # terminal application launcher for sway, using fzf # Based on: https://gitlab.com/FlyingWombat/my-scripts/blob/master/sway-launcher @@ -13,22 +13,21 @@ DIRS=( GLYPH_COMMAND=" " GLYPH_DESKTOP=" " -touch $HIST_FILE +touch "$HIST_FILE" # Filter DIRS array for directories that actually exist. Append *.desktop to remaining elements for i in "${!DIRS[@]}" ; do [[ ! -d "${DIRS[i]}" ]] && unset -v 'DIRS[$i]' || DIRS[$i]="${DIRS[i]}/*.desktop" ; done DIRS=("${DIRS[@]}") -HIST_FILE_CONTENT=$(cat "$HIST_FILE") -HIST_ENTRIES=$(echo "$HIST_FILE_CONTENT" | sed -n -e 's/^[0-9]* //p') +HIST_FILE_CONTENT=$(< "$HIST_FILE") function createPreview(){ DESCRIPTION='No description' if [[ $2 == 'command' ]]; then TITLE=$1 - DESCRIPTION=$(whatis -l $1 2>/dev/null | head -n1 | sed -n -e 's/^.*\(.*\).*\-//p') + DESCRIPTION=$(whatis -l "$1" 2>/dev/null | head -n1 | sed -n -e 's/^.*\(.*\).*\-//p') else TITLE=$(cat $1 | grep ^Name= | head -n1 | awk -F= '{print $2}') - DESCRIPTION=$(cat $1 | grep Comment= | awk -F= '{print $2}') + DESCRIPTION=$(grep Comment= "$1" | awk -F= '{print $2}') fi echo -e "\033[33m $TITLE \033[0m" echo "$DESCRIPTION" @@ -38,28 +37,28 @@ export -f createPreview FZFPIPE=$(mktemp) # Append Launcher History, removing usage count -(echo "$HIST_FILE_CONTENT" | sed -n -e 's/^[0-9]* //p' >> $FZFPIPE )& +(echo "$HIST_FILE_CONTENT" | sed -n -e 's/^[0-9]* //p' >> "$FZFPIPE" )& # Load and append Desktop entries (grep -roP "Type=Application" ${DIRS[@]} | awk -F : '{print $1}' | sort -u | xargs -d "\n" grep -oP "(?<=Name=).*" | - awk -F : -v pre="$GLYPH_DESKTOP" '{print $1 "|desktop|\033[33m" pre "\033[0m" $2}' >> $FZFPIPE )& + awk -F : -v pre="$GLYPH_DESKTOP" '{print $1 "|desktop|\033[33m" pre "\033[0m" $2}' >> "$FZFPIPE" )& # Load and append command list -({ IFS=:; ls -H $PATH; } | grep -v '/.*' | sort -u | awk -v pre="$GLYPH_COMMAND" '{print $1 "|command|\033[31m" pre "\033[0m" $1 }' >> $FZFPIPE )& +({ IFS=:; ls -H $PATH; } | grep -v '/.*' | sort -u | awk -v pre="$GLYPH_COMMAND" '{print $1 "|command|\033[31m" pre "\033[0m" $1 }' >> "$FZFPIPE" )& -command_str=$((tail -f $FZFPIPE & echo $! > pid) | - fzf +x +s -d '\|' --nth ..3 --with-nth 3.. --preview 'createPreview {1} {2}' --preview-window=up:3:wrap --ansi ; kill -9 $( pid) | + fzf +x +s -d '\|' --nth ..3 --with-nth 3.. --preview 'createPreview {1} {2}' --preview-window=up:3:wrap --ansi ; kill -9 "$( "$HIST_FILE" command='echo "nope"' -case $(echo $command_str | awk -F'|' '{print $2}') in +case $(echo "$COMMAND_STR" | awk -F'|' '{print $2}') in desktop) - file=$(echo $command_str | awk -F '|' '{print $1}') + file=$(echo "$COMMAND_STR" | awk -F '|' '{print $1}') command=$(cat $file | grep Exec | awk -F'=' '{print $2}') ;; command) - command=$(echo $command_str | awk -F '|' '{print $1}') + command=$(echo "$COMMAND_STR" | awk -F '|' '{print $1}') ;; esac -- cgit v1.2.3