Чтение онлайн

ЖАНРЫ

Основы программирования в Linux
Шрифт:

# Какой компилятор

CC = gcc

# Куда установить

# INSTDIR=/usr/local/bin

# Где хранятся файлы include

INCLUDE = .

# Опции для разработки

CFLAGS = -g -Wall -ansi

# Опции
для рабочей версии

# CFLAGS = -О -Wall -ansi

myapp: main.o 2.o 3.o

 $(CC) -о myapp main.о 2.о 3.o

main.о: main.c a.h

 $(CC) -I$(INCLUDE) $(CFLAGS) -c main.c

2.о: 2.c a.h b.h

 $(CC) -I$(INCLUDE) $(CFLAGS) -c 2.c

3.o: 3.c b.h c.h

 $(CC) -I$(INCLUDE) $(CFLAGS) -c 3.c

clean:

 -rm main.o 2.o 3.o

install: myapp

 @if [ -d $(INSTDIR) ]; \

 then \

cp myapp $(INSTDIR);\

chmod a+x $(INSTDIR)/myapp;\

chmod og-w $(INSTDIR)/myapp;\

echo "Installed in $(INSTDIR)";\

 else \

echo "Sorry, $(INSTDIR) does not exist";\

 fi

В этом make-файле есть несколько вещей, на которые следует обратить внимание. Во-первых, специальная цель

all
, которая задает только один выходной файл myapp. Следовательно, если вы выполняете
make
без указания задания, поведение по умолчанию — сборка файла myapp.

Следующая важная особенность относится к двум дополнительным заданиям:

clean
и
install
. В задании
clean
для удаления объектных файлов применяется команда
rm
. Команда начинается со знака
, тем самым сообщая команде
make
о необходимости игнорировать результат команды, поэтому
make
выполнится успешно, даже если объектных файлов нет и команда
rm
вернет ошибку. Правила для задания
clean
ни от чего не зависят, остаток строки после
clean:
пуст. Таким образом, задание всегда считается измененным со времени последнего выполнения, и его правило всегда выполняется, если
clean
указывается в качестве задания.

Задание

install
зависит от myapp, поэтому команда
make
знает, что должна создать myapp перед выполнением других команд задания
install
. Правила выполнения
install
состоят из нескольких команд сценария
командной оболочки. Поскольку команда
make
запускает командную оболочку для выполнения правил и применяет новую командную оболочку для каждого правила, следует добавлять обратные слэши, чтобы все команды сценария были в одной логической строке и передавались для выполнения все вместе одному сеансу командной оболочки. Эта команда начинается со знака отменяющего вывод команды в стандартный файл вывода перед выполнением правила.

Задание

install
выполняет несколько команд одну за другой для установки приложения в указанное расположение. Оно не проверяет успешность выполнения предыдущей команды перед выполнением следующей. Если очень важно, чтобы последующие команды выполнялись только в случае успешного завершения предыдущей, можно написать команды, объединенные с помощью операции
&&,
как показано далее:

@if [ -d $(INSTDIR) ]; \

 then \

 cp myapp $(INSTDIR) &&\

 chmod a+x $(INSTDIR)/myapp && \

 chmod og-w $(INSTDIR/myapp && \

 echo "Installed in $(INSTDIR)" ; \

else \

 echo "Sorry, $(INSTDIR) does not exist"; false ; \

fi

Как вы, вероятно, помните из главы 2, у командной оболочки есть команда

and
, благодаря которой выполнение последующей команды возможно лишь при успешном завершении предыдущей. В данном примере вас не слишком заботит успешное завершение предыдущих команд, поэтому можно придерживаться более простой формы.

Если вы — обычный пользователь, то у вас может не быть прав на установку новых команд в каталог /usr/local/bin. Можно изменить в make-файле каталог установки, изменить права доступа к этому каталогу или заменить пользователя (с помощью команды

su
) на root перед запуском
make install
.

$ rm *.о myapp

$ make -f Makefile3

gcc -I.
– g -Wall -ansi -c main.c

gcc -I.
– g -Wall -ansi -c 2.c

gcc -I.
– g -Wall -ansi -с 3.c

gcc -o myapp main.о 2.o 3.o

$ make -f Makefile3

make: Nothing to be done for 'all'.

$ rm myapp

$ make -f Makefile3 install

gcc -o myapp main.o 2.o 3.o

Installed in /usr/local/bin

make -f Makefile3 clean

rm main.о 2.о 3.о

$

Как это работает

Сначала вы удаляете файл myapp и все объектные файлы. Команда

make
самостоятельно выбирает задание
all
, которое приводит к сборке myapp. Затем вы снова запускаете команду
make
, но т.к. у файла myapp свежая версия,
make
не делает ничего. Далее вы удаляете файл myapp и выполняете
make install
. Эта команда создает заново двоичный файл и копирует его в каталог установки. В заключение выполняется команда
make clean
, удаляющая объектные файлы.

Поделиться с друзьями: