Я иногда хочу попробовать что-то очень короткое, чтобы подтвердить
семантика. Так как создание временного файла и размещение в
шаблон занимает более 30 секунд, у меня есть этот сценарий:
#!/bin/sh
body="$1"
out=$(mktemp /tmp/ccrun-XXXXXX)
src=${out}.c
cat > ${src} <<EOF
#include <limits.h>
#include <string.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#define UNUSED __attribute__((unused))
int main(int UNUSED argc,char UNUSED *argv[])
{
EOF
echo "$body" >> ${src}
echo -e "return 0;\n}" >> ${src}
cc -std=c99 -Wall -Wextra ${CCRUN_FLAGS} -o ${out} ${src} -lm
shift
echo ${out} "$@"
${out} "$@"
#rm ${out} ${src}
Пример вызова (этот код статически инициализирует массив указателей на функции) выглядит следующим образом:
$ ccrun 'int f(int a){return a+1;} int g(int a){return a+2;} int (*farr[2])(int) = {f,g}; for (int i=0; i<2; i++) printf("%d %d\n",i,farr[i](i));'
/tmp/ccrun-6nT4Wo
0 1
1 3
Если я хочу внести небольшие изменения, я просто редактирую командную строку.
Если это станет громоздким в командной строке, я отредактирую
временный файл, в данном случае /tmp/ccrun-6nT4Wo.c
. Командная строка
аргументы для исполняемого файла могут быть даны после программы (сначала
аргумент). Исполняемый файл остается на месте, чтобы его можно было запустить
без перекомпиляции. Вы можете сделать что-то подобное для любого
язык.