De acuerdo con la respuesta de daveraja , aquí hay un script bash que resolverá el propósito.
Considere una situación si está utilizando C-shell y desea ejecutar un comando sin salir del contexto / ventana de C-shell de la siguiente manera,
Comando que se ejecutará : busque la palabra exacta 'Prueba' en el directorio actual de forma recursiva solo en archivos * .h, * .c
grep -nrs --color -w --include="*.{h,c}" Testing ./
Solución 1 : ingrese a bash desde C-shell y ejecute el comando
bash
grep -nrs --color -w --include="*.{h,c}" Testing ./
exit
Solución 2 : escriba el comando deseado en un archivo de texto y ejecútelo usando bash
echo 'grep -nrs --color -w --include="*.{h,c}" Testing ./' > tmp_file.txt
bash tmp_file.txt
Solución 3 : ejecute el comando en la misma línea usando bash
bash -c 'grep -nrs --color -w --include="*.{h,c}" Testing ./'
Solución 4 : cree un sciprt (una vez) y utilícelo para todos los comandos futuros
alias ebash './execute_command_on_bash.sh'
ebash grep -nrs --color -w --include="*.{h,c}" Testing ./
El guión es el siguiente,
#!/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