blob: a574adabd513c3b88d1ed20b67b39cbf6b14ade6 [file] [log] [blame]
akmhoque298385a2014-02-13 14:13:09 -06001# -*- Mode: python; py-indent-offset: 4; indent-tabs-mode: nil; coding: utf-8; -*-
Yingdi Yu40cd1c32014-04-17 15:02:17 -07002"""
Davide Pesaventoe28d8752022-03-19 03:55:25 -04003Copyright (c) 2014-2022, The University of Memphis,
Vince Lehmanc2e51f62015-01-20 15:03:11 -06004 Regents of the University of California,
5 Arizona Board of Regents.
Yingdi Yu40cd1c32014-04-17 15:02:17 -07006
7This file is part of NLSR (Named-data Link State Routing).
8See AUTHORS.md for complete list of NLSR authors and contributors.
9
10NLSR is free software: you can redistribute it and/or modify it under the terms
11of the GNU General Public License as published by the Free Software Foundation,
12either version 3 of the License, or (at your option) any later version.
13
14NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
15without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16PURPOSE. See the GNU General Public License for more details.
17
18You should have received a copy of the GNU General Public License along with
19NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
20"""
21
Davide Pesaventof75bfda2019-11-10 18:34:13 -050022from waflib import Context, Logs, Utils
23import os, subprocess
24
Saurab Dulalcf064442020-12-14 11:04:57 -060025VERSION = "0.6.0"
sfayer93d9ec32014-12-04 23:34:41 +000026APPNAME = "nlsr"
Vince Lehmanb722b102014-08-24 16:33:49 -050027GIT_TAG_PREFIX = "NLSR-"
akmhoque298385a2014-02-13 14:13:09 -060028
akmhoque298385a2014-02-13 14:13:09 -060029def options(opt):
Yingdi Yu40cd1c32014-04-17 15:02:17 -070030 opt.load(['compiler_cxx', 'gnu_dirs'])
Davide Pesavento7ae8b082021-10-12 21:45:47 -040031 opt.load(['default-compiler-flags',
32 'coverage', 'sanitizers', 'boost',
33 'doxygen', 'sphinx_build'],
Davide Pesaventoe5569912019-01-29 19:39:06 -050034 tooldir=['.waf-tools'])
akmhoque298385a2014-02-13 14:13:09 -060035
Davide Pesaventof75bfda2019-11-10 18:34:13 -050036 optgrp = opt.add_option_group('NLSR Options')
37 optgrp.add_option('--with-tests', action='store_true', default=False,
38 help='Build unit tests')
Ashlesh Gawande30d96e42021-03-21 19:15:33 -070039 optgrp.add_option('--with-chronosync', action='store_true', default=False,
Davide Pesavento7ae8b082021-10-12 21:45:47 -040040 help='Build with ChronoSync support')
akmhoque05d5fcf2014-04-15 14:58:45 -050041
akmhoque298385a2014-02-13 14:13:09 -060042def configure(conf):
Vince Lehmanb722b102014-08-24 16:33:49 -050043 conf.load(['compiler_cxx', 'gnu_dirs',
Davide Pesavento6ebfd7c2017-08-26 17:52:54 -040044 'default-compiler-flags', 'boost',
Vince Lehmanb722b102014-08-24 16:33:49 -050045 'doxygen', 'sphinx_build'])
akmhoque298385a2014-02-13 14:13:09 -060046
Davide Pesaventof75bfda2019-11-10 18:34:13 -050047 conf.env.WITH_TESTS = conf.options.with_tests
Alexander Afanasyevfb2adee2015-03-30 10:56:55 -070048
Davide Pesaventoede59632022-08-26 20:35:44 -040049 conf.find_program('dot', mandatory=False)
50
51 # Prefer pkgconf if it's installed, because it gives more correct results
52 # on Fedora/CentOS/RHEL/etc. See https://bugzilla.redhat.com/show_bug.cgi?id=1953348
53 # Store the result in env.PKGCONFIG, which is the variable used inside check_cfg()
54 conf.find_program(['pkgconf', 'pkg-config'], var='PKGCONFIG')
Davide Pesavento7ae8b082021-10-12 21:45:47 -040055
Davide Pesaventod1f1df82022-03-12 16:40:37 -050056 pkg_config_path = os.environ.get('PKG_CONFIG_PATH', f'{conf.env.LIBDIR}/pkgconfig')
57 conf.check_cfg(package='libndn-cxx', args=['libndn-cxx >= 0.8.0', '--cflags', '--libs'],
58 uselib_store='NDN_CXX', pkg_config_path=pkg_config_path)
akmhoque85d88332014-02-17 21:11:21 -060059
Davide Pesaventof75bfda2019-11-10 18:34:13 -050060 boost_libs = ['system', 'iostreams', 'filesystem', 'regex']
61 if conf.env.WITH_TESTS:
Davide Pesaventod1f1df82022-03-12 16:40:37 -050062 boost_libs.append('unit_test_framework')
akmhoque85d88332014-02-17 21:11:21 -060063
dmcoomescf8d0ed2017-02-21 11:39:01 -060064 conf.check_boost(lib=boost_libs, mt=True)
Davide Pesaventod1f1df82022-03-12 16:40:37 -050065 if conf.env.BOOST_VERSION_NUMBER < 106501:
Davide Pesavento7ae8b082021-10-12 21:45:47 -040066 conf.fatal('The minimum supported version of Boost is 1.65.1.\n'
67 'Please upgrade your distribution or manually install a newer version of Boost.\n'
68 'For more information, see https://redmine.named-data.net/projects/nfd/wiki/Boost')
akmhoque05d5fcf2014-04-15 14:58:45 -050069
Ashlesh Gawande30d96e42021-03-21 19:15:33 -070070 if conf.options.with_chronosync:
Davide Pesaventod1f1df82022-03-12 16:40:37 -050071 conf.check_cfg(package='ChronoSync', args=['ChronoSync >= 0.5.4', '--cflags', '--libs'],
Ashlesh Gawande30d96e42021-03-21 19:15:33 -070072 uselib_store='CHRONOSYNC', pkg_config_path=pkg_config_path)
akmhoque05d5fcf2014-04-15 14:58:45 -050073
Davide Pesaventod1f1df82022-03-12 16:40:37 -050074 conf.check_cfg(package='PSync', args=['PSync >= 0.3.0', '--cflags', '--libs'],
75 uselib_store='PSYNC', pkg_config_path=pkg_config_path)
Ashlesh Gawande32ec3fd2018-07-18 13:42:32 -050076
Alexander Afanasyev67758b12018-03-06 18:36:44 -050077 conf.check_compiler_flags()
78
Davide Pesaventoe5569912019-01-29 19:39:06 -050079 # Loading "late" to prevent tests from being compiled with profiling flags
Yingdi Yu40cd1c32014-04-17 15:02:17 -070080 conf.load('coverage')
Davide Pesaventoc58cc7f2017-08-08 16:51:28 -050081 conf.load('sanitizers')
82
Davide Pesaventof75bfda2019-11-10 18:34:13 -050083 conf.define_cond('WITH_TESTS', conf.env.WITH_TESTS)
Junxiao Shia3a63972022-01-24 02:03:41 +000084 conf.define('DEFAULT_CONFIG_FILE', '%s/ndn/nlsr.conf' % conf.env.SYSCONFDIR)
Davide Pesaventof75bfda2019-11-10 18:34:13 -050085 # The config header will contain all defines that were added using conf.define()
86 # or conf.define_cond(). Everything that was added directly to conf.env.DEFINES
87 # will not appear in the config header, but will instead be passed directly to the
88 # compiler on the command line.
Yingdi Yu40cd1c32014-04-17 15:02:17 -070089 conf.write_config_header('config.hpp')
akmhoque05d5fcf2014-04-15 14:58:45 -050090
Vince Lehmanb722b102014-08-24 16:33:49 -050091def build(bld):
92 version(bld)
93
Davide Pesaventoe5569912019-01-29 19:39:06 -050094 bld(features='subst',
Alexander Afanasyev67758b12018-03-06 18:36:44 -050095 name='version.hpp',
Vince Lehmanb722b102014-08-24 16:33:49 -050096 source='src/version.hpp.in',
97 target='src/version.hpp',
Vince Lehmanb722b102014-08-24 16:33:49 -050098 VERSION_STRING=VERSION_BASE,
99 VERSION_BUILD=VERSION,
100 VERSION=int(VERSION_SPLIT[0]) * 1000000 +
101 int(VERSION_SPLIT[1]) * 1000 +
102 int(VERSION_SPLIT[2]),
103 VERSION_MAJOR=VERSION_SPLIT[0],
104 VERSION_MINOR=VERSION_SPLIT[1],
Davide Pesaventoc58cc7f2017-08-08 16:51:28 -0500105 VERSION_PATCH=VERSION_SPLIT[2])
Vince Lehmanb722b102014-08-24 16:33:49 -0500106
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500107 bld.objects(
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700108 target='nlsr-objects',
Davide Pesaventoe5569912019-01-29 19:39:06 -0500109 source=bld.path.ant_glob('src/**/*.cpp',
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700110 excl=['src/main.cpp']),
Ashlesh Gawande30d96e42021-03-21 19:15:33 -0700111 use='NDN_CXX BOOST CHRONOSYNC PSYNC',
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700112 includes='. src',
Davide Pesaventoc58cc7f2017-08-08 16:51:28 -0500113 export_includes='. src')
akmhoque298385a2014-02-13 14:13:09 -0600114
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500115 bld.program(
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700116 target='bin/nlsr',
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500117 name='nlsr',
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700118 source='src/main.cpp',
Davide Pesaventoc58cc7f2017-08-08 16:51:28 -0500119 use='nlsr-objects')
akmhoque298385a2014-02-13 14:13:09 -0600120
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500121 bld.program(
Vince Lehmanc439d662015-04-27 10:56:00 -0500122 target='bin/nlsrc',
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500123 name='nlsrc',
Vince Lehmanc439d662015-04-27 10:56:00 -0500124 source='tools/nlsrc.cpp',
Davide Pesaventoe5569912019-01-29 19:39:06 -0500125 use='nlsr-objects')
Vince Lehmanc439d662015-04-27 10:56:00 -0500126
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500127 if bld.env.WITH_TESTS:
Yingdi Yu40cd1c32014-04-17 15:02:17 -0700128 bld.recurse('tests')
Vince Lehmanb722b102014-08-24 16:33:49 -0500129
Davide Pesavento0da3eab2019-01-31 01:10:00 -0500130 bld.install_as('${SYSCONFDIR}/ndn/nlsr.conf.sample', 'nlsr.conf')
131
132 if Utils.unversioned_sys_platform() == 'linux':
133 bld(features='subst',
134 name='nlsr.service',
135 source='systemd/nlsr.service.in',
136 target='systemd/nlsr.service')
137
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500138 if bld.env.SPHINX_BUILD:
139 bld(features='sphinx',
140 name='manpages',
141 builder='man',
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500142 config='docs/conf.py',
Davide Pesavento0da3eab2019-01-31 01:10:00 -0500143 outdir='docs/manpages',
Davide Pesaventof75bfda2019-11-10 18:34:13 -0500144 source=bld.path.ant_glob('docs/manpages/*.rst'),
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500145 install_path='${MANDIR}',
Davide Pesaventof75bfda2019-11-10 18:34:13 -0500146 version=VERSION_BASE,
147 release=VERSION)
Vince Lehmanb722b102014-08-24 16:33:49 -0500148
149def docs(bld):
150 from waflib import Options
151 Options.commands = ['doxygen', 'sphinx'] + Options.commands
152
153def doxygen(bld):
154 version(bld)
155
156 if not bld.env.DOXYGEN:
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500157 bld.fatal('Cannot build documentation ("doxygen" not found in PATH)')
Vince Lehmanb722b102014-08-24 16:33:49 -0500158
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500159 bld(features='subst',
160 name='doxygen.conf',
161 source=['docs/doxygen.conf.in',
162 'docs/named_data_theme/named_data_footer-with-analytics.html.in'],
163 target=['docs/doxygen.conf',
164 'docs/named_data_theme/named_data_footer-with-analytics.html'],
165 VERSION=VERSION,
Davide Pesavento7ae8b082021-10-12 21:45:47 -0400166 HAVE_DOT='YES' if bld.env.DOT else 'NO',
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500167 HTML_FOOTER='../build/docs/named_data_theme/named_data_footer-with-analytics.html' \
168 if os.getenv('GOOGLE_ANALYTICS', None) \
169 else '../docs/named_data_theme/named_data_footer.html',
170 GOOGLE_ANALYTICS=os.getenv('GOOGLE_ANALYTICS', ''))
171
172 bld(features='doxygen',
173 doxyfile='docs/doxygen.conf',
174 use='doxygen.conf')
Vince Lehmanb722b102014-08-24 16:33:49 -0500175
176def sphinx(bld):
177 version(bld)
178
179 if not bld.env.SPHINX_BUILD:
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500180 bld.fatal('Cannot build documentation ("sphinx-build" not found in PATH)')
181
182 bld(features='sphinx',
183 config='docs/conf.py',
184 outdir='docs',
185 source=bld.path.ant_glob('docs/**/*.rst'),
Davide Pesaventof75bfda2019-11-10 18:34:13 -0500186 version=VERSION_BASE,
187 release=VERSION)
Vince Lehmanb722b102014-08-24 16:33:49 -0500188
189def version(ctx):
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500190 # don't execute more than once
Vince Lehmanb722b102014-08-24 16:33:49 -0500191 if getattr(Context.g_module, 'VERSION_BASE', None):
192 return
193
194 Context.g_module.VERSION_BASE = Context.g_module.VERSION
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500195 Context.g_module.VERSION_SPLIT = VERSION_BASE.split('.')
Vince Lehmanb722b102014-08-24 16:33:49 -0500196
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500197 # first, try to get a version string from git
198 gotVersionFromGit = False
Vince Lehmanb722b102014-08-24 16:33:49 -0500199 try:
200 cmd = ['git', 'describe', '--always', '--match', '%s*' % GIT_TAG_PREFIX]
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500201 out = subprocess.check_output(cmd, universal_newlines=True).strip()
202 if out:
203 gotVersionFromGit = True
Vince Lehmanb722b102014-08-24 16:33:49 -0500204 if out.startswith(GIT_TAG_PREFIX):
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500205 Context.g_module.VERSION = out.lstrip(GIT_TAG_PREFIX)
Vince Lehmanb722b102014-08-24 16:33:49 -0500206 else:
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500207 # no tags matched
208 Context.g_module.VERSION = '%s-commit-%s' % (VERSION_BASE, out)
Davide Pesaventoa08dc3f2018-05-24 00:40:28 -0400209 except (OSError, subprocess.CalledProcessError):
Vince Lehmanb722b102014-08-24 16:33:49 -0500210 pass
211
Alexander Afanasyev96ebd9b2020-06-01 19:16:52 -0400212 versionFile = ctx.path.find_node('VERSION.info')
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500213 if not gotVersionFromGit and versionFile is not None:
Vince Lehmanb722b102014-08-24 16:33:49 -0500214 try:
215 Context.g_module.VERSION = versionFile.read()
216 return
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500217 except EnvironmentError:
Vince Lehmanb722b102014-08-24 16:33:49 -0500218 pass
219
220 # version was obtained from git, update VERSION file if necessary
221 if versionFile is not None:
222 try:
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500223 if versionFile.read() == Context.g_module.VERSION:
224 # already up-to-date
225 return
226 except EnvironmentError as e:
227 Logs.warn('%s exists but is not readable (%s)' % (versionFile, e.strerror))
Vince Lehmanb722b102014-08-24 16:33:49 -0500228 else:
Alexander Afanasyev96ebd9b2020-06-01 19:16:52 -0400229 versionFile = ctx.path.make_node('VERSION.info')
Vince Lehmanb722b102014-08-24 16:33:49 -0500230
Vince Lehmanb722b102014-08-24 16:33:49 -0500231 try:
232 versionFile.write(Context.g_module.VERSION)
Alexander Afanasyev67758b12018-03-06 18:36:44 -0500233 except EnvironmentError as e:
234 Logs.warn('%s is not writable (%s)' % (versionFile, e.strerror))
Vince Lehmanb722b102014-08-24 16:33:49 -0500235
236def dist(ctx):
237 version(ctx)
238
239def distcheck(ctx):
240 version(ctx)