Makefile에서 이미 정의된 변수를 조작해서 새 변수를 정의하는 경우..
간단한 makefile을 작성 중인데.. 쉽게 해결이 안되어서 질문드립니다.
도움 부탁드리겠습니다..
———————————————————————————————-
1 CORNER = ss_xxxx
2 COND = `echo $(CORNER) | sed -n s/.{2}.*/\1/p`
3 ifeq($(COND), ss)
4 OPTION = +OPTION
5 endif
6 run:
7 echo $(COND)
8 ~~~~ $(OPTION)
———————————————————————————————-
대략 이런식의 makefile 입니다.
CORNER 값에서 COND를 얻어내고, 이 COND에 의해서 ifeq를 돌리는 것이죠.
실제로 CORNER라는 것은 이 makefile 윗단의 또 다른 makefile에서 들어오는 변수로서..
ss_~~~ or ff_~~~ 식으로 공통된 규칙을 가지고 있습니다.
제가 원하는 것은 ss인 경우에만 ifeq를 돌려서 OPTION을 정의해주는 것이죠.
8번 행은 실제로 shell에서 simulator를 돌리는 행으로서, COND=ss인 경우 +OPTION을 넣어주고자 합니다.
문제는..
7번행에서, 제가 원하는대로 ‘ss’ 값이 정상적으로 표시가 됩니다.
그러나 8번행에서, +OPTION이 들어가지 않습니다.
뭐가 문제인지 알아보기 위해서 2번행을 아래와 같이 수정했습니다.
2 COND=ss
이처럼 COND에 바로 ss를 넣어주면, +OPTION이 제대로 들어갑니다. ifeq가 잘 동작한것이죠.
변수에 바로 값을 넣어주는 것과 이미 정의된 변수를 조작해서 새 변수를 만드는 것이 다른가요?
CORNER값은 앞단의 makefile에서 넘어오는 값이라서.. ss를 고정시켜서는 안됩니다.
혹시 2번행 방식 말고.. 변수의 앞 2자리로 새 변수를 정의할 수 있는 방법이 있을까요?
참고로..
회사의 unix 시스템이 좀 오래되서 makefile 버전이 좀 낮긴 합니다. (정확히 몇인지는 모르겠네요 ^^)
gnu make도 아닌것 같고요..
고수님들의 조언 부탁드리겠습니다.
감사합니다..
?????????
?????????
---------------------------------------------
git init
git add .
git commit -am "project init"
---------------------------------------------
syntax checking하셔야 할 듯...
OPTION = +OPTION
위의 라인이 무슨 의미인지, 그리고 syntax도 틀린 것 같은 데...
아래와 같이 할려고 하신게 아닌지...
OPTION += {OPTION}
왜그런지 모르겠지만... ifeq 와
왜그런지 모르겠지만... ifeq 와 findstring을 조합하니 생각대로 동작합니다.
댓글 달기