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 --+ - 여기부터 의존관계 부분위의 예제는 최대한 매크로를 많이 이용하려고 했기 때문에 독해(?)하기 어려울 수도 있다.
번호 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|
5 | 3. 매크로(Macro) 와 확장자(Suffix) 규칙 | pjk | 2014.02.05 | 3216 |
4 | 4. Makefile를 작성할 때 알면 좋은 것들 | pjk | 2014.02.05 | 3720 |
3 | 5. make 중요 옵션 정리 | pjk | 2014.02.05 | 3096 |
» | 6. Makefile 작성의 가이드라인 | pjk | 2014.02.05 | 2978 |
1 | mmap() 함수, munmap() 함수 | pjk | 2014.02.05 | 16740 |