make (소프트웨어)

위키백과, 우리 모두의 백과사전.

Make
패러다임매크로, 선언형
설계자스투어트 펠트먼
발표일1976년 4월(48년 전)(1976-04)
구현 언어C
운영 체제유닉스 계열, 인페르노
파일 포맷Makefile
주요 구현체
BSD, GNU, nmake
방언
BSD make, GNU make, Microsoft nmake
영향을 준 언어
앤트, 레이크, MSBuild

make소프트웨어 개발을 위해 유닉스 계열 운영 체제에서 주로 사용되는 프로그램 빌드 도구이다.

여러 파일들끼리의 의존성과 각 파일에 필요한 명령을 정의함으로써 프로그램을 컴파일할 수 있으며 최종 프로그램을 만들 수 있는 과정을 서술할 수 있는 표준적인 문법을 가지고 있다.

위의 구조로 기술된 파일(주로 Makefile이라는 파일명)을 make가 해석하여 프로그램 빌드를 수행하게 된다.

파생[편집]

Makefile[편집]

make을 실행하기 전에 프로젝트의 목록 및 컴파일 및 링크 규칙을 만들어야 한다. 이것은 보통 Makefile을 사용한다. 이 파일에 규칙을 입력하여 파일로 만든다.

규칙[편집]

TARGET ...: PREREQUISITES ...
Tab ↹RECIPE
Tab ↹...

또 다른 형식은

TARGETS: PREREQUISITES ; RECIPE
Tab ↹RECIPE
Tab ↹...
TARGET
실행 파일, object 파일, 라이브러리 등 목적 규칙을 정의한다. RECIPE에서 실행된 결과로 만들어진다. RECIPE 여러개의 명령줄을 사용할 수가 있어 복잡한 기능도 수행이 가능하다. 생성파일이나 install 같은 기능적 블럭도 가능하다.
PREREQUISITES
TARGET을 만들 때, 의존성(연관관계)를 규정한다. 이 부분에 나열된 파일 중 수정된 파일이 있으면 TARGET을 다시 만든다.
RECIPE
TARGET을 만들기 위한 실행 파일이다. 이 실행 규칙에 따라 TARGET이 생성 된다. 주로 cc나 리눅스 명령어를 사용한다. 이 명령 줄은 여러 줄이 가능하다. 주의 할 것은 RECIPE 부분의 앞 공간은 키보드 Tab ↹을 사용해야 한다. Space키로 공간을 넣으면 안 된다.

 예  

     foo.o : foo.c defs.h       # module for twiddling the frobs
             cc -c -g foo.c

foo.c나 defs.h가 변경되면 cc -c -g foo.c명령을 실행해 foo.o을 만든다.

Makefile 예[편집]

     objects = main.o kbd.o command.o display.o \
               insert.o search.o files.o utils.o

     edit : $(objects)
             cc -o edit $(objects)

     main.o : defs.h
     kbd.o : defs.h command.h
     command.o : defs.h command.h
     display.o : defs.h buffer.h
     insert.o : defs.h buffer.h
     search.o : defs.h buffer.h
     files.o : defs.h buffer.h command.h
     utils.o : defs.h

     .PHONY : clean
     clean :
             rm edit $(objects)

[3]

위의 예에서 최종 실행 출력 파일은 edit이다. edit 실행 파일을 만들기 위해 여러 개의 소스 코드 파일을 이용하여 작성한 경우이다. 어떤 프로그램 소스 파일이 있는가는 objects 변수에 의해 설정되었다.

.PHONY : make clean을 실행하면 rm 명령만을 실행하게 한다. 위의 경우 단순히 명령줄로 사용할 때 사용한다. clean 뒤에 의존성 파일이 없으므로 타겟을 변경할 필요가 없어진다. 따라서 rm을 실행하지 않는다. 업데이트 필요성이 없어진다. 생성 파일이 아니 단순 타켓으로만 인식하게 할 수 있다.

clean을 실행해서 삭제하고 다시 컴파일하려면

 $ make clean

명령

 rm edit $(objects)

이 실행되어 모든 오브젝트 파일이 삭제된다. 동시에 실행 파일 edit도 삭제된다.

위의 예에서 구조를 다음과 같이 간단히 줄일 수 있다.

     objects = main.o kbd.o command.o display.o \
               insert.o search.o files.o utils.o

     edit : $(objects)
             cc -o edit $(objects)

     $(objects) : defs.h
     kbd.o command.o files.o : command.h
     display.o insert.o search.o files.o : buffer.h

와일드카드[편집]

와일드카드는 명령에서 사용될 수 있다. 이것은 셸에 의해서 확장된다.

 예   모든 오브젝트 파일들을 삭제하는 규칙

