В соответствии с ответом Давераджи , вот сценарий bash, который решит эту задачу.
Рассмотрим ситуацию, если вы используете C-shell и хотите выполнить команду, не выходя из контекста / окна C-shell следующим образом:
Выполняемая команда : искать точное слово Testing в текущем каталоге рекурсивно только в файлах * .h, * .c
grep -nrs --color -w --include="*.{h,c}" Testing ./
Решение 1. Войдите в bash из C-оболочки и выполните команду
bash
grep -nrs --color -w --include="*.{h,c}" Testing ./
exit
Решение 2. Запишите предполагаемую команду в текстовый файл и выполните ее с помощью bash.
echo 'grep -nrs --color -w --include="*.{h,c}" Testing ./' > tmp_file.txt
bash tmp_file.txt
Решение 3. Запустите команду в той же строке, используя bash
bash -c 'grep -nrs --color -w --include="*.{h,c}" Testing ./'
Решение 4. Создайте sciprt (одноразовый) и используйте его для всех будущих команд
alias ebash './execute_command_on_bash.sh'
ebash grep -nrs --color -w --include="*.{h,c}" Testing ./
Сценарий выглядит следующим образом:
#!/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