Makefile-퀵 가이드

특히 여러 소스 파일을 포함하고 컴파일해야 할 때마다 컴파일 명령을 입력해야하는 경우 소스 코드 파일을 컴파일하는 것이 지루할 수 있습니다. Makefile은이 작업을 단순화하는 솔루션입니다.

Makefile은 프로젝트를 자동으로 빌드하고 관리하는 데 도움이되는 특수 형식 파일입니다.

예를 들어 다음과 같은 소스 파일이 있다고 가정 해 보겠습니다.

  • main.cpp
  • hello.cpp
  • factorial.cpp
  • functions.h

main.cpp

다음은 main.cpp 소스 파일의 코드입니다.

#include <iostream>

using namespace std;

#include "functions.h"

int main(){
   print_hello();
   cout << endl;
   cout << "The factorial of 5 is " << factorial(5) << endl;
   return 0;
}

hello.cpp

아래에 주어진 코드는 hello.cpp 소스 파일입니다.

#include <iostream>

using namespace std;

#include "functions.h"

void print_hello(){
   cout << "Hello World!";
}

factorial.cpp

factorial.cpp에 대한 코드는 다음과 같습니다.

#include "functions.h"

int factorial(int n){
   
   if(n!=1){
      return(n * factorial(n-1));
   } else return 1;
}

functions.h

다음은 fnctions.h에 대한 코드입니다-

void print_hello();
int factorial(int n);

파일을 컴파일하고 실행 파일을 얻는 간단한 방법은 다음 명령을 실행하는 것입니다.

gcc  main.cpp hello.cpp factorial.cpp -o hello

이 명령은 hello 바이너리를 생성 합니다. 이 예에서는 4 개의 파일 만 있고 함수 호출의 순서를 알고 있습니다. 따라서 위의 명령을 입력하고 최종 바이너리를 준비하는 것이 가능합니다.

그러나 수천 개의 소스 코드 파일이있는 대규모 프로젝트의 경우 바이너리 빌드를 유지하기가 어려워집니다.

그만큼 make명령을 사용하면 큰 프로그램이나 프로그램 그룹을 관리 할 수 ​​있습니다. 큰 프로그램을 작성하기 시작하면 큰 프로그램을 다시 컴파일하는 것이 짧은 프로그램을 다시 컴파일하는 것보다 시간이 더 오래 걸린다는 것을 알 수 있습니다. 또한 일반적으로 프로그램의 작은 부분 (예 : 단일 기능)에서만 작업하고 나머지 프로그램의 대부분은 변경되지 않습니다.

다음 섹션에서는 프로젝트를 위해 makefile을 준비하는 방법을 살펴 봅니다.

그만큼 make프로그램을 사용하면 변수와 유사한 매크로를 사용할 수 있습니다. 매크로는 Makefile에서 = 쌍으로 정의됩니다. 아래에 예가 나와 있습니다.

MACROS  = -me
PSROFF  = groff -Tps
DITROFF = groff -Tdvi
CFLAGS  = -O -systype bsd43
LIBS    = "-lncurses -lm -lsdl"
MYFACE  = ":*)"

특수 매크로

대상 규칙 세트에서 명령을 실행하기 전에 미리 정의 된 특정 특수 매크로가 있습니다.

  • $ @는 만들 파일의 이름입니다.

  • $? 변경된 부양 가족의 이름입니다.

예를 들어 다음과 같은 규칙을 사용할 수 있습니다.

hello: main.cpp hello.cpp factorial.cpp
   $(CC) $(CFLAGS) $? $(LDFLAGS) -o $@

Alternatively:

hello: main.cpp hello.cpp factorial.cpp
   $(CC) $(CFLAGS) [email protected] $(LDFLAGS) -o $@

이 예에서 $ @는 hello 및 $?를 나타냅니다 . 또는 $ @. cpp는 변경된 모든 소스 파일을 선택합니다.

암시 적 규칙에 사용되는 특수 매크로가 두 개 더 있습니다. 그들은-

  • $ <조치를 발생시킨 관련 파일의 이름입니다.

  • $ * 대상 및 종속 파일이 공유하는 접두사.