clean:
        rm -f *.o

와일드카드 예제[편집]

와일드카드는 규칙의 종속물에서도 유용하다. makefile의 다음 규칙에서 'make print'는 대상의 인쇄한 마지막 시간 이후로 변경된 모든 '.c' 파일들을 인쇄할 것이다:

print: *.c
        lpr -p $?
        touch print

와일드카드 함수[편집]

와일드 카드는 규칙 안에서 자동으로 확장된다. 그러나 와일드 카드 확장은 일반적으로 변수가 설정되었을 때, 또는 함수의 매개변수 안에서는, 일반적으로 발생하지 않는다. 그런 경우에서 와일드카드 확장을 하려고 한다면 다음과 같이 wildcard 함수를 사용해야 한다.

$(wildcard pattern...)

$(wildcard *.c) # 한 디렉토리에 있는 모든 C 소스 파일들의 리스트를 획득하는 것이다.
$(patsubst %.c,%.o,$(wildcard *.c)) # '.c' 접미사를 '.o'로 변경해서 오브젝트 파일들의 리스트로 변경할 수 있다.

한 디렉토리에 있는 모든 C 파일들을 컴파일하고 이들을 모두 모아서 링크하려고 하는 makefile은 다음과 같이 작성될 수 있다:

objects := $(patsubst %.c,%.o,$(wildcard *.c))

foo : $(objects)
        cc -o foo $(objects)

make의 재귀적 사용[편집]

재귀적 사용이란 make를 makefile에서 하나의 명령으로 사용한다는 것이다. 큰 시스템을 만드는 여러 서브시스템들을 위한 여러 분리된 makefile들을 make 실행할 때 유용하다. 예를 들어서 자신의 makefile을 가지고 있는 'subdir' 서브디렉토리를 가지고 있고 상위 디렉토리의 makefile을 사용해서 그 서브 디렉토리에 대해서 make를 실행하고자 한다고 가정하자.

다음과 같이 할 수 있다:

subsystem:
        cd subdir && $(MAKE)

또는:

subsystem:
        $(MAKE) -C subdir

재귀적인 make 명령들은, 다음에서 볼 수 있듯이 'make' 명령 이름을 명시적으로 쓰지 않고, 항상 MAKE 변수를 사용하는 것이 좋다.

서브-make에 대한 통신 변수[편집]

특정 변수가 sub-make에 익스포트되기를 원한다면 export 지시어를 사용한다.

export variable ...

unexport variable ...

open_filelist() 어떤 변수를 정의하면서 동시에 그것을 익스포트할 수 있다 :

export variable = value

이것은 다음과 같은 결과를 가진다:

variable = value
export variable

다른 참조도 가능하다.

export variable := value
export variable += value

서브-make에 대한 통신 옵션[편집]

'-s'와 '-k' 같은 플래그들은 자동으로 변수 MAKEFLAGS를 통해서 서브-make에게 전달된다.

'-C', '-f', '-o', 그리고 '-W' 옵션들은 MAKEFLAGS에 들어가지 않는다; 이들 옵션들은 아래로 전달되지 않는다.

다른 플래그들은 아래로 전달하고자 하지 않는다면 반드시 다음과 같이 MAKEFLAGS의 값을 변경해야 한다:

subsystem:
        cd subdir && $(MAKE) MAKEFLAGS=

MAKEOVERRIDES =

빈 명령 사용하기[편집]

아무것도 하지 않는 명령들을 정의하는 것이 때때로 유용하다.

target: ;

동작[편집]

make는 일반적으로 실행 가능한 프로그램과 라이브러리를 소스 코드로부터 빌드하는 데 사용된다. 그러나 일반적으로 소스 파일을 대상 결과물로 변환하는 데 기여하는 어떠한 프로세스라도 (임의의 명령어들을 실행함으로써) make에 적용할 수 있다.

make는 명령 줄 변수로서 빌드할 대상 파일의 목록과 더불어 불러낼 수 있다:

  $ make 대상 [대상 ...]

변수 없이 make를 실행하면 makefile 안에 보이는 첫 번째 대상만을 빌드한다.

같이 보기[편집]

각주[편집]

  1. 《FreeBSD 2.0.5 Make Source Code》, 1993 
  2. Glenn Fowler (2012년 1월 4일). “nmake Overview”. Information and Software Systems Research, AT&T Labs Research. 2015년 9월 2일에 원본 문서에서 보존된 문서. 2017년 3월 16일에 확인함. 
  3. http://www.gnu.org/software/make/manual/make.txt

외부 링크[편집]