fix meson.build

This commit is contained in:
Mars 2024-06-22 01:55:17 -04:00
parent 164a68c5ee
commit ab097e2370
Signed by: pupbrained
GPG key ID: 0FF5B8826803F895
2 changed files with 75 additions and 22 deletions

View file

View file

@ -2,19 +2,22 @@ project(
'draconis++', 'cpp', 'draconis++', 'cpp',
version: '0.1.0', version: '0.1.0',
default_options: [ default_options: [
'cpp_std=c++20', 'cpp_std=c++23',
'default_library=static', 'default_library=static',
'warning_level=everything', 'warning_level=everything',
'buildtype=debugoptimized' 'buildtype=debugoptimized'
] ]
) )
clangtidy = find_program('clang-tidy', required: false)
cpp = meson.get_compiler('cpp') cpp = meson.get_compiler('cpp')
if host_machine.system() == 'darwin'
add_languages('objcpp')
objcpp = meson.get_compiler('objcpp')
add_project_arguments( add_project_arguments(
cpp.get_supported_arguments( objcpp.get_supported_arguments([
[
'-DCURL_STATICLIB',
'-Wno-c++20-compat', '-Wno-c++20-compat',
'-Wno-c++20-extensions', '-Wno-c++20-extensions',
'-Wno-c++98-compat', '-Wno-c++98-compat',
@ -25,36 +28,86 @@ add_project_arguments(
'-Wno-pre-c++20-compat-pedantic', '-Wno-pre-c++20-compat-pedantic',
'-Wno-switch-default', '-Wno-switch-default',
'-Wunused-function', '-Wunused-function',
]),
language: 'objcpp'
)
endif
common_cpp_args = [
'-Wno-c++20-compat',
'-Wno-c++20-extensions',
'-Wno-c++98-compat',
'-Wno-c++98-compat-pedantic',
'-Wno-disabled-macro-expansion',
'-Wno-missing-prototypes',
'-Wno-padded',
'-Wno-pre-c++20-compat-pedantic',
'-Wno-switch-default',
'-Wunused-function'
] ]
),
if host_machine.system() == 'windows'
common_cpp_args += ['-DCURL_STATICLIB']
endif
add_project_arguments(
cpp.get_supported_arguments(common_cpp_args),
language: 'cpp' language: 'cpp'
) )
source_file_names = [ source_file_names = [
'src/main.cpp', 'src/main.cpp',
'src/config/config.cpp', 'src/config/config.cpp',
'src/config/weather.cpp', 'src/config/weather.cpp'
'src/os/windows.cpp'
] ]
if host_machine.system() == 'linux'
source_file_names += ['src/os/linux.cpp']
elif host_machine.system() == 'darwin'
source_file_names += [
'src/os/macos.cpp',
'src/os/macos/bridge.mm',
]
elif host_machine.system() == 'windows'
source_file_names += ['src/os/windows.cpp']
endif
sources = [] sources = []
foreach file : source_file_names foreach file : source_file_names
sources += files(file) sources += files(file)
endforeach endforeach
deps = [
dependency('fmt', static: host_machine.system() != 'darwin'),
dependency('libcurl', static: host_machine.system() != 'darwin'),
dependency('tomlplusplus', static: host_machine.system() != 'darwin'),
dependency('yyjson', static: host_machine.system() != 'darwin')
]
if host_machine.system() == 'darwin'
deps += dependency('Foundation')
deps += dependency('MediaPlayer')
elif host_machine.system() == 'linux'
deps += dependency('sdbus-c++')
endif
objc_args = []
link_args = []
if host_machine.system() == 'darwin'
objc_args += ['-fobjc-arc']
link_args += ['-framework', 'Foundation', '-framework', 'MediaPlayer']
elif host_machine.system() == 'windows'
windows_sdk_lib_dir = 'C:/Program Files (x86)/Windows Kits/10/Lib/10.0.22621.0/um/x64' windows_sdk_lib_dir = 'C:/Program Files (x86)/Windows Kits/10/Lib/10.0.22621.0/um/x64'
link_args = ['-L' + windows_sdk_lib_dir, '-lwindowsapp', '-static'] link_args += ['-L' + windows_sdk_lib_dir, '-lwindowsapp', '-static']
endif
deps = []
deps += dependency('fmt', static : true)
deps += dependency('libcurl', static : true)
deps += dependency('tomlplusplus', static : true)
deps += dependency('yyjson', static : true)
executable( executable(
'draconis++', 'draconis++',
sources, sources,
dependencies : deps, objc_args: objc_args,
link_args : link_args link_args: link_args,
dependencies: deps
) )