일반적인 암시 적 규칙은 .cpp (소스 파일)에서 .o (객체) 파일을 구성하는 것입니다.

.cpp.o:
   $(CC) $(CFLAGS) -c $<

Alternatively:

.cpp.o:
   $(CC) $(CFLAGS) -c $*.c

기존 매크로

다양한 기본 매크로가 있습니다. 기본값을 인쇄하려면 "make -p"를 입력하여 볼 수 있습니다. 대부분은 사용되는 규칙에서 매우 분명합니다.

이러한 미리 정의 된 변수, 즉 암시 적 규칙에 사용되는 매크로는 두 가지 클래스로 나뉩니다. 그들은 다음과 같습니다-

  • 프로그램 이름 인 매크로 (예 : CC)

  • 프로그램의 인수를 포함하는 매크로 (예 : CFLAGS).

아래는 메이크 파일의 내장 규칙에서 프로그램 이름으로 사용되는 몇 가지 공통 변수의 표입니다.

Sr. 아니요 변수 및 설명
1

AR

아카이브 유지 프로그램; 기본값은 'ar'입니다.

2

AS

어셈블리 파일을 컴파일하는 프로그램; 기본값은 'as'입니다.

CC

C 프로그램을 컴파일하는 프로그램; 기본값은 'cc'입니다.

4

CO

RCS에서 파일을 체크 아웃하는 프로그램; 기본값은 'co'입니다.

5

CXX

C ++ 프로그램을 컴파일하는 프로그램; 기본값은`g ++ '입니다.

6

CPP

표준 출력에 대한 결과와 함께 C 전처리기를 실행하는 프로그램. 기본값은`$ (CC) -E '입니다.

7

FC

Fortran 및 Ratfor 프로그램을 컴파일하거나 전처리하는 프로그램 기본값은 'f77'입니다.

8

GET

SCCS에서 파일을 추출하는 프로그램; 기본값은 'get'입니다.

9

LEX

Lex 문법을 소스 코드로 바꾸는 데 사용하는 프로그램; 기본값은`lex '입니다.

10

YACC

Yacc 문법을 소스 코드로 바꾸는 데 사용할 프로그램 기본값은`yacc '입니다.

11

LINT

소스 코드에서 Lint를 실행하는 데 사용할 프로그램입니다. 기본값은`lint '입니다.

12

M2C

Modula-2 소스 코드를 컴파일하는 데 사용할 프로그램 기본값은 'm2c'입니다.

13

PC

파스칼 프로그램 컴파일 프로그램; 기본값은 'pc'입니다.

14

MAKEINFO

Texinfo 소스 파일을 Info 파일로 변환하는 프로그램; 기본값은`makeinfo '입니다.

15

TEX

TeX 소스에서 TeX dvi 파일을 만드는 프로그램; 기본값은 'tex'입니다.

16

TEXI2DVI

Texinfo 소스에서 TeX dvi 파일을 만드는 프로그램; 기본값은`texi2dvi '입니다.

17

WEAVE

웹을 TeX로 번역하는 프로그램; 기본값은 'weave'입니다.

18

CWEAVE

C Web을 TeX로 번역하는 프로그램; 기본값은 'cweave'입니다.

19

TANGLE

웹을 파스칼로 번역하는 프로그램; 기본값은`tangle '입니다.

20

CTANGLE

C Web을 C로 번역하는 프로그램; 기본값은 'ctangle'입니다.

21

RM

파일을 제거하는 명령; 기본값은 'rm -f'입니다.

다음은 위의 프로그램에 대한 추가 인수 값을 갖는 변수 테이블입니다. 별도로 언급하지 않는 한 이들 모두의 기본값은 빈 문자열입니다.

Sr. 아니. 변수 및 설명
1

ARFLAGS

아카이브 유지 프로그램을 제공하는 플래그; 기본값은`rv '입니다.

2

ASFLAGS

`.s '또는`.S'파일에서 명시 적으로 호출 될 때 어셈블러에 제공 할 추가 플래그.

CFLAGS

C 컴파일러에 제공 할 추가 플래그입니다.

4

CXXFLAGS

C 컴파일러에 제공 할 추가 플래그입니다.

5

COFLAGS

