作者:朱金灿
来源:http://blog.csdn.net/clever101
继续研究distcc。今天我在思考这样一个问题:分布式编译系统本身并不是编译器,它本质是一个编译请求的发起者和执行者,也就是说,它必须创建编译进程,而要创建编译进程,它需要找到编译器,具体到distcc,就是gcc编译器。就是分布式编译的客户端或者转入一个编译器参数,或者它自己去找编译器。
今天通过阅读代码,证实了我的猜测。Distcc客户端程序是一个控制台程序,它带有一些命令行参数,如—help用于显示帮助信息,--version用于显示版本信息等等。今天我们抛开这些细节,遵循这样研究思路:看看distcc如何gcc编译器,又是如何创建编译进程的。
很快,我们找到这样一个函数:dcc_find_compiler。看样子这个函数是用来实现寻找编译器的。让我们看看事实是不是这样的。
intdcc_find_compiler(char **argv, char ***out_argv)
{
int ret;
if (argv[1][0] == '-'
|| dcc_is_source(argv[1])
|| dcc_is_object(argv[1])) {
if ((ret = dcc_copy_argv(argv,out_argv, 0)) != 0) {
return ret;
}
/* change "distcc cc -cfoo.c" -> "cc -c foo.c" */
free((*out_argv)[0]);
(*out_argv)[0] =strdup("cc");
if ((*out_argv)[0] == NULL) {
return EXIT_OUT_OF_MEMORY;
}
return 0;
} else {
/* skip "distcc", point to"gcc -c foo.c" */
return dcc_copy_argv(argv + 1,out_argv, 0);
}
}
我们看到这个函数确实是查找编译器的。我们也看到了distcc实际上支持两种编译器的,一种是cc(貌似是SUN推出的C++编译器),另一种是gcc。找到的编译器及其编译文件参数保存在out_argv变量中。
既然我们找到编译器,那么下一步应该是创建编译进程。在main函数中在调用完dcc_find_compiler函数接着调用dcc_trim_path函数,貌似是检查系统有安装gcc或cc,反正不是创建编译进程的,暂且忽略。继续往下看。
跳过一些次要的函数,我终于找到一个重要的函数:dcc_build_somewhere_timed。在以后的岁月里我们将重点剖析该函数。这篇就到这里吧。
原文链接: https://www.cnblogs.com/lanzhi/archive/2012/02/03/6470894.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/40864
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!