하위 디렉토리의 Object 파일을 한번에 링크 시키는 문제 (Makefile)
제 문제를 일단 설명드리겠습니다.
home 디렉토리 아래에 A, B, C, Main 이라는 네개의 디렉토리가 있습니다.
A,B,C 는 모듈이 들어있는 폴더로서 각각 A_1.c, A_2.c, B_1.c, B_2.c, C_1.c, C_2.c 라는 c 파일과 각각의 폴더에 object파일을 생성해주는 Makefile 이 있습니다.
A,B,C 디렉토리의 Makefile===================
CC = gcc
CFLAGS = -W -Wall -g
SRCS = $(wildcard *.c)
OBJS = $(patsubst %.c, %.o, $(SRCS))
$(OBJS) : $(SRCS)
$(CC) $(CFLAGS) -c $(SRCS)
clean :
rm -rf *.o $(OBJS
===========================================
그리고 Main 디렉토리에는 main.c 와 A,B,C 오 마찬가지로 object파일을 생성해주는 Makefile 이 있습니다.
이때 home 디렉토리에 다른 Makefile 이 있는데 이것을 이용해 하위에 있는 object 파일들을 링크시키려고 합니다.
home 디렉토리의 Makefile====================
.SUFFIXES : .c .o
CC = gcc
CFLAGS = -W -Wall -g
SUBDIRS = A B C Main
VPATH = A:B:C:Main
OBJECTS = $(patsubst %.c, %.o, $(wildcard *.c))
TARGET = Implement
all : objs $(TARGET)
$(TARGET) : $(OBJECTS)
$(CC) $(CFLAGS) -o $(TARGET) $(OBJECTS)
objs :
@for DIR in $(SUBDIRS); do \
$(MAKE) -C $$DIR || exit $?; \
done;
dep :
gccmakedep $(SRC)
clean :
@for DIR in $(SUBDIRS); do \
$(MAKE) -C $$DIR clean; \
done;
rm -rf *.o
============================================================
각각의 디렉토리마다 object 파일은 잘 만들어집니다만
문제는 바로 위 Makefile에서 OBJECTS 에 아무값도 안들어가집니다.
그래서 편법으로 OBJECTS = $(SUBDIRS)\$(patsubst %.c, %.o, $(wildcard *.c)) 이렇게 해봐도 안되더라구요
제가 원하는 건 echo로 출력해봤을때 이렇게 나와야 합니다.
A/A_1.o A/A_2.o B/B_1.o B/B_2.o B/B_1.o B/B_2.o Main/main.o
VPATH 를 이용해 보려고 해도 잘 못하겠어서 이렇게 질문드립니다.
ㅜ.ㅜ 도와주세요


참고하세요.
PDF문서 http://aegis.sourceforge.net/auug97.pdf
원하는 글에 못미치더라도 참고한다면
좋은 결과를 얻을 수 있으실 것 같네요.
참고만 하세요
아래 테스트...
$ make clean rm -rf A/A_1.o A/A_2.o B/B_1.o B/B_2.o C/C_1.o C/C_2.o Main/main.o target $ make cc -IA -IB -IC -IMain -c -o A/A_1.o A/A_1.c cc -IA -IB -IC -IMain -c -o A/A_2.o A/A_2.c cc -IA -IB -IC -IMain -c -o B/B_1.o B/B_1.c cc -IA -IB -IC -IMain -c -o B/B_2.o B/B_2.c cc -IA -IB -IC -IMain -c -o C/C_1.o C/C_1.c cc -IA -IB -IC -IMain -c -o C/C_2.o C/C_2.c cc -IA -IB -IC -IMain -c -o Main/main.o Main/main.c cc -o target A/A_1.o A/A_2.o B/B_1.o B/B_2.o C/C_1.o C/C_2.o Main/main.o $ cat Makefile all: target MODULES := A B C Main CFLAGS += $(patsubst %,-I%,$(MODULES)) LIBS := SRC := include $(patsubst %,%/Makefile.mk,$(MODULES)) OBJ := $(patsubst %.c,%.o, $(filter %.c,$(SRC))) target: $(OBJ) $(CC) -o $@ $(OBJ) $(LIBS) clean: rm -rf $(OBJ) target $ cat A/Makefile.mk SRC += A/A_1.c A/A_2.c home에 존재하는 파일 목록입니다. /home/Makefile /home/A/A_1.c /home/A/A_2.c /home/A/Makeifle.mk /home/B/B_1.c /home/B/B_2.c /home/B/Makeifle.mk /home/C/C_1.c /home/C/C_2.c /home/B/Makeifle.mk없음
댓글 달기