RCS co 프로그램에 제공 할 추가 플래그입니다.

6

CPPFLAGS

이를 사용하는 C 전 처리기 및 프로그램 (예 : C 및 Fortran 컴파일러)에 제공 할 추가 플래그.

7

FFLAGS

Fortran 컴파일러에 제공 할 추가 플래그입니다.

8

GFLAGS

SCCS get 프로그램에 제공 할 추가 플래그입니다.

9

LDFLAGS

링커 'ld'를 호출해야 할 때 컴파일러에 제공 할 추가 플래그.

10

LFLAGS

Lex에게 줄 추가 플래그.

11

YFLAGS

Yacc에 제공 할 추가 플래그입니다.

12

PFLAGS

파스칼 컴파일러에 제공 할 추가 플래그입니다.

13

RFLAGS

Ratfor 프로그램 용 Fortran 컴파일러에 제공 할 추가 플래그입니다.

14

LINTFLAGS

보푸라기에 줄 추가 플래그.

NOTE − '-R'또는 '--no-builtin-variables'옵션을 사용하여 암시 적 규칙에서 사용하는 모든 변수를 취소 할 수 있습니다.

다음과 같이 명령 줄에서 매크로를 정의 할 수도 있습니다.

make CPP = /home/courses/cop4530/spring02

최종 바이너리가 다양한 소스 코드와 소스 헤더 파일에 의존하는 것은 매우 일반적입니다. 종속성은 중요합니다.make모든 대상의 소스에 대해 알고 있습니다. 다음 예를 고려하십시오-

hello: main.o factorial.o hello.o
   $(CC) main.o factorial.o hello.o -o hello

여기에서 우리는 makehello는 main.o, factorial.o 및 hello.o 파일에 따라 다릅니다. 따라서 이러한 개체 파일이 변경 될 때마다make 조치를 취할 것입니다.

동시에, 우리는 make.o 파일을 준비하는 방법. 따라서 다음과 같이 이러한 종속성을 정의해야합니다.

main.o: main.cpp functions.h
   $(CC) -c main.cpp

factorial.o: factorial.cpp functions.h
   $(CC) -c factorial.cpp

hello.o: hello.cpp functions.h
   $(CC) -c hello.cpp

이제 Makefile의 규칙을 배우겠습니다.

Makefile 대상 규칙의 일반적인 구문은 다음과 같습니다.

target [target...] : [dependent ....]
[ command ...]

위 코드에서 괄호 안의 인수는 선택 사항이며 줄임표는 하나 이상을 의미합니다. 여기에서 각 명령을 시작하는 탭이 필요합니다.

다음은 세 개의 다른 파일에서 대상을 hello로 만드는 규칙을 정의하는 간단한 예입니다.

hello: main.o factorial.o hello.o
   $(CC) main.o factorial.o hello.o -o hello

NOTE −이 예에서는 소스 파일에서 모든 개체 파일을 만들기위한 규칙을 제공해야합니다.

의미는 매우 간단합니다. "make target"이라고 말하면make적용되는 대상 규칙을 찾습니다. 그리고 부양 가족이 목표보다 새로운 경우make한 번에 하나씩 명령을 실행합니다 (매크로 대체 후). 부양 가족을 만들어야하는 경우 먼저 발생합니다 (따라서 재귀가 발생합니다).

Make명령이 실패 상태를 반환하면 종료됩니다. 이 경우 다음 규칙이 표시됩니다.

clean:
   -rm *.o *~ core paper

Make대시로 시작하는 명령 줄에서 반환 된 상태를 무시합니다. 예를 들어 코어 파일이 없는지 누가 신경 쓰나요?

Make매크로 대체 후 명령을 에코하여 무슨 일이 일어나고 있는지 보여줍니다. 때때로 당신은 그것을 끄고 싶을 수도 있습니다. 예를 들면-

install:
   @echo You must be root to install

사람들은 Makefile에서 특정 타겟을 기대하게되었습니다. 항상 먼저 탐색해야합니다. 그러나 모든 대상 (또는 만들기), 설치 및 정리 대상이 발견 될 것으로 예상하는 것이 합리적입니다.

  • make all − 응용 프로그램을 설치하기 전에 로컬 테스트를 수행 할 수 있도록 모든 것을 컴파일합니다.

  • make install − 적절한 장소에 애플리케이션을 설치합니다.

  • make clean − 응용 프로그램을 정리하고 실행 파일, 임시 파일, 개체 파일 등을 제거합니다.

