Makefile - Makefile

Makefile
Тип интернет-СМИ
текст / x-makefile
Тип форматаАвтоматизация сборки
СтандартPOSIX: сделать - Справочник по командам и утилитам, Единая спецификация UNIX, Выпуск 7 из Открытая группа

А makefile представляет собой файл (по умолчанию с именем "Makefile"), содержащий набор директив, используемых сделать автоматизация сборки инструмент для создания цели / цели.

Обзор

Чаще всего makefile направляет Сделать о том, как компилировать и ссылка на сайт а программа. А makefile работает по принципу, что файлы нужно воссоздавать только в том случае, если их зависимости новее, чем создаваемый / воссозданный файл. В makefile выполняется рекурсивно (с подготовкой зависимости перед каждым цель в зависимости от них), пока все не будет обновлено (что требует обновления) и не будет завершена основная / конечная цель. Эти инструкции с их зависимостями указаны в makefile. Если ни один из необходимых файлов не был изменен с момента последней компиляции программы, никакие действия не выполняются. Для больших программных проектов использование Makefiles может существенно сократить время сборки, если были изменены только несколько исходных файлов.

С помощью C /C ++ Например, при изменении исходного файла C / C ++ его необходимо перекомпилировать. Если файл заголовка был изменен, каждый исходный файл C / C ++, который включает файл заголовка, должен быть перекомпилирован для обеспечения безопасности. Каждая компиляция производит объектный файл соответствующий исходному файлу. Наконец, если какой-либо исходный файл был перекомпилирован, все объектные файлы, будь то вновь созданные или сохраненные из предыдущих компиляций, должны быть связаны вместе для создания новой исполняемой программы.[1]

Операционная система

Unix-подобный

Make-файлы созданы Unix-подобный систем и по-прежнему являются основным механизмом сборки программного обеспечения в таких средах.

Майкрософт Виндоус

Windows поддерживает различные make-файлы с nmake полезность. Стандартные Unix-подобные make-файлы могут выполняться в Windows в Cygwin окружающая среда или Mingw.

Содержание

Make-файлы содержат пять типов вещей: явные правила, неявные правила, определения переменных, директивы, и Комментарии.

  • An явное правило говорит, когда и как переделывать один или несколько файлов, называемых целями правила. В нем перечислены другие файлы, от которых зависят цели, называемые предпосылками цели, а также может быть указан рецепт для использования при создании или обновлении целей.
  • An неявное правило говорит, когда и как переделывать класс файлов на основе их имен. Он описывает, как цель может зависеть от файла с именем, аналогичным цели, и дает рецепт для создания или обновления такой цели.
  • А определение переменной это строка, в которой указывается значение текстовой строки для переменной, которая может быть подставлена ​​в текст позже.
  • А директива это инструкция для make сделать что-то особенное при чтении make-файла, например, чтение другого make-файла.
  • "#" В строке make-файла запускает комментарий. Он и остальная часть строки игнорируются.

Правила

Makefile состоит из «правил» в следующей форме:

цель: зависимости    системная команда(s)

А цель обычно это имя файла, созданного программой; примерами целей являются исполняемые или объектные файлы. Целью также может быть имя выполняемого действия, например «очистка».

А зависимость (также называется предпосылка) - это файл, который используется в качестве входных данных для создания цели. Цель часто зависит от нескольких файлов. Однако правило, определяющее рецепт для цели, не обязательно должно иметь никаких предварительных условий. Например, правило, содержащее команду удаления, связанную с целью «очистить», не имеет предварительных требований.

В системная команда (ы) (также называется рецепт) - это действие, которое выполняет make. В рецепте может быть более одной команды, либо в одной строке, либо каждая в отдельной строке. Обратите внимание на использование значимый отступ в указании команд; также обратите внимание, что отступ должен состоять из одного символа .

Исполнение

А makefile выполняется с сделать команда, например сделать [параметры] [цель1 цель2 ...]По умолчанию, когда make ищет make-файл, если имя make-файла не было включено в качестве параметра, она пробует следующие имена в следующем порядке: makefile и Makefile.[1]

пример

Вот make-файл, который описывает способ, которым исполняемый файл называется редактировать зависит от четырех объектных файлов, которые, в свою очередь, зависят от четырех исходных файлов C и двух файлов заголовков. Чтобы быть конкретным, редактировать цель, edit.o, kbd.o, command.o и display.o объекты, которые мы связываем, чтобы сделать исполняемый файл, defs.h и command.h заголовки, которые наши объекты должны правильно компилировать, и $(CC) -c $@ $< $(CCFLAGS) это системная команда.

  • $@ это макрос, который относится к цели
  • $< это макрос, который относится к первой зависимости
  • $^ это макрос, который относится ко всем зависимостям
  • % макрос для создания шаблона, который мы хотим наблюдать как в цели, так и в зависимости

Файл make перекомпилирует все объекты, если какой-либо из заголовков изменится, но если отдельные .c Если файл изменяется, единственное, что нужно будет сделать, это перекомпилировать этот файл и затем заново связать все объекты. Хорошо написанные правила make могут помочь сократить время компиляции за счет определения того, что изменилось, а что нет.

Обратите внимание на то, как используются переменные и правила статического шаблона, чтобы сделать make-файл более расширяемым и читаемым. Мы определяем одно и то же правило многократного использования, чтобы каждый .o от каждого .c, и сделать каждый цель от объектов.

Также обратите внимание, что мы можем связать только одну главную сеть за раз, поэтому мы должны отфильтровать другие сети при связывании.

Цели все и чистый названы .PHONY потому что они не относятся к реальным файлам, это то, что мы хотим сделать.

CC      := gccCCFLAGS := LDFLAGS :=ЦЕЛИ:= редактироватьСЕТЬ  := $(добавляет суффикс .o, $(ЦЕЛИ) )OBJ    := kbd.o command.o display.o $(СЕТЬ)DEPS   := defs.h command.h.PHONY: все чистыйвсе: $(ЦЕЛИ)чистый:rm -f $(ЦЕЛИ) $(OBJ)$ (OBJ): %.о : %.c $(DEPS)	$(CC) -c -o $@ $< $(CCFLAGS)$ (ЦЕЛИ): % : $(отфильтровано $(СЕТЬ), $(OBJ)) %.о	$(CC)$@ $(LIBS) $^ $(CCFLAGS) $(LDFLAGS)

Чтобы использовать этот make-файл для создания исполняемого файла с именем редактировать, тип сделать всеили сделать редактировать. Чтобы использовать этот make-файл для удаления исполняемого файла и всех объектных файлов из каталога, введите очистить.

Смотрите также

использованная литература

  1. ^ а б «Целевые правила POSIX».