blob: 811490dce8e7d374ddf816dab9b356c1b7f4ea7b [file] [log] [blame]
#
#==================================================================================
# Copyright (c) 2019 Nokia
# Copyright (c) 2018-2019 AT&T Intellectual Property.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#==================================================================================
#
Building RMr
The RIC Message Router (RMr) is built with CMake, and requires
a modern gcc compiler and make to be installed on the build
system. Typically, installing the following list of packages
in a container (Ubuntu) is all that is needed to craft a
development environment (containerised builds are also the
recommended approach):
gcc git make vim cmake g++ ksh bash
Kshell and vi are needed only if you wish to use the container
interactively. Bash is assumed necessary for CMake.
Build process
To build RMr, the usual CMake steps are followed:
mkdir build
cd build
cmake .. [options]
make package
This will create a .deb (provided the system supports this) in
the build directory. It's that simple.
The following flags may be given on the 'cmake' command line
(options) which are outside of "normal" CMake flags and affect
the configuration:
-DBUILD_DOC=1 Man pages generated
-DDEV_PKG=1 Development package configuration
-DMAN_PREFIX=<path> Supply a path where man pages are installed (default: /usr/share/man)
-DPACK_EXTERNALS=1 Include external libraries used to build in the run-time package
-DPRESERVE_PTYPE=1 Do not change the processor type when naming deb packages
-DSKIP_EXTERNALS=1 Do not use Nano/NNG submodules when building; uee installed packages
Packages
The build can be configured to generate either a run-time or
development package. The run-time generation is the default and
the -DDEV_PKG=1 option must be given to generate the development
package. The run-time package contains only the shared library
files (*.so), and the development package contains the headers,
man pages (if the man option is set) and archive (.a) files.
Resulting package names are illustrated in the CI section below.
Continuous Integration Build
Use the Dockerfile in the ci/ subdirectory. This installs all
the required tools, then builds RMr and executes the unit and
programm tests. If tests pass, then an image is created in the
local registry with both run-time and development packages.
To support the distribution of package(s) created during the
build by the CI process, a YAML file is left in the /tmp
directory (build_packages.yml) which contains a list of the
packages available from the image. Currently, both .deb and
.rpm packages are generated.
The following is a sample YAML file generated during this process:
---
files:
- /tmp/rmr-dev_1.0.34_x86_64.deb
- /tmp/rmr-dev-1.0.34-x86_64.rpm
- /tmp/rmr_1.0.34_x86_64.deb
- /tmp/rmr-1.0.34-x86_64.rpm
...
Alternatives
To build in a non-Linux environment, or to build with an
alternate install path (or both) read on.
Instead of using 'make package' as listed above, using
'make install' will build and install on the local system.
By default, the target install is into /usr/local which may
not be desired. To install into an alternate path add
these two options when the 'cmake ..' command is given:
-DCMAKE_INSTALL_PREFIX=/path/to/dir
-DMAN_PREFIX=/path/to/dir
The first will cause the make process to install into the named
directory, which can be in your home directory. The second
defines where manual pages are placed (if not defined
/usr/share/man is the target). Manual pages are generally
NOT built as the required tool has yet to be incorporated into
the build process and generally is not available on most systems.
Compiling and Linking User Applications
Should the Rmr and NNG/Nano libraries be installed in a directory
outside of the normal system spots (e.g. not in /usr/local)
it might be necessary to define the specific directory for
libraries (.e.g -L) on the command line, or via environment
variables (e.g.. C_INCLUDE_PATH, LD_LIBRARY_PATH, LIBRARY_PATH).
It may also be necessary to have the library directory defined
in the environment at run time. It is difficult to know what
each system needs, but the following linker ooptions work when
libraries are installed in the system spots:
-lrmr_nng -lnng -lpthread
Adding -L is one way to compensate when libraries are installed
a different spot (e.g. in $HOME/usr):
-L $HOME/usr -lrmr_nng -lnng -lpthread
Libraries
RMr supports both NNG and Nanomsg as underlying transport. They
are separate beasts, and while an NNG based program can
communicate with a Nanomsg based programme, their APIs are NOT
compatible. For this reason, and others, RMr generates two
libraries and requires that the underlying transport be selected
at link time rather than run time. The RMr API for both underlying
mechanisms is the same, so generating a NNG and Nanomsg version
of a programme should require no extra work; other than adding
a second link statement and giving it a different name.
Nanomsg is on its way out with respect to community support. RMr
will continue to support Nanomsg for a short period of time, but
new programmes should NOT use Nanomsg.
Manual Pages
By default the deb created does not include the manual pages. To
enable their creation, and subsequent inclusion in the deb, add
the following option to the cmake command:
-DBUILD_DOC=1
This will cause the {X}fm text formatting package to be fetched
(github) and built at cmake time (must exist before building)
and will trigger the generation of the man pages in both postscript
and troff format. The troff pages are placed into the deb and
the postscript pages are left in the build directory for the
developer to convert to PDF, or otherwise use.