MPC

The Makefile, Project, and Workspace Creator (MPC)

维护一个包含有多个build工具文件的跨平台项目着实是一大挑战,特别是当工程架构和平台不断的优化改变的时候。一个工程可能同时支持好Makefiles,Visual C++工程文件,Borland的Makefiles等等各种makefiles。添加文件和删除文件,修改工程选项设置是修改编译目标文件的名称都需要花很多时间去修改各个编译工具文件。能够只把工程指定信息存在同一个地方,避免重复劳动修改多个编译工具文件,这才是你想要的东西,MPC应运而生。

下面简单介绍一下使用MPC编写的Makefile的方法,详细可以参考ACE包中的文档makefile-hints.html一节
在ACE包中,在$ACE_ROOT/bin下有两个Perl脚本mpc.pl,mwc.pl和一个叫MakeProjectCreator的目录。

Project Creator

mpc.pl这个脚本可以生成支持GNU Make或MS NMake的Makefile,也可以生成支持VC的dsp或者vcproj文件。这里我只简单介绍一下如何生成Makefile,其他的大家可以去看文档:-)

mpc.pl需要读入一个以mpc为后缀的Project文档,该Project文档应当包含了生成makefile的基本信息。一个Project典型的mpc文档如下所示:

project(project_name) : baseproject,anotherbaseproject{
exename = foo
includes += "."
libpaths = directory

Source_Files {
file1.cpp
file2.cpp
.
.
fileN.cpp
}

Header_Files {
file1.h
file2.h
.
.
fileN.h
}
}

mpc.pl 工具的Project配置文件采用一种继承的方式读取预先的设定应用到当前的项目。其中project_name是可选的,如果没写那么将缺省用当前目录 代替。在Linux下生成可执行文件一般baseproject设为aceexe,若生成lib库则设为acelib.另外还有一些关键字如 exename(指定生成可执行文件的名称),sharedname(生成指定共享库的名称)等等。Source_Files 和 Header_Files段指定了该Project的源文件和头文件。其他关键字具体可以查看相关的文档。

mpc.pl读取project的mpc文件,并联合在MakeProjectCreator/Config 目录下的baseproject的配置文件baseprojectname.mpb以及MakeProjectCreator/template目录下各 种平台工具的编译文件的模板(.mpt文件 )以及缺省模板值文件(.mpd文件)生成指定项目的Makefile。

Workspace Creator

mwc.pl则是读入一个由.mwc文件生成一个workspace的编译文件。它的格式如下

workspace(workspace_name) {
file.mpc
directory
}

mwc.pl将逐个读入指定的.mpc文件以及指定目录下所有的.mpc文件生成各个project的Makefile,并生成整个workspace的Makefile。

另外这两个脚本都有丰富的参数可以用来改变模板中的一些默认值,有兴趣的话可以具体看看makeprojectcreator目录下的README和USAGE.

以mpc.pl为例使用这两个脚本的命令行如下:

mpc.pl -argv argv_values input_project.mpc //前提是$ACE_ROOT/bin在你的PATH中

输出

Makefile.project_name

转载请注明:运维派 » MPC

0
2.9k
4
  1. 现在好用的工具是越来越多了。

    想起两年前写一个要同时的Windows和Linux的项目时,当时的做法是自己用Python来将vcproj文件转换成Makefile。

    不过自己DIY的东西也有自己的好处,可以加入gcov等多种调试选项与特色定制,使用更加灵活。

    • @小魔 我们也是整vcproj迁移makefile,不过是用shell转的 哈
      mpc感觉比较适合大型的项目,优化他们的模版,然后结合联合编译就很不错