Makefile 암시 적 규칙

이 명령은 소스 코드 x.cpp에서 실행 가능한 x를 빌드하는 모든 경우에서 작동해야하는 명령입니다. 이것은 암시 적 규칙으로 설명 할 수 있습니다.

.cpp:
   $(CC) $(CFLAGS) [email protected] $(LDFLAGS) -o $@

이 암시 적 규칙은 xc에서 x를 만드는 방법을 말합니다. xc에서 cc를 실행하고 출력 x를 호출합니다. 특정 대상이 언급되지 않았으므로이 규칙은 암시 적입니다. 모든 경우에 사용할 수 있습니다.

또 다른 일반적인 암시 적 규칙은 .cpp (소스 파일)에서 .o (객체) 파일을 구성하는 것입니다.

.cpp.o:
   $(CC) $(CFLAGS) -c $<

alternatively

.cpp.o:
   $(CC) $(CFLAGS) -c $*.cpp

Make해당 .c 파일에서 cc -c를 사용하여 자동으로 ao 파일을 만들 수 있습니다. 이러한 규칙은make,이 이점을 활용하여 Makefile을 줄일 수 있습니다. 현재 대상이 종속 된 Makefile의 종속성 행에 .h 파일 만 표시하면,make해당 .cfile이 이미 필요하다는 것을 알게됩니다. 컴파일러에 대한 명령을 포함 할 필요는 없습니다.

이것은 아래와 같이 Makefile을 더 줄입니다.

OBJECTS = main.o hello.o factorial.o
hello: $(OBJECTS)
   cc $(OBJECTS) -o hello
hellp.o: functions.h

main.o: functions.h 
factorial.o: functions.h

Make.SUFFIXES 라는 특수 대상 을 사용하여 고유 한 접미사를 정의 할 수 있습니다. 예를 들어, 아래에 주어진 종속성 라인을 참조하십시오.

.SUFFIXES: .foo .bar

그것은 알려줍니다 make 이러한 특수 접미사를 사용하여 고유 한 규칙을 만들 것입니다.

방법과 유사 make.c 파일 에서 .o 파일 을 만드는 방법을 이미 알고 있으므로 다음과 같은 방식으로 규칙을 정의 할 수 있습니다.

.foo.bar:
   tr '[A-Z][a-z]' '[N-Z][A-M][n-z][a-m]' < $< > $@
.c.o:
   $(CC) $(CFLAGS) -c $<

첫 번째 규칙을 사용하면 .foo 파일 에서 .bar 파일 을 만들 수 있습니다 . 기본적으로 파일을 스크램블합니다. 두 번째 규칙은 다음에서 사용하는 기본 규칙입니다.make.c 파일 에서 .o 파일 을 만듭니다 .

다양한 형태로 사용할 수있는 수많은 지침이 있습니다. 그만큼make시스템의 프로그램이 모든 지시문을 지원하지 않을 수 있습니다. 따라서 귀하의make 여기서 설명하는 지침을 지원합니다. GNU make 이러한 지시문을 지원합니다.

조건부 지시문

조건부 지시문은-

  • 그만큼 ifeq지시문은 조건을 시작하고 조건을 지정합니다. 여기에는 쉼표로 구분되고 괄호로 묶인 두 개의 인수가 포함됩니다. 변수 대체는 두 인수 모두에서 수행 된 다음 비교됩니다. 두 인수가 일치하면 ifeq 다음의 makefile 행이 준수됩니다. 그렇지 않으면 무시됩니다.

  • 그만큼 ifneq지시문은 조건을 시작하고 조건을 지정합니다. 여기에는 쉼표로 구분되고 괄호로 묶인 두 개의 인수가 포함됩니다. 변수 대체는 두 인수 모두에서 수행 된 다음 비교됩니다. ifneq 다음의 makefile 행은 두 인수가 일치하지 않으면 준수됩니다. 그렇지 않으면 무시됩니다.

  • 그만큼 ifdef지시문은 조건을 시작하고 조건을 지정합니다. 단일 인수를 포함합니다. 주어진 인수가 참이면 조건은 참이됩니다.

  • 그만큼 ifndef지시문은 조건을 시작하고 조건을 지정합니다. 단일 인수를 포함합니다. 주어진 인수가 거짓이면 조건은 참이됩니다.

  • 그만큼 else지시문은 이전 조건이 실패한 경우 다음 행을 따르도록합니다. 위의 예에서 이것은 첫 번째 대안이 사용되지 않을 때마다 두 번째 대안 연결 명령이 사용됨을 의미합니다. 조건부에서 else를 갖는 것은 선택 사항입니다.

  • 그만큼 endif지시문은 조건부를 종료합니다. 모든 조건문은 endif로 끝나야합니다.

