In Übereinstimmung mit der Antwort von daveraja ist hier ein Bash-Skript, das den Zweck lösen wird.
Stellen Sie sich eine Situation vor, wenn Sie C-Shell verwenden und einen Befehl ausführen möchten, ohne den Kontext / das Fenster der C-Shell wie folgt zu verlassen:
Auszuführender Befehl : Suchen Sie das genaue Wort 'Testen' im aktuellen Verzeichnis rekursiv nur in * .h, * .c-Dateien
grep -nrs --color -w --include="*.{h,c}" Testing ./
Lösung 1 : Geben Sie bash von der C-Shell aus ein und führen Sie den Befehl aus
bash
grep -nrs --color -w --include="*.{h,c}" Testing ./
exit
Lösung 2 : Schreiben Sie den beabsichtigten Befehl in eine Textdatei und führen Sie ihn mit bash aus
echo 'grep -nrs --color -w --include="*.{h,c}" Testing ./' > tmp_file.txt
bash tmp_file.txt
Lösung 3 : Führen Sie den Befehl mit bash in derselben Zeile aus
bash -c 'grep -nrs --color -w --include="*.{h,c}" Testing ./'
Lösung 4 : Erstellen Sie einen sciprt (einmalig) und verwenden Sie ihn für alle zukünftigen Befehle
alias ebash './execute_command_on_bash.sh'
ebash grep -nrs --color -w --include="*.{h,c}" Testing ./
Das Skript lautet wie folgt:
#!/bin/bash
E_BADARGS=85
if [ ! -n "$1" ]
then
echo "Usage: `basename $0` grep -nrs --color -w --include=\"*.{h,c}\" Testing ."
echo "Usage: `basename $0` find . -name \"*.txt\""
exit $E_BADARGS
fi
TMPFILE=$(mktemp)
argList=""
for arg in "$@"
do
if echo $arg | grep -q " "; then
argList="$argList \"$arg\""
else
argList="$argList $arg"
fi
done
argList=$(echo $argList | sed 's/^ *//')
echo "$argList" >> $TMPFILE
last_command="rm -f $TMPFILE"
echo "$last_command" >> $TMPFILE
check_for_last_line=$(tail -n 1 $TMPFILE | grep -o "$last_command")
if [ "$check_for_last_line" == "$last_command" ]
then
bash $TMPFILE
exit 0
else
echo "Something is wrong"
echo "Last command in your tmp file should be removing itself"
echo "Aborting the process"
exit 1
fi