2012-04-23 03:14:34 +02:00
|
|
|
|
Getting Started With The POCO C++ Libraries
|
|
|
|
|
AAAIntroduction
|
|
|
|
|
|
|
|
|
|
!!!Welcome
|
|
|
|
|
|
|
|
|
|
Thank you for downloading the POCO C++ Libraries and welcome to the growing community of POCO C++ Libraries
|
2017-11-10 12:45:40 +01:00
|
|
|
|
users. This document will help you in getting a smooth ride while installing and setting up the
|
2012-04-23 03:14:34 +02:00
|
|
|
|
POCO C++ Libraries and going the first steps with the software.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!!Setting Up The POCO C++ Libraries
|
|
|
|
|
|
|
|
|
|
The POCO C++ Libraries are delivered in full source code only. Due to the
|
|
|
|
|
large number of possible build configurations, no binary releases are provided
|
2017-11-10 12:45:40 +01:00
|
|
|
|
from the project maintainers.
|
|
|
|
|
This means that you have to build the libraries and tools before you can use them the first time.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
<*Note: There are binary releases available as installation packages for
|
|
|
|
|
various operating systems (e.g., Debian Linux, Ubuntu Linux, OpenBSD,
|
|
|
|
|
OpenWRT, etc.). However, these packages are not maintained by the core
|
|
|
|
|
team and may not always be up to date.*>
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
Up-to-date [[https://conan.io Conan]] packages are available via
|
|
|
|
|
[[https://bintray.com/pocoproject/conan/Poco%3Apocoproject Bintray]].
|
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
!!Source Code Distribution Format
|
|
|
|
|
|
|
|
|
|
The source code for the POCO C++ Libraries is delivered in a ZIP file
|
|
|
|
|
for Windows users and/or in a compressed TAR file (.tar.gz or .tar.bz2)
|
|
|
|
|
for Unix/Linux users. Both archives contain the same files, the only
|
|
|
|
|
difference is that all text files in the ZIP files have line endings
|
|
|
|
|
suitable for Windows (CR-LF), while the text files in the TAR file have
|
|
|
|
|
line endings suitable for Unix/Linux (LF only).
|
|
|
|
|
All libraries and tools follow a common convention for the directory
|
|
|
|
|
layout. This directory layout is shown below.
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
build/ the build system for Unix and additional utility scripts
|
2012-04-23 03:14:34 +02:00
|
|
|
|
config/ build configurations for various Unix platforms
|
|
|
|
|
rules/ common build rules for all platforms
|
|
|
|
|
scripts/ build and utility scripts
|
|
|
|
|
vxconfig/ VxWorks build configurations
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
|
|
|
|
cmake/ Support files for CMake
|
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
bin/ all executables (dynamic link libraries on Windows)
|
|
|
|
|
bin64/ all 64-bit executables (and DLLs)
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
doc/ additional documentation
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
lib/ all libraries (import libraries on Windows)
|
|
|
|
|
lib64/ all 64-bit libraries
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
CppUnit/ project and make/build files for the CppUnit unit testing framework
|
|
|
|
|
doc/ additional documentation
|
|
|
|
|
include/
|
|
|
|
|
CppUnit/ header files for CppUnit
|
|
|
|
|
src/ source files for CppUnit
|
|
|
|
|
WinTestRunner/ Windows GUI for CppUnit
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
Foundation/ project and make/build files for the Foundation library
|
|
|
|
|
include/
|
|
|
|
|
Poco/ header files for the Foundation library
|
|
|
|
|
src/ source files for the Foundation library
|
|
|
|
|
testsuite/ project and make/build files for the Foundation testsuite
|
|
|
|
|
src/ source files for the Foundation testsuite
|
|
|
|
|
bin/ test suite executables
|
|
|
|
|
samples/ sample applications for the Foundation library
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
XML/ project and make/build files for the XML library
|
|
|
|
|
include/
|
|
|
|
|
Poco/
|
|
|
|
|
XML/ header files for the core XML library
|
|
|
|
|
SAX/ header files for SAX support
|
|
|
|
|
DOM/ header files for DOM support
|
|
|
|
|
src/ source files for the XML library
|
|
|
|
|
testsuite/ project and make/build files for the XML testsuite
|
|
|
|
|
src/ source files for the XML testsuite
|
|
|
|
|
bin/ test suite executables
|
|
|
|
|
samples/ sample applications for the XML library
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
Net/ project and make/build files for the Net library
|
|
|
|
|
include/
|
|
|
|
|
Poco/
|
|
|
|
|
Net/ header files for the Net library
|
|
|
|
|
src/ source files for the Net library
|
|
|
|
|
testsuite/ project and make/build files for the Net testsuite
|
|
|
|
|
src/ source files for the Net testsuite
|
|
|
|
|
bin/ test suite executables
|
|
|
|
|
samples/ sample applications for the Net library
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
Depending on what package you have downloaded (Basic or Complete
|
|
|
|
|
Edition), there may be other libraries as well (such as Data, Crypto,
|
|
|
|
|
NetSSL_OpenSSL and Zip).
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!External Dependencies
|
|
|
|
|
|
|
|
|
|
The following libraries require third-party software (header files and
|
|
|
|
|
libraries) being installed to build properly:
|
|
|
|
|
|
|
|
|
|
- NetSSL_OpenSSL and Crypt require OpenSSL.
|
2017-11-10 12:45:40 +01:00
|
|
|
|
- Data/ODBC requires ODBC
|
2012-04-23 03:14:34 +02:00
|
|
|
|
(Microsoft ODBC on Windows, unixODBC or iODBC on Unix/Linux)
|
|
|
|
|
- Data/MySQL requires the MySQL client.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!OpenSSL
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
<*Unix/Linux*>
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
Most Unix/Linux systems already have OpenSSL
|
2012-04-23 03:14:34 +02:00
|
|
|
|
preinstalled, or OpenSSL can be easily installed using the system’s
|
|
|
|
|
package management facility. For example, on Ubuntu (or other
|
|
|
|
|
Debian-based Linux distributions) you can type
|
|
|
|
|
|
|
|
|
|
$ sudo apt-get install openssl libssl-dev
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
to install the necessary packages.
|
|
|
|
|
If your system does not have OpenSSL, please get it from
|
|
|
|
|
http://www.openssl.org/ or another source. You do not have to build
|
|
|
|
|
OpenSSL yourself -- a binary distribution is fine.
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
On macOS, it's recommended to install OpenSSL via Homebrew.
|
|
|
|
|
|
|
|
|
|
$ brew install openssl
|
2017-11-10 13:12:12 +01:00
|
|
|
|
----
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<*Windows*>
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
On Windows, there are three options:
|
|
|
|
|
|
|
|
|
|
- Use POCO pre-built OpenSSL binaries (simplest and recommended)
|
|
|
|
|
- Build OpenSSL using scripts from POCO distribution package
|
|
|
|
|
- Use a third-party pre-built OpenSSL
|
|
|
|
|
|
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
<*POCO pre-built OpenSSL binaries*>
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
OpenSSL binaries (version 1.1.0) built with Visual Studio 2013 are available for
|
2018-02-24 16:16:14 +01:00
|
|
|
|
[[https://github.com/pocoproject/openssl/tree/master/build download]].
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
In case you are using pre-built binaries, please make sure to copy the
|
2017-11-10 13:12:12 +01:00
|
|
|
|
entire directory to <*C:\%POCO_BASE%\openssl\*>.
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2018-02-24 16:16:14 +01:00
|
|
|
|
Or, %POCO_BASE%\openssl directory can be deleted (if existing) and POCO openssl
|
|
|
|
|
github repository cloned into it:
|
2017-09-26 02:27:41 +02:00
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
$ cd %POCO_BASE%
|
|
|
|
|
$ rmdir /s /q openssl
|
|
|
|
|
$ git clone https://github.com/pocoproject/openssl
|
2017-09-26 02:27:41 +02:00
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
All libraries are located in their proper folders (eg. <*win64/bin/debug/*>),
|
2018-02-24 16:16:14 +01:00
|
|
|
|
and all are named accordingly (<*libcrypto[mt[d]]*> and <*libssl[mt[d]]*>).
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
<*Build OpenSSL using scripts from POCO distribution package*>
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
Alternatively, if you choose to build your own OpenSSL, POCO C++ Libraries
|
|
|
|
|
distribution package comes with scripts to build OpenSSL on Windows operating
|
2017-11-10 13:12:12 +01:00
|
|
|
|
system. This requires Windows PowerShell.
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
Usage:
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
C:\%POCO_BASE%\openssl\build.ps1 [-openssl_release 1.0.0 | 1.1.0]
|
|
|
|
|
[-vs_version 150 | 140 | 120 | 110 | 100 | 90]
|
|
|
|
|
[-config release | debug | both]
|
|
|
|
|
[-platform Win32 | x64]
|
|
|
|
|
[-library shared | static]
|
|
|
|
|
----
|
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
Example: Building OpenSSL 1.1.0, DLL release build for x64 with Visual Studio 2013:
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
C:\%POCO_BASE%\openssl\build.ps1 -openssl_release 1.1.0 -vs_version 120 -config release -platform x64 -library shared
|
|
|
|
|
----
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
The above command will download all the necessary packages (perl, nasm, etc)
|
2018-02-24 16:16:14 +01:00
|
|
|
|
and build OpenSSL in <*C:\%POCO_BASE%\openssl\build*> directory; the built OpenSSL
|
2017-11-10 13:12:12 +01:00
|
|
|
|
binaries can be linked from EXEs and DLLs built with Visual Studio 2008 to 2017.
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
Pre-generated POCO Visual Studio projects are configured to use headers and
|
2018-02-24 16:16:14 +01:00
|
|
|
|
libraries from <*C:\%POCO_BASE%\openssl\build*> directory.
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
2017-11-10 13:12:12 +01:00
|
|
|
|
<*Use a third-party pre-built OpenSSL*>
|
2017-09-26 01:58:15 +02:00
|
|
|
|
|
|
|
|
|
Yet another way to install OpenSSL on Windows is to use a binary
|
2017-11-10 12:45:40 +01:00
|
|
|
|
(prebuild) release, for example the one from Shining Light
|
2012-04-23 03:14:34 +02:00
|
|
|
|
Productions that comes with a Windows installer
|
2017-11-10 12:45:40 +01:00
|
|
|
|
(http://www.slproweb.com/products/Win32OpenSSL.html).
|
|
|
|
|
Depending on where you have installed the OpenSSL libraries,
|
|
|
|
|
you might have to edit the build script (buildwin.cmd), or add the
|
2012-04-23 03:14:34 +02:00
|
|
|
|
necessary paths to the INCLUDE and LIB environment variables. You might also
|
|
|
|
|
have to edit the project settings if the names of the OpenSSL libraries
|
|
|
|
|
from your build differ from the names used in the project files.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!ODBC
|
|
|
|
|
|
|
|
|
|
The Data library requires ODBC support on your system if you want to
|
|
|
|
|
build the ODBC connector (which is the default). On Windows platforms,
|
|
|
|
|
ODBC should be readily available if you have the Windows SDK installed.
|
|
|
|
|
On Unix/Linux platforms, you can use [[http://www.iodbc.org/ iODBC]]
|
2017-11-10 12:45:40 +01:00
|
|
|
|
or [[http://www.unixodbc.org/ unixODBC]. On
|
2012-04-23 03:14:34 +02:00
|
|
|
|
Linux, use your distribution's package management system to install the
|
|
|
|
|
necessary libraries and header files. For example, on Ubuntu, type
|
|
|
|
|
|
|
|
|
|
$ sudo apt-get install libiodbc2 libiodbc2-dev
|
2017-11-10 12:45:40 +01:00
|
|
|
|
----
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
to install the iODBC library and header files.
|
|
|
|
|
|
|
|
|
|
The Data/ODBC and Data/MySQL Makefiles will search for the ODBC and
|
|
|
|
|
MySQL headers and libraries in various places. Nevertheless, the
|
|
|
|
|
Makefiles may not be able to find the headers and libraries. In this
|
|
|
|
|
case, please edit the Makefile in Data/ODBC and/or Data/MySQL
|
|
|
|
|
accordingly.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!MySQL Client
|
|
|
|
|
|
|
|
|
|
The Data library requires the [[http://dev.mysql.com MySQL]] client
|
|
|
|
|
libraries and header files if you want to build the MySQL connector
|
|
|
|
|
(which is the default). On Windows platforms, use the MySQL client
|
|
|
|
|
installer to install the necessary files. On Unix/Linux platforms, use
|
|
|
|
|
the package management system of your choice to install the necessary
|
|
|
|
|
files. Alternatively, you can of course build MySQL yourself from
|
|
|
|
|
source.
|
|
|
|
|
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
!!Building using CMake
|
|
|
|
|
|
|
|
|
|
As an alternative to the platform specific Makefiles and Solutions, CMake can be used
|
|
|
|
|
to do build Poco. CMake is a cross platform Makefile generator that also supports
|
|
|
|
|
Microsoft Visual Studio and Apple Xcode.
|
|
|
|
|
Poco requires CMake 3.0 or higher. Static binaries for many platforms can be downloaded from http://www.cmake.org/
|
|
|
|
|
|
|
|
|
|
CMake supports out of source builds and this is the recommended way to build Poco using CMake.
|
|
|
|
|
|
|
|
|
|
Assuming you are currently in the Poco source directory on a Unix machine
|
|
|
|
|
and you like to build Poco with the generated Makefiles just type the following commands.
|
|
|
|
|
|
|
|
|
|
$ mkdir cmake_build
|
|
|
|
|
$ cd cmake_build
|
|
|
|
|
$ cmake ..
|
|
|
|
|
$ make
|
|
|
|
|
|
|
|
|
|
This will build Poco in a subdirectory <*cmake_build*>. All files produced during build are located in this directory.
|
|
|
|
|
|
|
|
|
|
CMake allows you to set some build time options. As an example: to disable the SevenZip support
|
|
|
|
|
type the following command:
|
|
|
|
|
|
|
|
|
|
$ cmake -DENABLE_SEVENZIP=OFF ..
|
|
|
|
|
|
|
|
|
|
Similar options are available for other components (see: CMakeLists.txt).
|
|
|
|
|
|
|
|
|
|
If you cannot or do not want to build with CMake, there are other options,
|
|
|
|
|
described in the following.
|
|
|
|
|
|
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
!!Building On Windows
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
Microsoft Visual Studio 2008 or newer is required to build the
|
|
|
|
|
POCO C++ Libraries on Windows platforms.
|
|
|
|
|
Solution and project files for all versions are included.
|
|
|
|
|
64-bit (x64) builds are supported as well.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
You can either build from within Visual Studio (<*Build->Batch
|
|
|
|
|
Build->Select All;Rebuild*>) or from the command line. To build from the
|
2017-11-10 12:45:40 +01:00
|
|
|
|
command line, start the Visual Studio 2008 (or 2010, 2013, etc.) Command
|
2012-04-23 03:14:34 +02:00
|
|
|
|
Prompt and go (<[cd]>) to the directory where you have extracted the POCO
|
|
|
|
|
C++ Libraries sources. Then, simply start the <*buildwin.cmd*> script and
|
2017-11-10 12:45:40 +01:00
|
|
|
|
pass as argument the version of visual studio (90, 100, 110, ... 150). You
|
2012-04-23 03:14:34 +02:00
|
|
|
|
can customize what is being built by <*buildwin.cmd*> by passing appropriate
|
|
|
|
|
command line arguments to it. Call <*buildwin.cmd*> without arguments to see
|
2013-06-20 06:55:17 +02:00
|
|
|
|
what is available. Build environment is set up by the buildwin.cmd; to avoid
|
2017-11-10 12:45:40 +01:00
|
|
|
|
build problems, it is recommended to start the build in a clean command
|
|
|
|
|
prompt console, i.e. not in the one provided by Visual Studio for 32/64-bit
|
|
|
|
|
builds (although those will work fine if used appropriately for the right
|
2013-06-20 06:55:17 +02:00
|
|
|
|
32/64-bit build type).
|
|
|
|
|
|
2012-04-23 03:14:34 +02:00
|
|
|
|
To disable certain components (e.g., NetSSL_OpenSSL or Data/MySQL) from
|
|
|
|
|
the build, edit the text file named <*components*> in the distribution
|
2013-06-20 06:55:17 +02:00
|
|
|
|
root directory and remove or comment the respective lines.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
Certain libraries, like NetSSL_OpenSSL, Crypto or Data/MySQL have
|
2017-11-10 12:45:40 +01:00
|
|
|
|
dependencies to other libraries. Since the build script does not know where to
|
2012-04-23 03:14:34 +02:00
|
|
|
|
find the necessary header files and import libraries, you have to either add
|
|
|
|
|
the header file paths to the <[INCLUDE]> environment variable and the
|
|
|
|
|
library path to the <[LIB]> environment variable, or you'll have to edit the
|
|
|
|
|
buildwin.cmd script, where these environment variables can be set as
|
2017-11-10 12:45:40 +01:00
|
|
|
|
well.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
In order to run the test suite and the samples, the top-most bin
|
|
|
|
|
directory containing the resulting shared libraries must be in the PATH
|
|
|
|
|
environment variable.
|
|
|
|
|
|
|
|
|
|
|
2017-11-10 12:45:40 +01:00
|
|
|
|
!!Building On Unix/Linux/macOS
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
For building on Unix platforms, the POCO C++ Libraries come with their
|
|
|
|
|
own build system. The build system is based on GNU Make 3.80 (or newer),
|
|
|
|
|
with the help from a few shell scripts. If you do not have GNU Make 3.80
|
2017-11-10 12:45:40 +01:00
|
|
|
|
(or newer) installed on your machine, you will need to download it from
|
|
|
|
|
http://directory.fsf.org/devel/build/make.html and
|
2012-04-23 03:14:34 +02:00
|
|
|
|
build and install it prior to building the POCO C++ Libraries.
|
|
|
|
|
|
|
|
|
|
You can check the version of GNU Make installed on your system with
|
|
|
|
|
|
|
|
|
|
$ gmake --version
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
or
|
|
|
|
|
|
|
|
|
|
$ make --version
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
Once you have GNU Make up and running, the rest is quite simple.
|
|
|
|
|
To extract the sources and build all libraries, testsuites and samples, simply
|
|
|
|
|
|
|
|
|
|
$ gunzip poco-X.Y.tar.gz
|
|
|
|
|
$ tar -xf poco-X.Y.tar
|
|
|
|
|
$ cd poco-X.Y
|
|
|
|
|
$ ./configure
|
|
|
|
|
$ gmake -s
|
|
|
|
|
----
|
|
|
|
|
|
2013-06-20 06:55:17 +02:00
|
|
|
|
For help, either invoke
|
|
|
|
|
|
|
|
|
|
$ ./configure --help
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
Alternatively, you can read the configure script source for a list of possible options.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
For starters, we recommend <[--no-tests]> and <[--no-samples]>, to reduce build times.
|
|
|
|
|
On a multicore or multiprocessor machine, use parallel makes to speed up
|
|
|
|
|
the build (<[make -j4]>).
|
|
|
|
|
|
|
|
|
|
Once you have successfully built POCO, you can install it
|
|
|
|
|
to <*/usr/local*> (or another directory specified as parameter
|
|
|
|
|
to configure <[--prefix=<path>]>):
|
|
|
|
|
|
|
|
|
|
$ sudo gmake -s install
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
You can omit certain components from the build. For example, you might
|
|
|
|
|
want to omit Data/ODBC or Data/MySQL if you do not have the corresponding
|
|
|
|
|
third-party libraries (iodbc or unixodbc, mysqlclient) installed
|
|
|
|
|
on your system. To do this, use the <[--omit]> argument to configure:
|
|
|
|
|
|
|
|
|
|
$ ./configure --omit=Data/ODBC,Data/MySQL
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
<*IMPORTANT: Make sure that the path to the build directory does not
|
2017-11-10 12:45:40 +01:00
|
|
|
|
contain symbolic links. Furthermore, on macOS (or other systems
|
|
|
|
|
with case insensitive filesystems), make sure that the characters in
|
2012-04-23 03:14:34 +02:00
|
|
|
|
the path have the correct case. Otherwise you'll get an error saying
|
|
|
|
|
"Current working directory not under $PROJECT_BASE.".*>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!Building On QNX Neutrino
|
|
|
|
|
|
|
|
|
|
For QNX Neutrino, the Unix build system (see the instructions above) is used.
|
|
|
|
|
You can use the build system to cross-compile for a target platform on a
|
|
|
|
|
Solaris or Linux host. Unfortunately, the Cygwin-based Windows host
|
|
|
|
|
environment has some major quirks that prevent the build system from
|
|
|
|
|
working there. You can also use the build system on a self-hosted QNX
|
|
|
|
|
system. The default build configuration for QNX (found in
|
|
|
|
|
build/config/QNX) is for a self-hosted x86 platform. To specify another
|
|
|
|
|
target, edit the CCVER setting in the build configuration file. For
|
|
|
|
|
example, to compile for a PowerPC target, specify
|
|
|
|
|
CCVER=3.3.1,gcc_ntoppcbe.
|
|
|
|
|
|
|
|
|
|
Service Pack 1 for QNX Neutrino 6.3 must be installed, otherwise compiling the
|
|
|
|
|
Foundation library will fail due to a problem with the <*<list>*> header in the
|
|
|
|
|
default (Dinkumware) C++ standard library.
|
|
|
|
|
|
|
|
|
|
When building on QNX, you might want to disable NetSSL_OpenSSL, Crypto and
|
|
|
|
|
some Data connectors, unless you have the necessary third party components
|
|
|
|
|
available:
|
|
|
|
|
|
|
|
|
|
$ ./configure --omit=NetSSL_OpenSSL,Crypto,Data/ODBC,Data/MySQL
|
|
|
|
|
----
|
|
|
|
|
|
|
|
|
|
!!!Tutorials And Sample Code
|
|
|
|
|
|
|
|
|
|
Introductory documentation consisting of various documents and tutorials
|
|
|
|
|
in the form of slide decks can be found at the
|
2014-12-22 00:06:53 +01:00
|
|
|
|
[[http://pocoproject.org/documentation/ POCO C++ Libraries Documentation]] page.
|
2012-04-23 03:14:34 +02:00
|
|
|
|
|
|
|
|
|
Sample applications demonstrating the various features of the POCO C++
|
|
|
|
|
Libraries are delivered with the source code. Every library's source
|
|
|
|
|
code directory
|
|
|
|
|
has a <*samples*> directory containing various sample applications.
|
|
|
|
|
|
|
|
|
|
When building the sample applications on platforms using the gmake-based
|
|
|
|
|
build system, please make sure that the environment variable
|
|
|
|
|
<[POCO_BASE]> contains
|
|
|
|
|
the path to the POCO C++ Libraries source tree root directory.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
!!!Creating Your Own POCO-based Applications
|
|
|
|
|
|
|
|
|
|
The best way to create your first POCO-based application is by copying
|
|
|
|
|
one of the sample projects and making the desired changes. Examine the
|
|
|
|
|
project files and Makefiles to see what compiler options must be set for
|
|
|
|
|
your specific platform.
|