diff options
Diffstat (limited to 'src/arrow/c_glib/meson.build')
-rw-r--r-- | src/arrow/c_glib/meson.build | 191 |
1 files changed, 191 insertions, 0 deletions
diff --git a/src/arrow/c_glib/meson.build b/src/arrow/c_glib/meson.build new file mode 100644 index 000000000..df04cf0a0 --- /dev/null +++ b/src/arrow/c_glib/meson.build @@ -0,0 +1,191 @@ +# -*- indent-tabs-mode: nil -*- +# +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you 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. + +project('arrow-glib', 'c', 'cpp', + license: 'Apache-2.0', + default_options: [ + 'cpp_std=c++11', + ]) + +version = '6.0.1' +if version.endswith('-SNAPSHOT') + version_numbers = version.split('-')[0].split('.') + version_tag = version.split('-')[1] +else + version_numbers = version.split('.') + version_tag = '' +endif +version_major = version_numbers[0].to_int() +version_minor = version_numbers[1].to_int() +version_micro = version_numbers[2].to_int() + +api_version = '1.0' +so_version = version_major * 100 + version_minor +so_version_patch = version_micro +library_version = '@0@.@1@.@2@'.format(so_version, so_version_patch, 0) + +prefix = get_option('prefix') +include_dir = join_paths(prefix, get_option('includedir')) +data_dir = join_paths(prefix, get_option('datadir')) + +gnome = import('gnome') +pkgconfig = import('pkgconfig') + +base_include_directories = [ + include_directories('.') +] + +have_gi = dependency('gobject-introspection-1.0', required: false).found() + +arrow_cpp_build_dir = get_option('arrow_cpp_build_dir') +arrow_cpp_build_type = get_option('arrow_cpp_build_type') +if arrow_cpp_build_dir == '' + arrow_cpp_build_lib_dir = '' +else + arrow_cpp_build_lib_dir = join_paths(meson.source_root(), + arrow_cpp_build_dir, + arrow_cpp_build_type.to_lower()) +endif + +if arrow_cpp_build_lib_dir == '' + arrow = dependency('arrow') + # They are just for checking required modules are enabled. They are built into + # libarrow.so. So we don't need additional build flags for them. + dependency('arrow-compute') + dependency('arrow-csv') + dependency('arrow-filesystem') + dependency('arrow-json') + + have_arrow_orc = dependency('arrow-orc', required: false).found() + arrow_cuda = dependency('arrow-cuda', required: false) + arrow_dataset = dependency('arrow-dataset', required: false) + arrow_flight = dependency('arrow-flight', required: false) + gandiva = dependency('gandiva', required: false) + parquet = dependency('parquet', required: false) + plasma = dependency('plasma', required: false) +else + base_include_directories += [ + include_directories(join_paths(arrow_cpp_build_dir, 'src')), + include_directories('../cpp/src'), + ] + cpp_compiler = meson.get_compiler('cpp') + arrow = cpp_compiler.find_library('arrow', + dirs: [arrow_cpp_build_lib_dir]) + arrow_orc_code = ''' +#include <arrow/adapters/orc/adapter.h> + +int +main(void) +{ + arrow::adapters::orc::ORCFileReader::Open(nullptr, nullptr, nullptr); + return 0; +} + ''' + have_arrow_orc = cpp_compiler.links(arrow_orc_code, + include_directories: base_include_directories, + dependencies: [arrow]) + arrow_cuda = cpp_compiler.find_library('arrow_cuda', + dirs: [arrow_cpp_build_lib_dir], + required: false) + arrow_dataset = cpp_compiler.find_library('arrow_dataset', + dirs: [arrow_cpp_build_lib_dir], + required: false) + arrow_flight = cpp_compiler.find_library('arrow_flight', + dirs: [arrow_cpp_build_lib_dir], + required: false) + gandiva = cpp_compiler.find_library('gandiva', + dirs: [arrow_cpp_build_lib_dir], + required: false) + parquet = cpp_compiler.find_library('parquet', + dirs: [arrow_cpp_build_lib_dir], + required: false) + plasma = cpp_compiler.find_library('plasma', + dirs: [arrow_cpp_build_lib_dir], + required: false) +endif + +cxx = meson.get_compiler('cpp') +cxx_flags = [] +if get_option('development_mode') + if cxx.get_id() == 'msvc' + cxx_flags += ['/WX'] + else + cxx_flags += ['-Werror'] + endif +endif +if cxx.get_id() != 'msvc' + cxx_flags += ['-Wmissing-declarations'] +endif +add_project_arguments(cxx.get_supported_arguments(cxx_flags), language: 'cpp') + +subdir('arrow-glib') +if arrow_cuda.found() + subdir('arrow-cuda-glib') +endif +if arrow_dataset.found() + subdir('arrow-dataset-glib') +endif +if arrow_flight.found() + subdir('arrow-flight-glib') +endif +if gandiva.found() + subdir('gandiva-glib') +endif +if parquet.found() + subdir('parquet-glib') +endif +if plasma.found() + subdir('plasma-glib') +endif +subdir('example') + +if get_option('gtk_doc') + subdir('doc/arrow-glib') + if arrow_dataset.found() + subdir('doc/arrow-dataset-glib') + endif + if arrow_flight.found() + subdir('doc/arrow-flight-glib') + endif + if gandiva.found() + subdir('doc/gandiva-glib') + endif + if parquet.found() + subdir('doc/parquet-glib') + endif + if plasma.found() + subdir('doc/plasma-glib') + endif +endif + +install_data('../LICENSE.txt', + 'README.md', + install_dir: join_paths(data_dir, 'doc', meson.project_name())) + +run_test = find_program('test/run-test.sh') +test('unit test', + run_test, + env: [ + 'ARROW_GLIB_TYPELIB_DIR=@0@/arrow-glib'.format(meson.build_root()), + 'ARROW_CUDA_GLIB_TYPELIB_DIR=@0@/arrow-cuda-glib'.format(meson.build_root()), + 'ARROW_DATASET_GLIB_TYPELIB_DIR=@0@/arrow-dataset-glib'.format(meson.build_root()), + 'GANDIVA_GLIB_TYPELIB_DIR=@0@/gandiva-glib'.format(meson.build_root()), + 'PARQUET_GLIB_TYPELIB_DIR=@0@/parquet-glib'.format(meson.build_root()), + 'PLASMA_GLIB_TYPELIB_DIR=@0@/plasma-glib'.format(meson.build_root()), + ]) |