Ubuntu上用premake编译GDAL
GDAL的编译脚本呈现出不同平台不同解决方案的百花齐放现状。我是从windows平台开始编译GDAL的,用的自然是nmake。那就是一种每个目录下都需要写makefile文件的构建方法,写的人麻烦,我因为要定制,也是不甚其烦。
基于前文:premake 在64位Ubuntu系统下编译32位GCC程序的基础,我在Ubuntu上构建了premake脚本,可以编译出debug64, debug32, release64和releae32的gdal动态和静态库。由于我所用的gdal是定制版本的,可能有所不同,下面的共参考。
创建一个config.lua脚本文件,内容如下:
-- A solution contains projects, and defines the available configurations
solution ("gdal")
configurations {"Debug64","Release64", "Debug32", "Release32"}
location "build"
includedirs
{
"/usr/src/linux-headers-3.8.0-30-generic/include/config/pci/",
"/usr/include/x86_64-linux-gnu/c++/4.8"
} configuration "Debug64"
targetdir "output/linux_debug_x64"
defines
{
"DEBUG",
"HAVE_SSE_AT_COMPILE_TIME"
} flags {"Symbols"} configuration "Debug32"
targetdir "output/linux_debug_x32"
defines
{
"DEBUG",
"HAVE_SSE_AT_COMPILE_TIME"
} buildoptions {"-m32"}
linkoptions {"-m32"}
flags {"Symbols"} configuration "Release64"
targetdir "output/linux_release_x64"
defines
{
"NDEBUG",
"HAVE_SSE_AT_COMPILE_TIME"
} flags {"OptimizeSize"} configuration "Release32"
targetdir "output/linux_release_x32"
defines
{
"NDEBUG",
"HAVE_SSE_AT_COMPILE_TIME"
} buildoptions {"-m32"}
linkoptions {"-m32"}
flags {"OptimizeSize"} -- project port defines one build target
p = project("port")
basedir(p.name)
location("build/" .. p.name)
kind "SharedLib"
language "C++"
files { p.name .. "/*.h", p.name .. "/*.cpp" } excludes
{
p.name .. "/cpl_vsil_stdout.cpp",
p.name .. "/cpl_odbc.cpp",
p.name .. "/cpl_win32ce_api.cpp",
p.name .. "/cpl_vsil_simple.cpp",
p.name .. "/cpl_vsil_win32.cpp",
p.name .. "/cpl_vsil_gzip.cpp",
p.name .. "/cpl_vsil_buffered_reader.cpp",
p.name .. "/cpl_minizip_zip",
p.name .. "/cpl_minizip_zip.cpp",
p.name .. "/cpl_minizip_unzip.cpp",
p.name .. "/xmlreformat.cpp",
p.name .. "/cpl_vsil_tar.cpp",
p.name .. "/cpl_quad_tree.cpp",
p.name .. "/cpl_vsil_readahead_reader.cp",
p.name .. "/cpl_google_oauth2.cpp",
p.name .. "/cpl_vsil_curl.cpp",
p.name .. "/cpl_vsil_curl_streaming.cpp",
p.name .. "/cpl_minizip_ioapi.cpp",
p.name .. "/cpl_vsil_abstract_archive.cpp",
p.name .. "/cpl_vsil_cache.cpp",
p.name .. "/cpl_spawn.cpp"
} includedirs
{
"./port",
"./ogr",
"./gcore",
"./alg",
"./ogr/ogrsf_frmts",
"./frmts/zlib"
} -- project ogr defines one build target
p = project("ogr")
basedir(p.name)
location("build/" .. p.name)
-- build .a here because nmake generats ogr.lib
kind "StaticLib"
language "C++"
files
{
p.name .. "/*.c",
p.name .. "/*.cpp"
} excludes
{
p.name .. "/ogrlinearring.cpp",
p.name .. "/ogrutils.cpp",
p.name .. "/ogr2gmlgeometry.cpp",
p.name .. "/ogrmultipoint.cpp",
p.name .. "/ogrmultipolygon.cpp",
p.name .. "/ogrfeaturestyle.cpp",
p.name .. "/swq_op_registrar.cpp",
p.name .. "/ogr_api.cpp",
p.name .. "/ogrsurface.cpp",
p.name .. "/ogrfielddefn.cpp",
p.name .. "/ogr_opt.cpp",
p.name .. "/ogrmultilinestring.cpp",
p.name .. "/ogrfeature.cpp",
p.name .. "/swq.cpp",
p.name .. "/ogrgeometrycollection.cpp",
p.name .. "/ogrcurve.cpp",
p.name .. "/gml2ogrgeometry.cpp",
p.name .. "/ograssemblepolygon.cpp",
p.name .. "/ogrfeaturequery.cpp",
p.name .. "/ogrgeometry.cpp",
p.name .. "/swq_op_general.cpp",
p.name .. "/ogrgeometryfactory.cpp",
p.name .. "/ogrlinestring.cpp",
p.name .. "/swq_parser.cpp",
p.name .. "/ogrpolygon.cpp",
p.name .. "/swq_select.cpp",
p.name .. "/swq_expr_node.cpp",
p.name .. "/ogrpoint.cpp",
p.name .. "/ogrfeaturedefn.cpp",
} includedirs
{
"./port",
"./ogr",
"./gcore",
"./alg",
"./ogr/ogrsf_frmts",
"./ogrsf_frmts",
"./frmts/gtiff/libgeotiff"
} -- project ogr defines one build target
p = project("gcore")
basedir(p.name)
location("build/" .. p.name)
kind "SharedLib"
language "C++"
files { p.name .. "/*.h", p.name .. "/*.cpp" } excludes
{
p.name .. "/gdaljp2metadata.cpp",
p.name .. "/gdaljp2box.cpp",
p.name .. "/gdalgmlcoverage.cpp"
} includedirs
{
"./port",
"./ogr",
"./gcore",
"./alg",
"./ogr/ogrsf_frmts",
"./ogrsf_frmts",
"./frmts/gtiff"
} -- project frmts defines one build target
-- After this last project build is finished, then link all obj and libs to library
p = project("frmts")
basedir(p.name)
location("build/" .. p.name)
kind "SharedLib"
language "C++"
files
{
p.name .. "/*.cpp",
p.name .. "/jpeg/*.cpp",
p.name .. "/jpeg/*.c",
p.name .. "/nitf/*.cpp",
p.name .. "/nitf/*.c",
p.name .. "/gtiff/*.cpp",
p.name .. "/gtiff/*.c",
p.name .. "/gtiff/libtiff/*.c",
p.name .. "/gtiff/libgeotiff/*.c",
p.name .. "/jpeg/*.cpp",
p.name .. "/jpeg/*.c",
p.name .. "/dted/*.cpp",
p.name .. "/dted/*.c",
p.name .. "/zlib/*.cpp",
p.name .. "/zlib/*.c"
} excludes
{
p.name .. "/nitf/rpftocdataset.cpp",
p.name .. "/nitf/nitfdump.c",
p.name .. "/dted/dted_test.c",
p.name .. "/dted/dteddataset.cpp",
p.name .. "/gtiff/libtiff/tif_print.c",
p.name .. "/gtiff/libgeotiff/geo_trans.c",
p.name .. "/zlib/gzio.c"
} includedirs
{
"./port",
"./ogr",
"./gcore",
"./alg",
"./ogr/ogrsf_frmts",
"./frmts/zlib",
"./frmts/jpeg/libjpeg",
"./frmts/gtiff/libtiff",
"./frmts/vrt",
"./frmts/gtiff/libgeotiff",
"./frmts/jpeg/jpeg-8c"
} defines
{
"FRMT_nitf",
"DFRMT_gtiff",
"FRMT_jpeg",
"FRMT_dted",
"FRMT_zlib"
}
整个设计是用一个solution包含四个project,分别对应GDAL的port, ogr, gcore和frmts目录下的代码。premake会自动为每个项目build出动态或者静态库。但是premake4还没有办法在编译时知道自己的configuration是什么(这个功能要到premake5.0才有)。为了弥补这个缺憾,我写了四个脚本,分别在最后将所有的*.o和*.a文件link成libgdal.so和libgdal.a文件。
比如rebuild_linxu_debug_32.sh文件,
export CXX=clang++
export CC=clang
rm -rf build
rm -rf output/linux_debug_x32
../../../depfiles/build/linux/premake4 --file=config.lua gmake
cd build
make config=debug32
cd -
$CXX -o output/linux_debug_x32/libgdal.so build/port/obj/Debug32/*.o output/linux_debug_x32/libogr.a build/gcore/obj/Debug32/*.o build/frmts/obj/Debug32/*.o -m32 -shared
ar -rcs output/linux_debug_x32/libgdal.a build/port/obj/Debug32/*.o output/linux_debug_x32/libogr.a build/gcore/obj/Debug32/*.o build/frmts/obj/Debug32/*.o
这里可以看到,我用的是clang编译器,去掉开头两行,就变成了gcc了。其他脚本类似。
最后有一个rebuild.sh脚本,编译出所有的版本。
rm -rf output
./rebuild_linux_debug_64.sh
./rebuild_linux_release_64.sh
./rebuild_linux_debug_32.sh
./rebuild_linux_release_32.sh
就在顶层目录下搞定,再也不需要维护那么多makefile了。
Ubuntu上用premake编译GDAL的更多相关文章
- 在Ubuntu上下载、编译和安装Android最新内核源代码(Linux Kernel)
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6564592 在前一篇文章提到,从源代码树下载下 ...
- .NET跨平台:在Ubuntu上用自己编译的dnx运行ASP.NET 5示例程序
在 Linux Ubuntu 上成功编译 dnx 之后,会在 artifacts/build/ 文件夹中生成 dnx-coreclr-linux-x64/ 与 dnx-mono/ 这2个文件夹,前者是 ...
- ubuntu上安装mysql 编译安装
为什么要折腾?首先说明的是ubuntu上安装mysql等软件是非常容易简单的,其简单的程度盖过windows上的安装,一句sudo apt-get install就可以搞定.如果想用最简便的方法安装m ...
- 【转】在Ubuntu上下载、编译和安装Android最新源代码
原文网址:http://blog.csdn.net/luoshengyang/article/details/6559955 看完了前面说的几本书之后,对Linux Kernel和Android有一定 ...
- 在Ubuntu上下载、编译和安装Android最新源码
看完了前面说的几本书之后,对Linux Kernel和Android有一定的认识了,是不是心里蠢蠢欲动,想小试牛刀自己编译一把Android源码了呢?一直习惯使用Windows系统,而Android源 ...
- 在Ubuntu上下载、编译和安装Android最新源代码
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6559955 看完了前面说的几本书之后,对Lin ...
- ubuntu上u-boot的编译
1,下载u-boot 2,将Windows中的u-boot复制到ubuntu虚拟机中自定义目录并解压 3,进入该目录cd 4,安装dtc:sudo apt-get install device-tre ...
- ubuntu上源码编译安装mysql5.7.27
一.查看操作系统环境和目录结构,并创建mysql用户和组,以及规划安装mysql所需要的目录. #cat /etc/issue 查看发行版本信息: #cat /proc/version 查看正在运行 ...
- [Ubuntu篇] 在ubuntu上源码编译gtest,编写gtest-config.cmake并测试
本文首发于个人博客https://kezunlin.me/post/4a1427cf/,欢迎阅读! compile gtest on ubuntu 16.04 Guide compile gtest ...
随机推荐
- ZOJ 38727(贪心)
这道题真心坑.越想越远 想的飞起来了. 最后纠结起后缀表达式的定义来了. 题意: 就是给你一个串 , 让你用最少改动次数来实它变成一个合法的后缀表达式, 改动方式有两种, 一种是直接加入数字或者 ...
- o怎么样racle输入dmp数据库文件
Oracle进出口数据imp/exp等价物oracle数据恢复和备份. exp命令可以从远程数据库传输数据server出到本地的dmp文件,imp命令能够把dmp文件从本地导入到远处的数据库serve ...
- 【转】adb.exe,start-server' failed -- run manually if necessary
[转]Android adb.exe程序启动不起来,如何处理 解决问题: 百度google大家多说的是任务管理器 kill掉adb 或者重启adb server,但我任务管理器就没有adb ,猜测是某 ...
- Problem C Andy's First Dictionary(set的使用)
题目链接:Problem C 题意:输入一个文本,找出所有不同的单词,按照字典序从小到大输出,单词不区分大小写. 思路:将字母序列都存为小写,非字母的字符变成空格,然后利用stringstream实现 ...
- Android 学习开发笔记《Service 与 Thread 的区别 》
很多时候,你可能会问,为什么要用 Service,而不用 Thread 呢,因为用 Thread 是很方便的,比起 Service 也方便多了,下面我详细的来解释一下. 1). Thread:Thre ...
- ssh无密登录
ssh登录一般两种方式: 1.密码登录 2.密钥验证无需密码 使用方式:1.生成密钥 2.将公钥追加到authorized_keys中,需要注意的是执行权限需为600,这里因而第一次添加使用的是> ...
- mybatis字段名与类属性名不相同的冲突
新建一个表 CREATE TABLE orders( order_id INT PRIMARY KEY AUTO_INCREMENT, order_no ), order_price FLOAT ); ...
- 射频识别技术漫谈(16)——Mifare UltraLight
Mifare UltraLight又称为MF0,从UltraLight(超轻的)这个名字就可以看出来,它是一个低成本.小容量的卡片.低成本,是指它是目前市场中价格最低的遵守ISO14443A协议的芯片 ...
- cocos2dx中的层CCLayer
什么是层,层在cocos2dx里是一个能处理触摸事件的CCNode,因为它负责用户交互,因此大部分游戏细节都在这个类中完成,所以我们经常派生这个图层来完成逻辑交互代码.当然如果你的图层不需要接受交互信 ...
- mahout贝叶斯算法开发思路(拓展篇)1
首先说明一点,此篇blog解决的问题是就下面的数据如何应用mahout中的贝叶斯算法?(这个问题是在上篇(...完结篇)blog最后留的问题,如果想直接使用该工具,可以在mahout贝叶斯算法拓展下载 ...