mirror of
https://github.com/pgbackrest/pgbackrest.git
synced 2025-01-18 04:58:51 +02:00
4fb8a0ecdd
This is immediately useful because it will detect any extern'd functions or variables that are not being used. It also detects functions or variables that are declared but not defined. If a FV/VR_EXTERN macro is missing it will be detected either because of a mismatch in the declaration/definition or because a new defined symbol will appear in the nm test. Eventually the unity build will be used to create a more optimized pgbackrest binary but that will need to wait.
195 lines
8.0 KiB
Meson
195 lines
8.0 KiB
Meson
####################################################################################################################################
|
|
# pgBackRest Project
|
|
####################################################################################################################################
|
|
project(
|
|
'pgbackrest',
|
|
['c'],
|
|
version: '2.44dev',
|
|
license: 'MIT',
|
|
meson_version: '>=0.45',
|
|
default_options: [
|
|
# Core options
|
|
'buildtype=release',
|
|
'warning_level=2',
|
|
|
|
# Base options
|
|
'b_ndebug=if-release',
|
|
|
|
# Perform unity builds in a single file
|
|
'unity_size=100000',
|
|
|
|
# Compiler options
|
|
'c_std=c99',
|
|
],
|
|
)
|
|
|
|
# Selected C compiler
|
|
cc = meson.get_compiler('c')
|
|
|
|
####################################################################################################################################
|
|
# OS-specific settings
|
|
####################################################################################################################################
|
|
if host_machine.system() == 'linux'
|
|
add_global_arguments('-D_POSIX_C_SOURCE=200809L', language : 'c')
|
|
elif host_machine.system() == 'darwin'
|
|
add_global_arguments('-D_DARWIN_C_SOURCE', language : 'c')
|
|
endif
|
|
|
|
####################################################################################################################################
|
|
# Enable/disable warnings
|
|
####################################################################################################################################
|
|
# Enable as many additional warnings as possible to catch potential errors
|
|
warning_enable = [
|
|
# Warn for implicit conversions that may alter a value
|
|
'-Wconversion',
|
|
|
|
# Warn about duplicated conditions in an if-else-if chain
|
|
'-Wduplicated-cond',
|
|
|
|
# Warn when an if-else has identical branches
|
|
'-Wduplicated-branches',
|
|
|
|
# Warn if the format string is not a string literal and cannot be checked
|
|
'-Wformat-nonliteral',
|
|
|
|
# Enable -Wformat plus additional format checks
|
|
'-Wformat=2',
|
|
|
|
# Warn if the format string requires an unsigned argument and the argument is signed and vice versa
|
|
'-Wformat-signedness',
|
|
|
|
# Warn about anything that depends on the “size of” a function type or of void
|
|
'-Wpointer-arith',
|
|
|
|
# Warn if a function is declared or defined without specifying the argument types
|
|
'-Wstrict-prototypes',
|
|
|
|
# Warn if a variable-length array is used
|
|
'-Wvla',
|
|
|
|
# Give string constants the type const char[length] so that copying the address of one into a non-const char * pointer produces
|
|
# a warning
|
|
'-Wwrite-strings',
|
|
]
|
|
|
|
# Disable various unhelpful warnings
|
|
warning_disable = [
|
|
# Warn for variables that might be changed by longjmp or vfork. Disable because of constant false positives/negatives.
|
|
'-Wno-clobbered',
|
|
|
|
# Warn if a structure’s initializer has some fields missing. Disable so we can initialize with {0}.
|
|
'-Wno-missing-field-initializers',
|
|
|
|
# Warn when a switch case falls through. Disable because this an useful aspect of switches and tests should catch problems.
|
|
'-Wno-implicit-fallthrough',
|
|
]
|
|
|
|
add_project_arguments(cc.get_supported_arguments(warning_enable, warning_disable), language: 'c')
|
|
|
|
####################################################################################################################################
|
|
# Enable additional optimizations for release builds. We would prefer to use `get_option('optimization') in ['2', '3']` when our
|
|
# minimum version is high enough to allow it.
|
|
####################################################################################################################################
|
|
if get_option('buildtype') == 'release'
|
|
optimization_enable = [
|
|
# Unroll loops whose number of iterations can be determined at compile time or upon entry to the loop
|
|
'-funroll-loops',
|
|
|
|
# Perform loop vectorization on trees
|
|
'-ftree-vectorize',
|
|
]
|
|
|
|
add_project_arguments(cc.get_supported_arguments(optimization_enable), language: 'c')
|
|
endif
|
|
|
|
####################################################################################################################################
|
|
# Stop after the first error when error on warn enabled. Subsequent errors are often caused by the first error.
|
|
####################################################################################################################################
|
|
if get_option('fatal-errors')
|
|
add_project_arguments(cc.get_supported_arguments('-Wfatal-errors'), language: 'c')
|
|
endif
|
|
|
|
####################################################################################################################################
|
|
# Generate -fmacro-prefix-map so the relative path to the source directory is not included in the __FILE__ macro. This provides
|
|
# reproducible builds and minimizes the file path in debug messages, just like an in-tree make build. For test source, prefix with
|
|
# test/ in case there are any module name collisions.
|
|
####################################################################################################################################
|
|
file_prefix = run_command(
|
|
[
|
|
'python3',
|
|
'-c',
|
|
'import sys, os; print(os.path.relpath(sys.argv[1], sys.argv[2]))',
|
|
meson.current_source_dir(),
|
|
meson.current_build_dir(),
|
|
],
|
|
# check: true, # This should be set when the minimum supported meson version is >= 0.47
|
|
).stdout().strip()
|
|
|
|
add_project_arguments(cc.get_supported_arguments('-fmacro-prefix-map=@0@/src/=' . format(file_prefix)), language: 'c')
|
|
add_project_arguments(cc.get_supported_arguments('-fmacro-prefix-map=@0@/test/src/=test/' . format(file_prefix)), language: 'c')
|
|
|
|
####################################################################################################################################
|
|
# Build configuration
|
|
####################################################################################################################################
|
|
configuration = configuration_data()
|
|
|
|
# Find required bz2 library
|
|
lib_bz2 = cc.find_library('bz2')
|
|
|
|
# Find optional lz4 library
|
|
lib_lz4 = dependency('liblz4', required: false)
|
|
|
|
if lib_lz4.found()
|
|
configuration.set('HAVE_LIBLZ4', true, description: 'Is liblz4 present?')
|
|
endif
|
|
|
|
# Find required openssl library
|
|
lib_openssl = dependency('openssl')
|
|
|
|
# Find required pq library
|
|
lib_pq = dependency('libpq')
|
|
|
|
# Find required xml library
|
|
lib_xml = dependency('libxml-2.0')
|
|
|
|
# Find required yaml library (only used for build)
|
|
lib_yaml = dependency('yaml-0.1')
|
|
|
|
# Find required gz library
|
|
lib_z = dependency('zlib')
|
|
|
|
# Find optional zstd library
|
|
lib_zstd = dependency('libzstd', version: '>=1.0', required: false)
|
|
|
|
if lib_zstd.found()
|
|
configuration.set('HAVE_LIBZST', true, description: 'Is libzstd present?')
|
|
endif
|
|
|
|
# Check if the C compiler supports _Static_assert()
|
|
if cc.compiles('''int main(int arg, char **argv) {({ _Static_assert(1, "foo");});} ''')
|
|
configuration.set('HAVE_STATIC_ASSERT', true, description: 'Does the compiler provide _Static_assert()?')
|
|
endif
|
|
|
|
# Enable debug code. We would prefer to use `get_option('debug')` when our minimum version is high enough to allow it.
|
|
if get_option('buildtype') == 'debug' or get_option('buildtype') == 'debugoptimized'
|
|
configuration.set('DEBUG', true, description: 'Enable debug code')
|
|
endif
|
|
|
|
# Set configuration path
|
|
configuration.set_quoted('CFGOPTDEF_CONFIG_PATH', get_option('configdir'), description: 'Configuration path')
|
|
|
|
# Set FN_NO_RETURN macro
|
|
configuration.set('FN_NO_RETURN', '__attribute__((__noreturn__))', description: 'Indicate that a function does not return')
|
|
|
|
# Set FN_INLINE_ALWAYS macro
|
|
configuration.set(
|
|
'FN_INLINE_ALWAYS', '__attribute__((always_inline)) static inline',
|
|
description: 'Indicate that a function should always be inlined'
|
|
)
|
|
|
|
####################################################################################################################################
|
|
# Include subdirs
|
|
####################################################################################################################################
|
|
subdir('src')
|
|
subdir('test/src')
|