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
可以看到,只有红黑树和数组的源文件被编译和打包成库了。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.