make를 많이 써 본 사람은 어느 정도 자신만의 Makefile
을 작성하는
일정한 스타일 같은 것이 있다. 프로그램이 짜는 사람마다 다르듯이
Makefile
도 각각이다. 여기서는 그냥 가장 일반적인 가이드라인을
제시하기로 한다. 다음 장에서 Makefile
의 여러 예제를 살펴보면서
다시 한번 자세히 설명할 것이다.
매크로를 잘 사용하면 Makefile
이 깔끔해질 뿐 아니라, 내용의 수정도
용이하다. 조금 과장해서 말한다면, 최대한 매크로를 많이 사용하라고
말하고 싶다. Makefile
내에서 두번 이상 나오는 것들은 매크로로 정의해 두면
편하다. 자신의 프로그램 특성에 따라서 기존의 매크로를 재정의 하는 것도
좋다.
make에서 정의되어 있는 규칙들을 최대한 이용한다. 확장자 규칙은 무조건 이용하기를 권한다. 기존의 규칙들을 자기가 정의하는 것도 좋지만, 억지로 이럴 필요는 없다.
대체로 아래와 같이 Makefile
을 구성한다.
.SUFFIXES : .c .o --+
CFLAGS = -g |
|
OBJS = main.o \ |
read.o \ | 매크로 정의 부분
write.o |
SRCS = $(OBJS:.o=.c) |
|
TARGET = test --+
$(TARGET): $(OBJS) --+
$(CC) -o $@ $(OBJS) |
dep : |
gccmakedpend $(SRCS) |
new : | 명령어 정의 부분
touch $(SRCS) ; $(MAKE) |
clean : |
$(RM) $(OBJS) $(TARGET) core --+
- 여기부터 의존관계 부분
위의 예제는 최대한 매크로를 많이 이용하려고 했기 때문에 독해(?)하기 어려울 수도 있다.
다음장 예고
다음 장에는 Makefile
의 여러 가지 작성 예제를 가지고 설명을
하겠습니다. 아직 make에 익숙하기 않을 것이라고 생각하기 때문입니다.
최대한 다양한 예제를 다룸으로써 나중에 많은 도움이 되도록 하죠. make
수행 중에 나올 수 있는 여러 에러들도 다음 장에서 한번 다루어 보죠.
그리고 가능하다면 Imakefile
란 것도 한번 건드려 봅시다.