조건부 지시문의 구문

다른 조건이없는 간단한 조건 문의 구문은 다음과 같습니다.

conditional-directive
   text-if-true
endif

text-if-true는 조건이 참인 경우 메이크 파일의 일부로 간주되는 텍스트 행일 수 있습니다. 조건이 거짓이면 대신 텍스트가 사용되지 않습니다.

복잡한 조건 문의 구문은 다음과 같습니다.

conditional-directive
   text-if-true
else
   text-if-false
endif

조건이 참이면 text-if-true가 사용됩니다. 그렇지 않으면 text-if-false가 사용됩니다. text-if-false는 여러 줄의 텍스트 일 ​​수 있습니다.

조건 지시문의 구문은 조건문이 단순하든 복잡하든 동일합니다. 다양한 조건을 테스트하는 네 가지 지시문이 있습니다. 그들은 주어진대로-

ifeq (arg1, arg2)
ifeq 'arg1' 'arg2'
ifeq "arg1" "arg2"
ifeq "arg1" 'arg2'
ifeq 'arg1' "arg2"

위 조건의 반대 지시는 다음과 같습니다.

ifneq (arg1, arg2)
ifneq 'arg1' 'arg2'
ifneq "arg1" "arg2"
ifneq "arg1" 'arg2'
ifneq 'arg1' "arg2"

조건부 지시문의 예

libs_for_gcc = -lgnu
normal_libs =

foo: $(objects)
ifeq ($(CC),gcc)
   $(CC) -o foo $(objects) $(libs_for_gcc)
else
   $(CC) -o foo $(objects) $(normal_libs)
endif

포함 지시문

그만큼 include directive 허용 make계속하기 전에 현재 메이크 파일 읽기를 중단하고 하나 이상의 다른 메이크 파일을 읽습니다. 지시문은 다음과 같은 makefile의 한 줄입니다.

include filenames...

