How to build CppCMS 1.x.x
How to build CppCMS 1.x.x
Requirements
In order to build CppCMS you need:
Mandatory Requirements
- Modern C++ Compiler -- GCC, MSVC 9, Intel. See supported compilers and platforms
- CMake 2.6 and above, 2.8.x is recommended.
- Zlib library
- PCRE library.
- Python >=2.4 (but not 3)
Recommended Dependencies
- ICU Library 3.6 and above -- support of advanced localization features.
gcrypt or OpenSSL library -- for support of encrypted session cookies.
If both available gcrypt would be used.
Suggested
- iconv library (if libc does not provide iconv interface)
Dependencies for Common Linux Distributions
Debian Based (Debian, Ubuntu):
Packages: cmake libpcre3-dev zlib1g-dev libgcrypt11-dev libicu-dev python
Getting:
- aptitude install cmake libpcre3-dev zlib1g-dev libgcrypt11-dev libicu-dev python
RPM Based (RadHat, CentOS, Fedora, Suse):
Packages: cmake gcc-c++ gcc make zlib-devel pcre-devel libicu-devel libgcrypt-devel
Getting:
- yum install cmake gcc-c++ gcc make zlib-devel pcre-devel libicu-devel libgcrypt-devel
Notes for Microsoft Visual C++ users
Building cppcms with Visual Studio projects is not supported due to complexity of debug and release mode.
You should use nmake as shown in the example.
Getting The Sources
Download the latest cppcms-1.x.x.tar.bz2 from sourceforge and extract it:
- tar -xjf cppcms-1.0.4.tar.bz2
If you want to get latest version You need git to get the sources:
- git clone https://github.com/artyom-beilis/cppcms.git cppcms
Build Process
Go to the cppcms directory you created and create build directory and go to it:
- mkdir build
- cd build
Now configure the library with CMake
- cmake ..
Or
- cmake various_build_options ..
Then run
- make
- make test
- make install
Build Options
-DDISABLE_STATIC=ON
-- disable building of static version of cppcms library-DDISABLE_SHARED=ON
-- disable building of shared version of cppcms library-DDISABLE_ICONV=ON
-- disable usage of iconv (ICU would be used instead)-DDISABLE_GCRYPT=ON
-- disable usage of gcrypt library.-DDISABLE_OPENSSL=ON
-- disable usage of OpenSSL.-DUSE_WINDOWS6_API=ON
-- use Windows Vista, Windows 7 API if possible, allows CppCMS using native Windows Vista/7 conditional variables and other advanced API. By default disabled.-DLIBDIR=lib64
- use alternative name for library directory, for example use lib64 on Red Hat based distributions.
Generic Size Optimization Options for Embedded Builds:
-DDISABLE_FCGI=ON
-- build without FastCGI Server API.-DDISABLE_SCGI=ON
-- build without SCGI Server API.-DDISABLE_HTTP=ON
-- build without internal HTTP server.-DDISABLE_ICU_LOCALE=ON
-- do not use ICU for localization but rather C++std::locale
, Windows API or POSIX API based localization -- many localization features would not be available, but it may be useful for embedded builds.-DDISABLE_PREFORK_CACHE=ON
- disable cache support for preforking modes (process shared cache)-DDISABLE_TCPCACHE=ON
- disable distributed cache support (memcached-like solution support)-DDISABLE_CACHE=ON
- disable caching system at all.-DDISABLE_GZIP=ON
- disable output gzip compression support (eliminates dependency on zlib)
Generic useful CMake options:
-DCMAKE_BUILD_TYPE=(Debug|Release|RelWithDebInfo|MinSizeRel)
-- release type. RelWithDebInfo is default, unless using MSVC where Debug is default.-DCMAKE_INCLUDE_PATH=/path/to/include
-- path to location of libraries headers, provide it in order to find libraries headers installed in non-standard locations. You almost always need to provide it under Windows.-DCMAKE_LIBRARY_PATH=/path/to/lib
-- path to location of libraries, provide it in order to find libraries installed in non-standard locations. You almost always need to provide it under Windows.-DCMAKE_INSTALL_PREFIX=/usr/local
-- Installation prefix (similar to autoconf --prefix). Defaults to /usr/local
Examples
POSIX Operating Systems
I assume that you are in a terminal in the build directory inside the CppCMS source directory.
Build under Linux, FreeBSD and Cygwin:
- cmake ..
- make
- make test
- make install
Build under OpenSolaris with SunStudio
- cmake -DCMAKE_C_COMPILER=/usr/bin/suncc -DCMAKE_CXX_COMPILER=/usr/bin/sunCC ..
- make
- make test
- make install
Build under OpenSolaris with GCC, where ICU installed in /opt/icu
- cmake -DCMAKE_INCLUDE_PATH=/opt/icu/include -DCMAKE_LIBRARY_PATH=/opt/icu/lib ..
- make
- make test
- make install
Microsoft Windows
We assume that 3rd part libraries installed in c:\3rd_part
and sources are placed ind:\projects\cppcms
Note: You need to setup correct PATH variables in order to let system find all DLLs it needs.
Under cmd.exe:
- set PATH=c:\3rd_part\lib;%PATH%
- set PATH=d:\projects\cppcms\build\booster;%PATH%
Under bash:
- export PATH=/c/3rd_part/lib:"$PATH"
- export PATH=/d/projects/cppcms/build/booster:"$PATH"
MinGW Builds:
For mingw builds you also need to pass a path to the mingw's library directory, otherwise it may not find winsock library correctly. Assuming you have mingw installed in c:\mingw
Open MinGW Shell terminal
- cmake -G "MSYS Makefiles" -DCMAKE_INCLUDE_PATH=c:/3rd_part/include -DCMAKE_LIBRARY_PATH="c:/3rd_part/lib;c:/mingw/lib" -DCMAKE_INSTALL_PREFIX=c:/mingw ..
- make
- make test
- make install
MSVC Builds:
Open MSVC Shell terminal (All Programs > Microsoft Visual Studio 2008 > Visual Studio Tools > Visual Studio 2008 Command Prompt)
- cmake -G "NMake Makefiles" -DCMAKE_INCLUDE_PATH=c:/3rd_part/include -DCMAKE_LIBRARY_PATH=c:/3rd_part/lib -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=c:/cppcms ..
- nmake
- nmake test
- nmake install
Cross Compiling
The build is just ordinary CMake cross-compilation procedure. For more information readhttp://www.cmake.org/Wiki/CMake_Cross_Compiling
We would provide an example for ARM under Linux, without ICU.
Create ToolChain.cmake
- SET(CMAKE_SYSTEM_NAME Linux)
- SET(CMAKE_C_COMPILER /usr/bin/arm-linux-gnueabi-gcc)
- SET(CMAKE_CXX_COMPILER /usr/bin/arm-linux-gnueabi-g++)
- SET(CMAKE_FIND_ROOT_PATH /usr/arm-linux-gnueabi)
- SET(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
- SET(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
- SET(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
Configure
- cmake -DCMAKE_TOOLCHAIN_FILE=ToolChain.cmake -DDISABLE_ICU_LOCALIZATION=ON -DCMAKE_ISTALL_PREFIX=/usr/arm-linux-eabi ..
- make
- make install
How to build CppCMS 1.x.x的更多相关文章
- CppCMS1.0.3 Build by VS2012
1.CppCMS简介 CppCMS是一个C++的Web开发框架(不是一个CMS).它不同于大多数其他Web开发框架,如巨蟒Django , Java的Servlets ,或C++ Wt因为它在设计和调 ...
- CPPCMS库在Windows下的使用
标题:CPPCMS库在Windows下的使用时间:2012-7作者:Kagula 环境:[1]WinXP SP3[2]VisualStudio2008 SP1[3]ZLib 1.2.7[4]PCRE ...
- 解决 Springboot Unable to build Hibernate SessionFactory @Column命名不起作用
问题: Springboot启动报错: Caused by: org.springframework.beans.factory.BeanCreationException: Error creati ...
- [WARNING] Using platform encoding (GBK actually) to copy filtered resources, i.e. build is platform
eclipse maven clean install 报错 1. 修改properties-->resource-->utf-8仍然报错 2.修改项目pom.xml文件,增加: < ...
- 解决 Could not find com.android.tools.build:gradle 问题
今天拉同事最新的代码,编译时老是报如下错误: Error:Could not find com.android.tools.build:gradle:2.2.0.Searched in the fol ...
- 搭建TFS 2015 Build Agent环境(一)
Download the build agent Downloading the build agent is really simple. Navigate to your TFS control ...
- Go build constraints
Go语言有一个不(奇)错(葩)的设计,就是build constraints(构建约束).可以在源码中通过注释的方式指定编译选项,比如只允许在linux下,或者在386的平台上编译啊之类的:还可以通过 ...
- [异常解决] How to build a gcc toolchain for nRF51 on linux (very detailed!!!)
1.Install gcc-arm-none-eabi https://devzone.nordicsemi.com/tutorials/7/This link shows that developm ...
- Microsoft Build 2016 Day 2 记录(多图慎入)
Microsoft Build 2016 Day 1 记录 Microsoft Build 2016 进行到了第二天,我觉得这一天的内容非常精彩,因为主要和开发者相关
随机推荐
- JS——冒泡案例
模态框 1.因为a链接和和顶级document都注册了单击事件,所以要阻止a链接向父级盒子冒泡,不然又会从document的单击事件走一遍 2.在document的单击事件中,只需要判断触发事件的目标 ...
- 在CentOS下搭建Android 开发环境
在CentOS下搭建Android 开发环境 目录 1.环境搭建 1.1.JDK安装 1.2.Eclipse安装 1.3.ADT安装 1.4.Android SDK安装 1.5.Android NDK ...
- (转)分布式文件存储FastDFS(六)FastDFS多节点配置
http://blog.csdn.net/xingjiarong/article/details/50759918 前面几篇关于FastDFS的博客中介绍了如何在一台机器上搭建一个简易的FastDFS ...
- QQ空间里写的开发心得
不回头看一眼还真没发现我已经写过这么多开发心得日志. 理一理设备数据走向 https://user.qzone.qq.com/1156740846/blog/1522292793 action的生命 ...
- Java数值数学类
Java数值数学类 序号 方法与描述 1 xxxValue() 将 Number 对象转换为xxx数据类型的值并返回. 2 compareTo() 将number对象与参数比较. 3 equals ...
- include和require区别
1. include()执行的时候需要引用的文件每次都要进行读取评估; require()执行时需要引用的文件只处理一次(实际上执行时需要引用的文件内容替换了require()语句) 可以看出若有包 ...
- js 输入框只能输入 1-7 的数字
$jq(function () { $jq("#XSCM_WORKDAY").keyup(function () { //如果输入非数字,则替换为'',如果输入数字,则在每4位之后 ...
- npm和gulp学习
npm的使用 node Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,是一种JavaScript语言运行平台,和浏览器这个运行平台是同一个概念. npm np ...
- Vue源码学习(二)——生命周期
官网对生命周期给出了一个比较完成的流程图,如下所示: 从图中我们可以看到我们的Vue创建的过程要经过以下的钩子函数: beforeCreate => created => beforeMo ...
- (蓝桥)2017C/C++A组第一题迷宫
#include<iostream> #include<memory.h> using namespace std; char mi[10][10] ; int visited ...