make (소프트웨어)
make
는 소프트웨어 개발을 위해 유닉스 계열 운영 체제에서 주로 사용되는 프로그램 빌드 도구이다.
패러다임 | 매크로, 선언형 |
---|---|
설계자 | 스투어트 펠트먼 |
발표일 | 1976년 4월 |
구현 언어 | C |
운영 체제 | 유닉스 계열, 인페르노 |
파일 포맷 | Makefile |
주요 구현체 | |
BSD, GNU, nmake | |
방언 | |
BSD make, GNU make, Microsoft nmake | |
영향을 준 언어 | |
앤트, 레이크, MSBuild 등 |
여러 파일들끼리의 의존성과 각 파일에 필요한 명령을 정의함으로써 프로그램을 컴파일할 수 있으며 최종 프로그램을 만들 수 있는 과정을 서술할 수 있는 표준적인 문법을 가지고 있다.
위의 구조로 기술된 파일(주로 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)
위의 예에서 최종 실행 출력 파일은 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 안에 보이는 첫 번째 대상만을 빌드한다.
같이 보기
편집각주
편집- ↑ 《FreeBSD 2.0.5 Make Source Code》, 1993
- ↑ Glenn Fowler (2012년 1월 4일). “nmake Overview”. Information and Software Systems Research, AT&T Labs Research. 2015년 9월 2일에 원본 문서에서 보존된 문서. 2017년 3월 16일에 확인함.
- ↑ http://www.gnu.org/software/make/manual/make.txt