Melon是一个跨平台开源C语言库,提供了各类开发常用的组件。无第三方软件依赖,开箱即用,且配套中英文文档齐全。
正因为Melon提供了非常多的组件,才有了今天这个主题——模块选择性编译。所谓的选择性编译,简单来说就是:想要用什么组件就编译什么组件,无关组件不会编译成库。
这样做有两个目的:
下面我们就演示一下如何进行模块选择性编译。
第一步:获取Melon仓库
git clone https://github.com/Water-Melon/Melon.git
第二步:进入仓库
cd Melon
第三步:执行configure,我们的选择性编译也是在这一步
./configure --select=rbtree,array
这里假设我们仅编译红黑树和数组两个组件。
第四步:执行make
make
第五步:执行make install
make install
如果安装的位置权限不够,则需要
sudo make install
第三步中--select
的参数是以逗号分隔的模块名称,注意不要有空格。
在Melon官方文档中,每个组件的文档内,都给出了对应的模块名称。
还有一种简单的办法去获取模块名。在Melon中,几乎每个模块都有一对.c和.h文件。当我们需要用到某个模块,一般都是include那个模块的头文件。而头文件的命名一般是mln_<module>.h
,这里的module
部分就是模块名称(<>
只是用来突出模块名称)。
下面内容为笔者在虚机上执行上述命令进行选择性编译安装的终端输出内容。
$ git clone https://github.com/Water-Melon/Melon.git
Cloning into 'Melon'...
remote: Enumerating objects: 6095, done.
remote: Counting objects: 100% (1281/1281), done.
remote: Compressing objects: 100% (480/480), done.
remote: Total 6095 (delta 909), reused 1131 (delta 793), pack-reused 4814
Receiving objects: 100% (6095/6095), 3.22 MiB | 1.02 MiB/s, done.
Resolving deltas: 100% (4417/4417), done.
$ cd Melon
nik@nik:~/test/Melon$ ./configure --select=rbtree,array
Installation Path [/usr/local/melon]
Melang script Path [/usr/local/lib/melang]
Melang dylib Path [/usr/local/lib/melang_dynamic]
Configure done!
Melon$ make
test -d objs || mkdir objs
test -d lib || mkdir lib
cc -Iinclude -c -Wall -Werror -O3 -fPIC -o objs/mln_rbtree.o src/mln_rbtree.c
cc -Iinclude -c -Wall -Werror -O3 -fPIC -o objs/mln_array.o src/mln_array.c
cc -o lib/libmelon.so objs/mln_rbtree.o objs/mln_array.o -Wall -lpthread -Llib/ -ldl -shared -fPIC
ar -r lib/libmelon.a objs/mln_rbtree.o objs/mln_array.o
ar: creating lib/libmelon.a
Melon$ sudo make install
test -d /usr/local/lib/melang || mkdir -p /usr/local/lib/melang
test -d /usr/local/melon || mkdir -p /usr/local/melon
cp -fr lib /usr/local/melon
cp -fr include /usr/local/melon
test -d /usr/local/melon/conf || cp -fr conf /usr/local/melon
test -d /usr/local/lib/melang/trace || cp -fr trace /usr/local/lib/melang
可以看到,只有红黑树和数组的源文件被编译和打包成库了。