meson build - do a little tidying of the main meson.build in root

this will need further work. i want to try and trim this down as much
as i can and make it easy to read/follow and see mistakes (thus the
aligning or afgs in many places)
This commit is contained in:
Carsten Haitzler 2017-07-30 17:35:24 +09:00
parent 6ab9c576df
commit c87d70eb9a
1 changed files with 294 additions and 291 deletions

View File

@ -1,19 +1,22 @@
##### project
project('enlightenment', 'c',
version: '0.21.99',
license: 'BSD 2 clause',
version : '0.21.99',
license : 'BSD 2 clause',
default_options: [ 'c_std=gnu99', 'warning_level=2' ],
meson_version: '>= 0.40.0')
meson_version : '>= 0.40.0')
##### convenience variables for later
proj = meson.project_name()
ver = meson.project_version()
chmod = join_paths(meson.source_root(), 'meson-chmod.sh')
#### check for mixed autofoo and meson build tree mess
clean_check = run_command('meson/clean_check.sh')
if clean_check.returncode() == 0
error('Meson build requires a clean source tree')
endif
e_version = meson.project_version().split('.')
e_version = ver.split('.')
git_version = '0'
git = find_program('git')
if git.found() == true
@ -22,7 +25,8 @@ if git.found() == true
git_version = git_cmd.stdout().strip()
endif
endif
e_version_rev = '.'.join([meson.project_version(), git_version])
e_version_rev = '.'.join([ver, git_version])
#e_version_rev = e_version
efl_version = '>= 1.19.99'
@ -72,12 +76,12 @@ endforeach
add_global_arguments(dev_cflags, language: 'c')
config_h = configuration_data()
config_h.set('E_INTERNAL', '1')
config_h.set('_GNU_SOURCE', '1')
config_h.set('_ALL_SOURCE', '1')
config_h.set('E_INTERNAL' , '1')
config_h.set('_GNU_SOURCE' , '1')
config_h.set('_ALL_SOURCE' , '1')
config_h.set('_POSIX_PTHREAD_SEMANTICS', '1')
config_h.set('_TANDEM_SOURCE', '1')
config_h.set('__EXTENSIONS__', '1')
config_h.set('_TANDEM_SOURCE' , '1')
config_h.set('__EXTENSIONS__' , '1')
#config_h.set('E_RELEASE_BUILD', '1')
if get_option('nls') == true
@ -87,14 +91,15 @@ endif
darwin = host_machine.system().startswith('darwin')
if darwin == true
code='''
#define _GNU_SOURCE 1
#include <unistd.h>
extern char **environ;
'''
#define _GNU_SOURCE 1
#include <unistd.h>
extern char **environ;
'''
if cc.links(code, name: 'environ test')
config_h.set('HAVE_ENVIRON', '1')
endif
endif
openbsd = host_machine.system().startswith('openbsd')
netbsd = host_machine.system().startswith('netbsd')
freebsd = host_machine.system().startswith('freebsd')
@ -123,63 +128,60 @@ if host_os == 'linux'
endif
module_arch = '@0@-@1@-@2@'.format(host_os, host_machine.cpu_family(), release)
config_h.set_quoted('MODULE_ARCH', module_arch)
config_h.set_quoted('PACKAGE', proj)
config_h.set_quoted('PACKAGE_VERSION', e_version_rev)
config_h.set_quoted('VERSION', e_version_rev)
add_global_arguments('-DPACKAGE_BIN_DIR="@0@"'.format(dir_bin), language: 'c')
add_global_arguments('-DPACKAGE_LIB_DIR="@0@"'.format(dir_lib), language: 'c')
add_global_arguments('-DPACKAGE_DATA_DIR="@0@"'.format(join_paths(dir_data, proj)), language: 'c')
add_global_arguments('-DPACKAGE_SYSCONF_DIR="@0@"'.format(dir_sysconf), language: 'c')
config_h.set_quoted('LOCALE_DIR', join_paths([dir_prefix, 'share/locale']))
config_h.set_quoted('PACKAGE_URL', 'https://www.enlightenment.org')
config_h.set_quoted('PACKAGE_TARNAME', proj)
config_h.set_quoted('MODULE_ARCH' , module_arch)
config_h.set_quoted('PACKAGE' , proj)
config_h.set_quoted('PACKAGE_VERSION' , e_version_rev)
config_h.set_quoted('VERSION' , e_version_rev)
config_h.set_quoted('LOCALE_DIR' , join_paths([dir_prefix, 'share/locale']))
config_h.set_quoted('PACKAGE_URL' , 'https://www.enlightenment.org')
config_h.set_quoted('PACKAGE_TARNAME' , proj)
config_h.set_quoted('PACKAGE_BUGREPORT', 'enlightenment-devel@lists.sourceforge.net')
config_h.set_quoted('PACKAGE_STRING', proj + ' ' + e_version_rev)
config_h.set_quoted('PACKAGE_NAME', proj)
config_h.set_quoted('BINDIR', dir_bin)
config_h.set_quoted('DATADIR', dir_data)
config_h.set_quoted('PACKAGE_STRING' , proj + ' ' + e_version_rev)
config_h.set_quoted('PACKAGE_NAME' , proj)
config_h.set_quoted('BINDIR' , dir_bin)
config_h.set_quoted('DATADIR' , dir_data)
if cc.has_function('setenv') == true
config_h.set('HAVE_SETENV', '1')
config_h.set('HAVE_SETENV' , '1')
endif
if cc.has_function('unsetenv') == true
config_h.set('HAVE_UNSETENV', '1')
config_h.set('HAVE_UNSETENV' , '1')
endif
if cc.has_function('clearenv') == true
config_h.set('HAVE_CLEARENV', '1')
config_h.set('HAVE_CLEARENV' , '1')
endif
if cc.has_header('features.h') == true
config_h.set('HAVE_FEATURES_H', '1')
config_h.set('HAVE_FEATURES_H' , '1')
endif
if cc.has_header('sys/ptrace.h') == true
config_h.set('HAVE_SYS_PTRACE_H', '1')
config_h.set('HAVE_SYS_PTRACE_H' , '1')
endif
if cc.has_header('arpa/inet.h') == true
config_h.set('HAVE_ARPA_INET_H', '1')
config_h.set('HAVE_ARPA_INET_H' , '1')
endif
if cc.has_header('netinet/in.h') == true
config_h.set('HAVE_NETINET_IN_H', '1')
config_h.set('HAVE_NETINET_IN_H' , '1')
endif
if cc.has_header('execinfo.h') == true
config_h.set('HAVE_EXECINFO_H', '1')
else
if cc.has_function('backtrace_symbols_fd', dependencies: 'execinfo') == false
config_h.set('HAVE_EXECINFO_H' , '1')
elif cc.has_function('backtrace_symbols_fd', dependencies: 'execinfo') == false
execinfo_dep = dependency('execinfo', required: false)
endif
endif
if cc.has_header('fnmatch.h') == false
error('fnmatch.h not found')
endif
if cc.has_function('fnmatch') == false
dep_fnmatch = dependency('fnmatch', required: true)
endif
add_global_arguments('-DPACKAGE_BIN_DIR="@0@"'.format(dir_bin), language: 'c')
add_global_arguments('-DPACKAGE_LIB_DIR="@0@"'.format(dir_lib), language: 'c')
add_global_arguments('-DPACKAGE_DATA_DIR="@0@"'.format(join_paths(dir_data, proj)), language: 'c')
add_global_arguments('-DPACKAGE_SYSCONF_DIR="@0@"'.format(dir_sysconf), language: 'c')
if cc.has_header('CFBase.h',
args: '-I/System/Library/Frameworks/CoreFoundation.framework/Headers') == true
add_global_arguments('-I/System/Library/Frameworks/CoreFoundation.framework/Headers', language: 'c')
@ -187,7 +189,6 @@ if cc.has_header('CFBase.h',
add_global_link_arguments('-framework CoreFoundation', '-framework IOKit')
endif
if get_option('pam') == true
if cc.has_header('security/pam_appl.h')
config_h.set('HAVE_PAM', '1')
@ -265,20 +266,19 @@ else
endif
sysactions = configuration_data()
sysactions.set('HALT', HALT)
sysactions.set('REBOOT', REBOOT)
sysactions.set('SUSPEND', SUSPEND)
sysactions.set('HALT' , HALT)
sysactions.set('REBOOT' , REBOOT)
sysactions.set('SUSPEND' , SUSPEND)
sysactions.set('HIBERNATE', HIBERNATE)
sysactions.set('MOUNT', MOUNT)
sysactions.set('UMOUNT', UMOUNT)
sysactions.set('EJECT', EJECT)
sysactions.set('MOUNT' , MOUNT)
sysactions.set('UMOUNT' , UMOUNT)
sysactions.set('EJECT' , EJECT)
if cc.has_function('eeze_disk_function', dependencies: dependency('eeze')) == true
config_h.set('HAVE_EEZE_MOUNT', '1')
eeze_mount = true
endif
if get_option('files') == true
config_h.set('ENABLE_FILES', '1')
endif
@ -306,35 +306,34 @@ if get_option('mount-eeze') == true
endif
dep_rt = cc.find_library('rt', required: false)
dep_eina = dependency('eina', version: efl_version, required: true)
dep_eet = dependency('eet', required: true)
dep_ecore = dependency('ecore', required: true)
dep_ecore_ipc = dependency('ecore-ipc', required: true)
dep_ecore_file = dependency('ecore-file', required: true)
dep_ecore_con = dependency('ecore-con', required: true)
dep_ecore_input = dependency('ecore-input', required: true)
dep_eina = dependency('eina' , required: true, version: efl_version)
dep_eet = dependency('eet' , required: true)
dep_ecore = dependency('ecore' , required: true)
dep_ecore_ipc = dependency('ecore-ipc' , required: true)
dep_ecore_file = dependency('ecore-file' , required: true)
dep_ecore_con = dependency('ecore-con' , required: true)
dep_ecore_input = dependency('ecore-input' , required: true)
dep_ecore_input_evas = dependency('ecore-input-evas', required: true)
dep_ecore_evas = dependency('ecore-evas', required: true)
dep_evas = dependency('evas', required: true)
dep_edje = dependency('edje', required: true)
dep_efreet = dependency('efreet', required: true)
dep_efreet_mime = dependency('efreet-mime', required: true)
dep_efreet_trash = dependency('efreet-trash', required: true)
dep_eio = dependency('eio', required: true)
dep_eo = dependency('eo', required: true)
dep_eldbus = dependency('eldbus', required: true)
dep_emotion = dependency('emotion', required: true)
dep_elementary = dependency('elementary', required: true)
dep_ecore_evas = dependency('ecore-evas' , required: true)
dep_evas = dependency('evas' , required: true)
dep_edje = dependency('edje' , required: true)
dep_efreet = dependency('efreet' , required: true)
dep_efreet_mime = dependency('efreet-mime' , required: true)
dep_efreet_trash = dependency('efreet-trash' , required: true)
dep_eio = dependency('eio' , required: true)
dep_eo = dependency('eo' , required: true)
dep_eldbus = dependency('eldbus' , required: true)
dep_emotion = dependency('emotion' , required: true)
dep_elementary = dependency('elementary' , required: true)
dep_wayland = []
if get_option('wayland') == true
wayland_protocols = dependency('wayland-protocols', version: '>= 1.7')
dir_wayland_protocols = wayland_protocols.get_pkgconfig_variable('pkgdatadir')
wayland_version = '>= 1.11.0'
dep_wayland = [
dependency('ecore-wl2'),
dependency('wayland-server', version: wayland_version),
dependency('wayland-client', version: wayland_version),
dep_wayland = [ dependency('ecore-wl2'),
dependency('wayland-server' , version: wayland_version),
dependency('wayland-client' , version: wayland_version),
wayland_protocols,
dependency('wayland-scanner', version: wayland_version),
dependency('xkbcommon'),
@ -346,12 +345,11 @@ if get_option('wayland') == true
requires_drm = 'ecore-drm2'
dep_wayland += dep_ecore_drm2
endif
requires_wayland = ' '.join([
'wayland-protocols >= 1.7',
requires_wayland = ' '.join([ 'wayland-protocols >= 1.7',
'ecore-wl2',
requires_drm,
' '.join(['wayland-server', wayland_version]),
' '.join(['wayland-client', wayland_version]),
' '.join(['wayland-server' , wayland_version]),
' '.join(['wayland-client' , wayland_version]),
' '.join(['wayland-scanner', wayland_version]),
'xkbcommon',
'uuid'
@ -399,9 +397,9 @@ subdir('src/bin')
module_files = []
module_ldflags = '-module -avoid-version'
module_includes = ['../../..', '../../bin', '../../bin/efx']
module_includes2 = [ '../..', '../bin', '../bin/efx' ]
module_deps = [deps_e, dep_dl]
module_includes = [ '../../..', '../../bin', '../../bin/efx' ]
module_includes2 = [ '../..' , '../bin' , '../bin/efx' ]
module_deps = [ deps_e, dep_dl ]
subdir('src/modules')
@ -421,29 +419,34 @@ subdir('data/xsession')
subdir('doc')
meson.add_install_script('meson/meson_inst.sh', suid_exes)
meson.add_install_script('meson/meson_inst.sh' , suid_exes)
meson.add_install_script('meson/meson_modules.sh', module_files)
configure_file(output: 'config.h', install: false, configuration: config_h)
pkgconfig.generate(
name: proj,
description: 'Enlightenment Window Manager',
filebase: proj,
subdirs: proj,
configure_file(output : 'config.h',
install : false,
configuration: config_h)
pkgconfig.generate(name : proj,
description : 'Enlightenment Window Manager',
filebase : proj,
subdirs : proj,
#requires: deps_e,
requires: requires_e,
version: e_version_rev,
requires : requires_e,
version : e_version_rev,
libraries_private: '-lm',
install_dir: dir_pkgconfig,
variables: [
'exec_prefix=${prefix}',
install_dir : dir_pkgconfig,
variables : [ 'exec_prefix=${prefix}',
'datarootdir=@0@'.format(dir_data),
'datadir=${datarootdir}',
'modules=@0@/enlightenment/modules'.format(dir_lib),
'pkgdatadir=${datarootdir}/'+ proj + '/data',
'pkgdatadir=${datarootdir}/' + proj + '/data',
'themes=${pkgdatadir}/themes',
'backgrounds=${pkgdatadir}/backgrounds',
'release=@0@'.format(release)
]
)
)
install_data(['AUTHORS', 'COPYING'], install_dir: join_paths(dir_data, 'enlightenment'))
install_data([ 'AUTHORS',
'COPYING'
],
install_dir: join_paths(dir_data, 'enlightenment'))