파일 이름은 쉘 파일 이름 패턴을 포함 할 수 있습니다. 줄의 시작 부분에 추가 공백이 허용되고 무시되지만 탭은 허용되지 않습니다. 예를 들어, 세 개의`.mk '파일, 즉`a.mk',`b.mk ',`c.mk', $ (bar)가있는 경우 bish bash로 확장되고 다음과 같이 확장됩니다. 표현.

include foo *.mk $(bar)

is equivalent to:

include foo a.mk b.mk c.mk bish bash

makeinclude 지시문을 처리하고 makefile 읽기를 일시 중지하고 나열된 각 파일에서 차례로 읽습니다. 완료되면make 지시문이 나타나는 메이크 파일 읽기를 다시 시작합니다.

재정의 지시문

변수가 명령 인수로 설정된 경우 메이크 파일의 일반적인 할당은 무시됩니다. makefile에서 명령 인수로 설정 했음에도 변수를 설정하려면 다음과 같은 라인 인 override 지시문을 사용할 수 있습니다.

override variable = value

or

override variable := value

그만큼 make프로그램은 지능형 유틸리티이며 소스 파일에서 수행 한 변경 사항에 따라 작동합니다. 4 개의 파일 main.cpp, hello.cpp, factorial.cpp 및 functions.h가있는 경우 나머지 모든 파일은 functions.h에 종속되고 main.cpp는 hello.cpp 및 factorial.cpp에 모두 종속됩니다. 따라서 functions.h를 변경하면make모든 소스 파일을 다시 컴파일하여 새 개체 파일을 생성합니다. 그러나 main.cpp를 변경하면 다른 파일에 종속되지 않으므로 main.cpp 파일 만 재 컴파일되고 help.cpp 및 factorial.cpp는 그렇지 않습니다.

파일을 컴파일하는 동안 make개체 파일을 확인하고 타임 스탬프를 비교합니다. 소스 파일에 오브젝트 파일보다 새로운 타임 스탬프가있는 경우 소스 파일이 변경된 것으로 가정하여 새 오브젝트 파일을 생성합니다.

재 컴파일 방지

수천 개의 파일로 구성된 프로젝트가있을 수 있습니다. 때로는 소스 파일을 변경했지만 그에 의존하는 모든 파일을 다시 컴파일하고 싶지 않을 수 있습니다. 예를 들어 다른 파일이 종속 된 헤더 파일에 매크로 또는 선언을 추가한다고 가정합니다. 보수적이기 때문에make 헤더 파일을 변경하려면 모든 종속 파일을 재 컴파일해야하지만 재 컴파일이 필요하지 않으며 컴파일을 기다리는 데 시간을 낭비하지 않는다는 것을 알고 있습니다.

헤더 파일을 변경하기 전에 문제가 예상되면`-t '플래그를 사용할 수 있습니다. 이 플래그는make규칙에서 명령을 실행하지 않고 마지막 수정 날짜를 변경하여 대상을 최신으로 표시합니다. 이 절차를 따라야합니다-

  • 정말로 재 컴파일이 필요한 소스 파일을 재 컴파일하려면`make '명령을 사용하십시오.

  • 헤더 파일을 변경하십시오.

  • 모든 오브젝트 파일을 최신으로 표시하려면`make -t '명령을 사용하십시오. 다음에 make를 실행할 때 헤더 파일의 변경으로 인해 재 컴파일이 발생하지 않습니다.

일부 파일을 다시 컴파일해야 할 때 헤더 파일을 이미 변경 한 경우에는 너무 늦습니다. 대신 지정된 파일을 "이전"으로 표시하는`-o file '플래그를 사용할 수 있습니다. 즉, 파일 자체는 다시 만들어지지 않으며 다른 계정으로 다시 만들어지지 않습니다. 이 절차를 따라야합니다-

  • 특정 헤더 파일과는 별개의 이유로 컴파일이 필요한 소스 파일을`make -o header file '로 다시 컴파일하십시오. 여러 헤더 파일이 관련된 경우 각 헤더 파일에 대해 별도의`-o '옵션을 사용하십시오.

  • `make -t '로 모든 오브젝트 파일을 업데이트하십시오.

이 장에서는 Makefile의 다양한 기능을 살펴 보겠습니다.

Make의 재귀 적 사용

재귀 적 사용 make 사용을 의미 makemakefile의 명령으로. 이 기술은 더 큰 시스템을 구성하는 다양한 하위 시스템에 대해 별도의 메이크 파일을 원할 때 유용합니다. 예를 들어, 자체 메이크 파일이있는`subdir '이라는 하위 디렉토리가 있고 포함 된 디렉토리의 메이크 파일이 실행되기를 원한다고 가정합니다.make하위 디렉토리에 있습니다. 아래 코드를 작성하면됩니다.

subsystem:
   cd subdir && $(MAKE)

or, equivalently:
 	
subsystem:
   $(MAKE) -C subdir

재귀를 쓸 수 있습니다 make이 예제를 복사하여 명령을 실행하십시오. 그러나 작동 방식과 이유, 하위 메이크가 최상위 메이크와 어떻게 관련되는지 알아야합니다.

서브 메이크에 변수 전달

