|
48 | 48 | version_major = version_numbers[0].to_int() |
49 | 49 | version_minor = version_numbers[1].to_int() |
50 | 50 | version_micro = version_numbers[2].to_int() |
| 51 | +version_no_snapshot = '.'.join(version_numbers) |
51 | 52 |
|
52 | 53 | api_version = '1.0' |
53 | 54 | so_version = version_major * 100 + version_minor |
|
81 | 82 | generate_vapi = have_gi and get_option('vapi') |
82 | 83 | if generate_vapi |
83 | 84 | pkgconfig_variables += ['vapidir=@0@'.format(vapi_dir)] |
84 | | - add_languages('vala') |
| 85 | + add_languages('vala', native: false) |
85 | 86 | endif |
86 | 87 |
|
87 | 88 | arrow_cpp_build_dir = get_option('arrow_cpp_build_dir') |
|
97 | 98 | endif |
98 | 99 |
|
99 | 100 | if arrow_cpp_build_lib_dir == '' |
100 | | - arrow = dependency('arrow', version: ['>=' + version]) |
| 101 | + common_args = {'version': [f'>=@version_no_snapshot@']} |
| 102 | + arrow = dependency( |
| 103 | + 'arrow', |
| 104 | + 'Arrow', |
| 105 | + kwargs: common_args, |
| 106 | + modules: ['Arrow::arrow_shared'], |
| 107 | + ) |
101 | 108 | # They are just for checking required modules are enabled. They are built into |
102 | 109 | # libarrow.so. So we don't need additional build flags for them. |
103 | | - dependency('arrow-compute', version: ['>=' + version]) |
104 | | - dependency('arrow-csv', version: ['>=' + version]) |
105 | | - dependency('arrow-filesystem', version: ['>=' + version]) |
106 | | - dependency('arrow-json', version: ['>=' + version]) |
| 110 | + if arrow.type_name() == 'cmake' |
| 111 | + assert( |
| 112 | + arrow.get_variable('ARROW_COMPUTE', default_value: 'OFF') == 'ON', |
| 113 | + 'compute module must be enabled', |
| 114 | + ) |
| 115 | + assert( |
| 116 | + arrow.get_variable('ARROW_CSV', default_value: 'OFF') == 'ON', |
| 117 | + 'CSV module must be enabled', |
| 118 | + ) |
| 119 | + assert( |
| 120 | + arrow.get_variable('ARROW_FILESYSTEM', default_value: 'OFF') == 'ON', |
| 121 | + 'filesystem module must be enabled', |
| 122 | + ) |
| 123 | + assert( |
| 124 | + arrow.get_variable('ARROW_JSON', default_value: 'OFF') == 'ON', |
| 125 | + 'JSON module must be enabled', |
| 126 | + ) |
| 127 | + else |
| 128 | + dependency('arrow-compute', kwargs: common_args) |
| 129 | + dependency('arrow-csv', kwargs: common_args) |
| 130 | + dependency('arrow-filesystem', kwargs: common_args) |
| 131 | + dependency('arrow-json', kwargs: common_args) |
| 132 | + endif |
107 | 133 |
|
108 | | - have_arrow_orc = dependency( |
109 | | - 'arrow-orc', |
110 | | - required: false, |
111 | | - version: ['>=' + version], |
112 | | - ).found() |
| 134 | + if arrow.type_name() == 'cmake' |
| 135 | + have_arrow_orc = (arrow.get_variable('ARROW_ORC', default_value: 'OFF') == 'ON') |
| 136 | + else |
| 137 | + have_arrow_orc = dependency( |
| 138 | + 'arrow-orc', |
| 139 | + kwargs: common_args, |
| 140 | + required: false, |
| 141 | + ).found() |
| 142 | + endif |
113 | 143 | arrow_cuda = dependency( |
114 | 144 | 'arrow-cuda', |
| 145 | + 'ArrowCUDA', |
| 146 | + kwargs: common_args, |
| 147 | + modules: ['ArrowCUDA::arrow_cuda_shared'], |
115 | 148 | required: false, |
116 | | - version: ['>=' + version], |
117 | 149 | ) |
118 | | - # we do not support compiling glib without acero engine |
| 150 | + # we do not support compiling GLib without Acero engine |
119 | 151 | arrow_acero = dependency( |
120 | 152 | 'arrow-acero', |
121 | | - required: true, |
122 | | - version: ['>=' + version], |
| 153 | + 'ArrowAcero', |
| 154 | + kwargs: common_args, |
| 155 | + modules: ['ArrowAcero::arrow_acero_shared'], |
123 | 156 | ) |
124 | 157 | arrow_dataset = dependency( |
125 | 158 | 'arrow-dataset', |
| 159 | + 'ArrowDataset', |
| 160 | + kwargs: common_args, |
| 161 | + modules: ['ArrowDataset::arrow_dataset_shared'], |
126 | 162 | required: false, |
127 | | - version: ['>=' + version], |
128 | 163 | ) |
129 | 164 | arrow_flight = dependency( |
130 | 165 | 'arrow-flight', |
| 166 | + 'ArrowFlight', |
| 167 | + kwargs: common_args, |
| 168 | + modules: ['ArrowFlight::arrow_flight_shared'], |
131 | 169 | required: false, |
132 | | - version: ['>=' + version], |
133 | 170 | ) |
134 | 171 | arrow_flight_sql = dependency( |
135 | 172 | 'arrow-flight-sql', |
| 173 | + 'ArrowFlightSql', |
| 174 | + kwargs: common_args, |
| 175 | + modules: ['ArrowFlightSql::arrow_flight_sql_shared'], |
| 176 | + required: false, |
| 177 | + ) |
| 178 | + gandiva = dependency( |
| 179 | + 'gandiva', |
| 180 | + 'Gandiva', |
| 181 | + kwargs: common_args, |
| 182 | + modules: ['Gandiva::gandiva_shared'], |
136 | 183 | required: false, |
137 | | - version: ['>=' + version], |
138 | 184 | ) |
139 | | - gandiva = dependency('gandiva', required: false, version: ['>=' + version]) |
140 | | - parquet = dependency('parquet', required: false, version: ['>=' + version]) |
| 185 | + parquet = dependency( |
| 186 | + 'parquet', |
| 187 | + 'Parquet', |
| 188 | + kwargs: common_args, |
| 189 | + modules: ['Parquet::parquet_shared'], |
| 190 | + ) |
141 | 191 | else |
142 | 192 | base_include_directories += [ |
143 | 193 | include_directories(join_paths(arrow_cpp_build_dir, 'src')), |
|
0 commit comments