# Make ### make란? * 프로그램 그룹 중에서 어느 부분이 새롭게 컴파일 되어야 하는지를 자동적으로 판단해서 필 요한 커맨드를 사용해서 그들을 재 컴파일 시킴 * 많은 프로그램 모듈들로 구성된 대규모 프로그램을 효율적으로 유지하고, 일관성 있게 관리 하도록 도와주는 도구 * 소스 수정 시 유관 파일들을 재컴파일 & 링크하는 반복적인 작업을 간단하게 처리함 * 선결조건(prerequisites)으로부터 대상(target)을 만들어 내는 다목적 프로그램 ### make의 동작 * make는 여러 파일들 간의 의존성을 저장하고 수정된 파일에 연관된 소스 파일들만을 재 컴파일 하도록 해줌 * 수정한 소스 파일들만 자동적으로 재 컴파일하고 링크하도록 함 * 소스 수정 시 유관 파일들을 재컴파일 & 링크하는 반복적인 작업을 간단하게 처리함 * make 유틸리티는 이전에 make 명령을 실행했던 시점 이후에 이뤄진 프로젝트 작업들에 대해서만 갱신 작업을 수행함 ### make의 필요성 * 프로그램 개발 및 유지보수의 편리성을 지원 * 명령어의 배치 처리 가능, 자주 쓰는 명령어를 자동화할 수 있음 * 입력파일 변경 시 자동적으로 결과 파일이 바뀌기를 원할 때 # Makefile `대상(target) : 의존하는 파일들(prerequisites)` `<tab> 명령어(command)` `<tab> 명령어(command)` * clean 주로 make하는 과정에서 생긴 .o 파일이나 실행 파일을 삭제하는 역할 * dep gccmakedep 명령어를 통해 의존 관계를 자동으로 생성한다. `<identifier> = <files>` identifier를 통해 여러 개의 파일들을 간단하게 부를 수 있는 매크로 코드 상에서 쓸 때는 `$(<identifier>)`로 써야 한다. * 내장매크로(Internal macro) | 매크로 | 의미 | |:--:|--| | $@ | 현재의 목표 (Target) 파일명 | | $? | 현재의 목표파일(Target)보다 더 최근에 갱신된 의존 파일 명단 | | $* | 현재의 목표파일(Target)보다 더 최근에 갱신된 확장자를 제외한 의존 파일 명단 | | $< | 의존 파일(전제 조건) 중 첫번째 파일명 | | $^ | 현재 모든 의존 파일들의 명단 | | $+ | '$^'과 같지만, 두 번 이상 나열된 전제 조건은 makefile에 나열된 순서대로 복제됨 | | $% | 타깃이 라이브러리 모듈일 때 멤버에 대응되는 파일명 | * 내장매크로(Pre-defined macro) | 매크로 | 의미 | |:--:|--| | AR | Archive-maintaining program; default ‘ar’. | | ARFLAGS | ar 명령어의 옵션 설정 | | AS | Program for compiling assembly files; default ‘as’. | | ASFLAGS | as 명령어의 옵션 설정 | | CC | Program for compiling C programs; default ‘cc’. | | CFLAGS | cc 명령어의 옵션 설정 | | CXX | Program for compiling C++ programs; default ‘g++’. | | CXXFLAGS | g++ 명령어의 옵션 설정 | | LDFLAGS | ld 명령어의 옵션 설정 | * 확장자 규칙 (Suffix Rules) 확장자 규칙은 미리 정의해 놓은 일반화한 기술 파일 항목을 가리킴 ``` .SUFFIXES : .o .c .s .c.o : $(CC) $(CFLAGS) -c $< .s.o : $(AS) $(ASFLAGS) -o $@ $< ```