최상위 수준의 변수 값 make명시적인 요청에 의해 환경을 통해 서브 메이크에 전달 될 수 있습니다. 이러한 변수는 하위 메이크에서 기본값으로 정의됩니다. `-e '스위치를 사용하지 않는 한 sub-make makefile이 사용하는 makefile에 지정된 것을 덮어 쓸 수 없습니다.

변수를 전달하거나 내보내려면 make각 명령을 실행하기 위해 환경에 변수와 해당 값을 추가합니다. 하위 메이크는 환경을 사용하여 변수 값 테이블을 초기화합니다.

특수 변수 SHELL 및 MAKEFLAGS는 항상 내보내집니다 (내보내기를 취소하지 않는 한). MAKEFILES는 무엇이든 설정하면 내보내집니다.

특정 변수를 하위 make로 내보내려면 다음과 같이 export 지시문을 사용하십시오.

export variable ...

변수가 내보내지지 않도록하려면 아래와 같이 unexport 지시문을 사용하십시오.

unexport variable ...

변수 MAKEFILES

환경 변수 MAKEFILES가 정의 된 경우 make값을 다른 makefile보다 먼저 읽을 추가 makefile의 이름 목록 (공백으로 구분)으로 간주합니다. 이는 include 지시문과 매우 유사합니다. 다양한 디렉토리에서 해당 파일을 검색합니다.

MAKEFILES의 주요 용도는 다음의 재귀 호출 간의 통신에 있습니다. make.

다른 디렉토리의 헤더 파일 포함

헤더 파일을 다른 디렉토리에 넣고 실행중인 경우 make다른 디렉토리에있는 경우 헤더 파일의 경로를 제공해야합니다. makefile에서 -I 옵션을 사용하여 수행 할 수 있습니다. functions.h 파일이 / home / tutorialspoint / header 폴더에 있고 나머지 파일이 / home / tutorialspoint / src / 폴더에 있다고 가정하면 makefile은 다음과 같이 작성됩니다.

INCLUDES = -I "/home/tutorialspoint/header"
CC = gcc
LIBS =  -lm
CFLAGS = -g -Wall
OBJ =  main.o factorial.o hello.o

hello: ${OBJ}
   ${CC} ${CFLAGS} ${INCLUDES} -o $@ ${OBJS} ${LIBS}
.cpp.o:
   ${CC} ${CFLAGS} ${INCLUDES} -c $<

변수에 더 많은 텍스트 추가

종종 이미 정의 된 변수의 값에 더 많은 텍스트를 추가하는 것이 유용합니다. 다음과 같이`+ = '를 포함하는 행으로이 작업을 수행합니다.

objects += another.o

변수 객체의 값을 취하고 아래에 표시된대로 단일 공백이 앞에 오는 'another.o'텍스트를 추가합니다.

objects = main.o hello.o factorial.o
objects += another.o

위의 코드는 객체를`main.o hello.o factorial.o another.o '로 설정합니다.

`+ = '사용은 다음과 유사합니다.

objects = main.o hello.o factorial.o
objects := $(objects) another.o

Makefile의 연속 줄

Makefile에서 너무 큰 줄이 마음에 들지 않으면 아래와 같이 백 슬래시 "\"를 사용하여 줄을 끊을 수 있습니다.

OBJ =  main.o factorial.o \
   hello.o

is equivalent to

OBJ =  main.o factorial.o hello.o

명령 프롬프트에서 Makefile 실행

"Makefile"이라는 이름으로 Makefile을 준비한 경우 명령 프롬프트에서 간단히 make를 작성하면 Makefile 파일이 실행됩니다. 그러나 Makefile에 다른 이름을 지정한 경우 다음 명령을 사용하십시오.

make -f your-makefile-name

이것은 hello 프로그램을 컴파일하기위한 Makefile의 예입니다. 이 프로그램은 main.cpp , factorial.cpphello.cpp 세 파일로 구성됩니다 .

# Define required macros here
SHELL = /bin/sh

OBJS =  main.o factorial.o hello.o
CFLAG = -Wall -g
CC = gcc
INCLUDE =
LIBS = -lm

hello:${OBJ}
   ${CC} ${CFLAGS} ${INCLUDES} -o $@ ${OBJS} ${LIBS}

clean:
   -rm -f *.o core *.core

.cpp.o:
   ${CC} ${CFLAGS} ${INCLUDES} -c $<

이제 프로그램을 빌드 할 수 있습니다. hello 사용 make. 명령을 내릴 경우make clean 그런 다음 현재 디렉토리에서 사용 가능한 모든 오브젝트 파일과 코어 파일을 제거합니다.