Makefile总结续

来源:互联网 发布:linux常用命令ln 编辑:程序博客网 时间:2024/06/10 17:16

转载地址:http://blog.csdn.net/aiwoziji13/article/details/7330333

1.ccppc: No such files

这个问题很奇怪,明明有那个文件。

出现两种情况

第一种情况、命令手动输入和makefile自动输入一样都出现错误

我就缩短命令,减少一些-D宏定义,结果发现时受到-DBCM_PLATFORM_SRING的影响。

第二种情况、命令手动输入不会出现错误,但是makefile执行命令会出现ccppc: CreateProcess: No such file or directory

通过查找,终于知道原因,是Makefile中有一句: export GCC_EXEC_PREFIX=$(WIND_BASE)/host/$(WIND_HOST_TYPE)/lib/gcc-lib/

这句话的作用是set GCC prefix and PATH to find what it neess, and export them to subshells.


2.链接.a文件,undefined reference to `func' 

以前总是认为.a既然生成,肯定里面的函数都定义了。这可不一定。

没有定义的函数,可能通过extern func,规避掉了。但是真正链接的时候,系统就会copy .a库文件的函数,此时发现没有,就会报错。

除此之外,我们还需要注意在链接命令中给出所依赖的库时,需要注意库之间的依赖顺序,依赖其他库的库一定要放到被依赖库的前面,这样才能真正避免undefined reference的错误,完成编译链接。

3.终于明白了sdk变量的使用方法

SDK :=$(shell if [ -n "$$SDK" ] ;then\
    echo $$SDK;\
    else\

...
    pwd;                    \
    fi)

...
include ${SDK}/make/Make.config

因为我们在windows下通过.bat文件设置SDK的值,就相当于shell变量。所以我们用$$SDK读环境变量SDK的值,再赋给Makefile的SDK变量。

这以后,${SDK}其实读的是Makefile的SDK值。

参考Makefile中的shell语法

4.使用tornado的环境变量,在windows运行makefile问题

每个语句都可以在windows cmd.exe(即shell) 下运行通过

但是合起来就不行

具体问题有

第一、copying multiple files, but last argument ';' is not directory /*cp时出现错误*/

第二、文件名、目录名或卷标语法不正确/*cd时出现错误*/

上面的问题原因主要在于windows下的多条shell语句连接符号不是';',是'&&'


0 0