duckdb 0.10.2-dev0.0 → 0.10.2-dev3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/binding.gyp +22 -18
- package/binding.gyp.in +3 -0
- package/package.json +1 -1
- package/src/duckdb/extension/icu/icu-timezone.cpp +3 -1
- package/src/duckdb/extension/icu/icu_extension.cpp +6 -2
- package/src/duckdb/extension/json/buffered_json_reader.cpp +10 -3
- package/src/duckdb/extension/json/include/buffered_json_reader.hpp +2 -0
- package/src/duckdb/extension/json/include/json_scan.hpp +13 -7
- package/src/duckdb/extension/json/include/json_serializer.hpp +5 -4
- package/src/duckdb/extension/json/include/json_structure.hpp +3 -3
- package/src/duckdb/extension/json/json_functions/json_serialize_plan.cpp +15 -5
- package/src/duckdb/extension/json/json_functions/json_serialize_sql.cpp +15 -6
- package/src/duckdb/extension/json/json_functions/json_structure.cpp +21 -20
- package/src/duckdb/extension/json/json_functions/read_json.cpp +37 -3
- package/src/duckdb/extension/json/json_functions.cpp +7 -2
- package/src/duckdb/extension/json/json_scan.cpp +57 -33
- package/src/duckdb/extension/parquet/column_reader.cpp +12 -3
- package/src/duckdb/extension/parquet/column_writer.cpp +44 -7
- package/src/duckdb/extension/parquet/include/parquet_writer.hpp +5 -1
- package/src/duckdb/extension/parquet/parquet_extension.cpp +30 -3
- package/src/duckdb/extension/parquet/parquet_metadata.cpp +1 -1
- package/src/duckdb/extension/parquet/parquet_writer.cpp +4 -2
- package/src/duckdb/extension/parquet/zstd_file_system.cpp +1 -1
- package/src/duckdb/src/catalog/catalog.cpp +5 -1
- package/src/duckdb/src/catalog/catalog_entry/duck_schema_entry.cpp +21 -5
- package/src/duckdb/src/catalog/catalog_entry/duck_table_entry.cpp +8 -9
- package/src/duckdb/src/catalog/catalog_entry/index_catalog_entry.cpp +3 -7
- package/src/duckdb/src/catalog/catalog_entry/sequence_catalog_entry.cpp +1 -1
- package/src/duckdb/src/catalog/catalog_entry/table_catalog_entry.cpp +6 -7
- package/src/duckdb/src/catalog/catalog_entry.cpp +8 -0
- package/src/duckdb/src/catalog/catalog_search_path.cpp +5 -0
- package/src/duckdb/src/catalog/catalog_set.cpp +2 -2
- package/src/duckdb/src/catalog/default/default_functions.cpp +6 -6
- package/src/duckdb/src/catalog/default/default_schemas.cpp +1 -1
- package/src/duckdb/src/catalog/default/default_views.cpp +7 -7
- package/src/duckdb/src/catalog/dependency_catalog_set.cpp +2 -1
- package/src/duckdb/src/catalog/dependency_list.cpp +92 -8
- package/src/duckdb/src/catalog/dependency_manager.cpp +53 -68
- package/src/duckdb/src/catalog/duck_catalog.cpp +1 -1
- package/src/duckdb/src/common/adbc/adbc.cpp +287 -45
- package/src/duckdb/src/common/arrow/appender/union_data.cpp +2 -2
- package/src/duckdb/src/common/box_renderer.cpp +12 -12
- package/src/duckdb/src/common/crypto/md5.cpp +2 -1
- package/src/duckdb/src/common/enum_util.cpp +307 -1
- package/src/duckdb/src/common/enums/expression_type.cpp +4 -0
- package/src/duckdb/src/common/enums/optimizer_type.cpp +1 -1
- package/src/duckdb/src/common/file_system.cpp +60 -13
- package/src/duckdb/src/common/filename_pattern.cpp +13 -13
- package/src/duckdb/src/common/gzip_file_system.cpp +1 -1
- package/src/duckdb/src/common/http_state.cpp +1 -1
- package/src/duckdb/src/common/local_file_system.cpp +72 -71
- package/src/duckdb/src/common/multi_file_reader.cpp +48 -28
- package/src/duckdb/src/common/row_operations/row_matcher.cpp +2 -2
- package/src/duckdb/src/common/serializer/buffered_file_reader.cpp +13 -1
- package/src/duckdb/src/common/serializer/buffered_file_writer.cpp +32 -13
- package/src/duckdb/src/common/string_util.cpp +2 -3
- package/src/duckdb/src/common/tree_renderer.cpp +32 -67
- package/src/duckdb/src/common/types/bit.cpp +6 -6
- package/src/duckdb/src/common/types/data_chunk.cpp +2 -2
- package/src/duckdb/src/common/types/hash.cpp +6 -6
- package/src/duckdb/src/common/types/hyperloglog.cpp +2 -0
- package/src/duckdb/src/common/types/row/tuple_data_allocator.cpp +13 -0
- package/src/duckdb/src/common/types/row/tuple_data_layout.cpp +5 -7
- package/src/duckdb/src/common/types/uuid.cpp +1 -1
- package/src/duckdb/src/common/types/vector.cpp +22 -14
- package/src/duckdb/src/common/types.cpp +8 -1
- package/src/duckdb/src/common/vector_operations/comparison_operators.cpp +20 -18
- package/src/duckdb/src/common/vector_operations/generators.cpp +1 -1
- package/src/duckdb/src/common/vector_operations/is_distinct_from.cpp +267 -110
- package/src/duckdb/src/common/vector_operations/vector_hash.cpp +52 -23
- package/src/duckdb/src/common/virtual_file_system.cpp +33 -20
- package/src/duckdb/src/core_functions/aggregate/algebraic/avg.cpp +2 -2
- package/src/duckdb/src/core_functions/aggregate/distributive/minmax.cpp +3 -3
- package/src/duckdb/src/core_functions/aggregate/distributive/sum.cpp +31 -16
- package/src/duckdb/src/core_functions/aggregate/holistic/quantile.cpp +3 -0
- package/src/duckdb/src/core_functions/aggregate/nested/list.cpp +2 -0
- package/src/duckdb/src/core_functions/core_functions.cpp +1 -1
- package/src/duckdb/src/core_functions/function_list.cpp +2 -2
- package/src/duckdb/src/core_functions/scalar/date/time_bucket.cpp +1 -1
- package/src/duckdb/src/core_functions/scalar/generic/system_functions.cpp +46 -17
- package/src/duckdb/src/core_functions/scalar/list/array_slice.cpp +1 -1
- package/src/duckdb/src/core_functions/scalar/list/flatten.cpp +82 -45
- package/src/duckdb/src/core_functions/scalar/list/list_aggregates.cpp +2 -2
- package/src/duckdb/src/core_functions/scalar/list/list_sort.cpp +3 -0
- package/src/duckdb/src/core_functions/scalar/math/numeric.cpp +3 -2
- package/src/duckdb/src/core_functions/scalar/string/hex.cpp +2 -4
- package/src/duckdb/src/core_functions/scalar/string/repeat.cpp +12 -21
- package/src/duckdb/src/execution/column_binding_resolver.cpp +2 -10
- package/src/duckdb/src/execution/expression_executor/execute_comparison.cpp +133 -66
- package/src/duckdb/src/execution/expression_executor/execute_function.cpp +0 -2
- package/src/duckdb/src/execution/expression_executor.cpp +0 -4
- package/src/duckdb/src/execution/expression_executor_state.cpp +1 -1
- package/src/duckdb/src/execution/index/art/art.cpp +2 -2
- package/src/duckdb/src/execution/index/unknown_index.cpp +13 -13
- package/src/duckdb/src/execution/join_hashtable.cpp +1 -1
- package/src/duckdb/src/execution/nested_loop_join/nested_loop_join_mark.cpp +0 -1
- package/src/duckdb/src/execution/operator/csv_scanner/buffer_manager/csv_buffer.cpp +10 -7
- package/src/duckdb/src/execution/operator/csv_scanner/buffer_manager/csv_buffer_manager.cpp +32 -1
- package/src/duckdb/src/execution/operator/csv_scanner/buffer_manager/csv_file_handle.cpp +16 -2
- package/src/duckdb/src/execution/operator/csv_scanner/scanner/scanner_boundary.cpp +7 -7
- package/src/duckdb/src/execution/operator/csv_scanner/scanner/string_value_scanner.cpp +354 -159
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/csv_sniffer.cpp +11 -2
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/dialect_detection.cpp +22 -7
- package/src/duckdb/src/execution/operator/csv_scanner/sniffer/type_detection.cpp +1 -1
- package/src/duckdb/src/execution/operator/csv_scanner/state_machine/csv_state_machine_cache.cpp +10 -10
- package/src/duckdb/src/execution/operator/csv_scanner/table_function/csv_file_scanner.cpp +9 -18
- package/src/duckdb/src/execution/operator/csv_scanner/table_function/global_csv_state.cpp +180 -47
- package/src/duckdb/src/execution/operator/csv_scanner/util/csv_error.cpp +100 -58
- package/src/duckdb/src/execution/operator/csv_scanner/util/csv_reader_options.cpp +88 -21
- package/src/duckdb/src/execution/operator/helper/physical_vacuum.cpp +12 -13
- package/src/duckdb/src/execution/operator/join/physical_iejoin.cpp +2 -0
- package/src/duckdb/src/execution/operator/persistent/csv_rejects_table.cpp +118 -23
- package/src/duckdb/src/execution/operator/persistent/physical_batch_copy_to_file.cpp +2 -2
- package/src/duckdb/src/execution/operator/persistent/physical_batch_insert.cpp +14 -5
- package/src/duckdb/src/execution/operator/persistent/physical_copy_database.cpp +1 -1
- package/src/duckdb/src/execution/operator/persistent/physical_export.cpp +5 -5
- package/src/duckdb/src/execution/operator/schema/physical_attach.cpp +1 -1
- package/src/duckdb/src/execution/physical_plan/plan_simple.cpp +0 -9
- package/src/duckdb/src/execution/physical_plan/plan_vacuum.cpp +18 -0
- package/src/duckdb/src/execution/physical_plan_generator.cpp +5 -3
- package/src/duckdb/src/execution/radix_partitioned_hashtable.cpp +81 -106
- package/src/duckdb/src/execution/reservoir_sample.cpp +1 -1
- package/src/duckdb/src/execution/window_executor.cpp +48 -28
- package/src/duckdb/src/execution/window_segment_tree.cpp +20 -23
- package/src/duckdb/src/function/aggregate/sorted_aggregate_function.cpp +1 -1
- package/src/duckdb/src/function/cast/enum_casts.cpp +20 -55
- package/src/duckdb/src/function/cast/vector_cast_helpers.cpp +10 -9
- package/src/duckdb/src/function/cast_rules.cpp +9 -1
- package/src/duckdb/src/function/compression_config.cpp +1 -1
- package/src/duckdb/src/function/function_binder.cpp +45 -44
- package/src/duckdb/src/function/function_set.cpp +9 -9
- package/src/duckdb/src/function/pragma/pragma_queries.cpp +1 -2
- package/src/duckdb/src/function/scalar/compressed_materialization/compress_integral.cpp +21 -5
- package/src/duckdb/src/function/scalar/compressed_materialization/compress_string.cpp +2 -2
- package/src/duckdb/src/function/scalar/list/list_select.cpp +5 -2
- package/src/duckdb/src/function/scalar/list/list_zip.cpp +5 -4
- package/src/duckdb/src/function/scalar/operators/arithmetic.cpp +60 -32
- package/src/duckdb/src/function/scalar/sequence/nextval.cpp +1 -1
- package/src/duckdb/src/function/scalar/strftime_format.cpp +31 -25
- package/src/duckdb/src/function/scalar/string/caseconvert.cpp +6 -6
- package/src/duckdb/src/function/scalar/string/length.cpp +23 -2
- package/src/duckdb/src/function/scalar/string/like.cpp +1 -1
- package/src/duckdb/src/function/scalar/string/regexp/regexp_extract_all.cpp +1 -1
- package/src/duckdb/src/function/scalar/system/aggregate_export.cpp +3 -3
- package/src/duckdb/src/function/table/arrow/arrow_array_scan_state.cpp +1 -1
- package/src/duckdb/src/function/table/arrow.cpp +7 -1
- package/src/duckdb/src/function/table/copy_csv.cpp +17 -13
- package/src/duckdb/src/function/table/read_csv.cpp +52 -39
- package/src/duckdb/src/function/table/sniff_csv.cpp +7 -13
- package/src/duckdb/src/function/table/system/duckdb_constraints.cpp +1 -1
- package/src/duckdb/src/function/table/system/duckdb_databases.cpp +7 -1
- package/src/duckdb/src/function/table/system/duckdb_extensions.cpp +12 -2
- package/src/duckdb/src/function/table/system/duckdb_sequences.cpp +1 -2
- package/src/duckdb/src/function/table/system/duckdb_tables.cpp +2 -2
- package/src/duckdb/src/function/table/system/pragma_metadata_info.cpp +9 -2
- package/src/duckdb/src/function/table/system/pragma_table_info.cpp +10 -6
- package/src/duckdb/src/function/table/table_scan.cpp +1 -4
- package/src/duckdb/src/function/table/version/pragma_version.cpp +3 -3
- package/src/duckdb/src/include/duckdb/catalog/catalog.hpp +6 -2
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/duck_index_entry.hpp +1 -1
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/duck_schema_entry.hpp +1 -1
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry/sequence_catalog_entry.hpp +1 -1
- package/src/duckdb/src/include/duckdb/catalog/catalog_entry.hpp +6 -1
- package/src/duckdb/src/include/duckdb/catalog/catalog_set.hpp +3 -3
- package/src/duckdb/src/include/duckdb/catalog/default/default_functions.hpp +3 -3
- package/src/duckdb/src/include/duckdb/catalog/dependency.hpp +26 -4
- package/src/duckdb/src/include/duckdb/catalog/dependency_list.hpp +39 -6
- package/src/duckdb/src/include/duckdb/catalog/dependency_manager.hpp +19 -14
- package/src/duckdb/src/include/duckdb/catalog/duck_catalog.hpp +1 -1
- package/src/duckdb/src/include/duckdb/catalog/standard_entry.hpp +4 -0
- package/src/duckdb/src/include/duckdb/common/allocator.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/arrow/arrow_wrapper.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/bit_utils.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/box_renderer.hpp +16 -16
- package/src/duckdb/src/include/duckdb/common/crypto/md5.hpp +0 -1
- package/src/duckdb/src/include/duckdb/common/enum_util.hpp +32 -0
- package/src/duckdb/src/include/duckdb/common/enums/expression_type.hpp +4 -2
- package/src/duckdb/src/include/duckdb/common/exception/binder_exception.hpp +14 -10
- package/src/duckdb/src/include/duckdb/common/exception/catalog_exception.hpp +4 -4
- package/src/duckdb/src/include/duckdb/common/exception/conversion_exception.hpp +6 -6
- package/src/duckdb/src/include/duckdb/common/exception/http_exception.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/exception/parser_exception.hpp +4 -4
- package/src/duckdb/src/include/duckdb/common/exception/transaction_exception.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/exception.hpp +57 -58
- package/src/duckdb/src/include/duckdb/common/exception_format_value.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/extra_type_info.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/file_open_flags.hpp +134 -0
- package/src/duckdb/src/include/duckdb/common/file_opener.hpp +9 -6
- package/src/duckdb/src/include/duckdb/common/file_system.hpp +35 -36
- package/src/duckdb/src/include/duckdb/common/filename_pattern.hpp +4 -6
- package/src/duckdb/src/include/duckdb/common/fixed_size_map.hpp +13 -13
- package/src/duckdb/src/include/duckdb/common/helper.hpp +42 -47
- package/src/duckdb/src/include/duckdb/common/http_state.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/hugeint.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/index_vector.hpp +10 -10
- package/src/duckdb/src/include/duckdb/common/local_file_system.hpp +13 -10
- package/src/duckdb/src/include/duckdb/common/memory_safety.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/multi_file_reader_options.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/opener_file_system.hpp +50 -24
- package/src/duckdb/src/include/duckdb/common/operator/abs.hpp +12 -4
- package/src/duckdb/src/include/duckdb/common/optional_ptr.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/pipe_file_system.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/platform.h +1 -1
- package/src/duckdb/src/include/duckdb/common/printer.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/profiler.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/progress_bar/display/terminal_progress_bar_display.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/random_engine.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/re2_regex.hpp +7 -7
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_file_reader.hpp +3 -0
- package/src/duckdb/src/include/duckdb/common/serializer/buffered_file_writer.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/serializer/deserialization_data.hpp +17 -6
- package/src/duckdb/src/include/duckdb/common/serializer/deserializer.hpp +12 -0
- package/src/duckdb/src/include/duckdb/common/serializer/serialization_traits.hpp +14 -0
- package/src/duckdb/src/include/duckdb/common/serializer/serializer.hpp +16 -0
- package/src/duckdb/src/include/duckdb/common/sort/duckdb_pdqsort.hpp +3 -0
- package/src/duckdb/src/include/duckdb/common/sort/partition_state.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/string_util.hpp +4 -4
- package/src/duckdb/src/include/duckdb/common/tree_renderer.hpp +24 -25
- package/src/duckdb/src/include/duckdb/common/typedefs.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/types/cast_helpers.hpp +1 -2
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_collection.hpp +10 -10
- package/src/duckdb/src/include/duckdb/common/types/column/column_data_collection_iterators.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/types/column/partitioned_column_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/constraint_conflict_info.hpp +1 -2
- package/src/duckdb/src/include/duckdb/common/types/data_chunk.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/types/date.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/hash.hpp +5 -5
- package/src/duckdb/src/include/duckdb/common/types/hyperloglog.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/interval.hpp +4 -4
- package/src/duckdb/src/include/duckdb/common/types/row/partitioned_tuple_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_layout.hpp +10 -3
- package/src/duckdb/src/include/duckdb/common/types/row/tuple_data_segment.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/selection_vector.hpp +12 -12
- package/src/duckdb/src/include/duckdb/common/types/string_heap.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types/string_type.hpp +21 -20
- package/src/duckdb/src/include/duckdb/common/types/time.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/types/timestamp.hpp +3 -3
- package/src/duckdb/src/include/duckdb/common/types/uuid.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/types/value.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/types/vector.hpp +15 -7
- package/src/duckdb/src/include/duckdb/common/types/vector_buffer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/types.hpp +14 -10
- package/src/duckdb/src/include/duckdb/common/uhugeint.hpp +2 -2
- package/src/duckdb/src/include/duckdb/common/union_by_name.hpp +1 -1
- package/src/duckdb/src/include/duckdb/common/unique_ptr.hpp +15 -14
- package/src/duckdb/src/include/duckdb/common/vector.hpp +21 -21
- package/src/duckdb/src/include/duckdb/common/vector_operations/aggregate_executor.hpp +2 -0
- package/src/duckdb/src/include/duckdb/common/vector_operations/general_cast.hpp +2 -1
- package/src/duckdb/src/include/duckdb/common/vector_operations/generic_executor.hpp +2 -3
- package/src/duckdb/src/include/duckdb/common/vector_operations/unary_executor.hpp +3 -2
- package/src/duckdb/src/include/duckdb/common/vector_operations/vector_operations.hpp +50 -32
- package/src/duckdb/src/include/duckdb/common/virtual_file_system.hpp +10 -11
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/distributive_functions.hpp +1 -1
- package/src/duckdb/src/include/duckdb/core_functions/aggregate/sum_helpers.hpp +13 -1
- package/src/duckdb/src/include/duckdb/core_functions/function_list.hpp +1 -1
- package/src/duckdb/src/include/duckdb/core_functions/lambda_functions.hpp +2 -1
- package/src/duckdb/src/include/duckdb/execution/aggregate_hashtable.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/column_binding_resolver.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/expression_executor.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/expression_executor_state.hpp +2 -5
- package/src/duckdb/src/include/duckdb/execution/merge_sort_tree.hpp +3 -3
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/aggregate_object.hpp +2 -2
- package/src/duckdb/src/include/duckdb/execution/operator/aggregate/distinct_aggregate_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/base_scanner.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/column_count_scanner.hpp +0 -3
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_buffer.hpp +9 -6
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_buffer_manager.hpp +3 -0
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_error.hpp +40 -22
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_file_handle.hpp +5 -0
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_file_scanner.hpp +1 -0
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_option.hpp +6 -4
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_reader_options.hpp +24 -10
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/csv_state_machine.hpp +4 -0
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/global_csv_state.hpp +3 -1
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/skip_scanner.hpp +0 -3
- package/src/duckdb/src/include/duckdb/execution/operator/csv_scanner/string_value_scanner.hpp +58 -17
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_batch_collector.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_explain_analyze.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_prepare.hpp +3 -3
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_set.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/operator/helper/physical_vacuum.hpp +4 -1
- package/src/duckdb/src/include/duckdb/execution/operator/persistent/csv_rejects_table.hpp +16 -5
- package/src/duckdb/src/include/duckdb/execution/physical_operator_states.hpp +6 -6
- package/src/duckdb/src/include/duckdb/execution/physical_plan_generator.hpp +2 -1
- package/src/duckdb/src/include/duckdb/execution/window_executor.hpp +1 -1
- package/src/duckdb/src/include/duckdb/execution/window_segment_tree.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/aggregate_function.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/cast/cast_function_set.hpp +5 -5
- package/src/duckdb/src/include/duckdb/function/cast/default_casts.hpp +4 -4
- package/src/duckdb/src/include/duckdb/function/cast/vector_cast_helpers.hpp +6 -6
- package/src/duckdb/src/include/duckdb/function/compression_function.hpp +4 -4
- package/src/duckdb/src/include/duckdb/function/copy_function.hpp +10 -13
- package/src/duckdb/src/include/duckdb/function/function.hpp +3 -3
- package/src/duckdb/src/include/duckdb/function/function_binder.hpp +24 -23
- package/src/duckdb/src/include/duckdb/function/function_serialization.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/function_set.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/pragma_function.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/scalar/regexp.hpp +3 -3
- package/src/duckdb/src/include/duckdb/function/scalar/strftime_format.hpp +7 -7
- package/src/duckdb/src/include/duckdb/function/scalar/string_functions.hpp +3 -3
- package/src/duckdb/src/include/duckdb/function/scalar_function.hpp +6 -6
- package/src/duckdb/src/include/duckdb/function/table/arrow/arrow_duck_schema.hpp +4 -4
- package/src/duckdb/src/include/duckdb/function/table/arrow.hpp +2 -2
- package/src/duckdb/src/include/duckdb/function/table/read_csv.hpp +1 -3
- package/src/duckdb/src/include/duckdb/function/table/table_scan.hpp +1 -1
- package/src/duckdb/src/include/duckdb/function/table_function.hpp +12 -11
- package/src/duckdb/src/include/duckdb/function/udf_function.hpp +66 -60
- package/src/duckdb/src/include/duckdb/main/appender.hpp +6 -6
- package/src/duckdb/src/include/duckdb/main/attached_database.hpp +3 -1
- package/src/duckdb/src/include/duckdb/main/buffered_data/buffered_data.hpp +2 -2
- package/src/duckdb/src/include/duckdb/main/buffered_data/simple_buffered_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/main/capi/capi_internal.hpp +2 -2
- package/src/duckdb/src/include/duckdb/main/chunk_scan_state/query_result.hpp +2 -2
- package/src/duckdb/src/include/duckdb/main/client_context.hpp +1 -1
- package/src/duckdb/src/include/duckdb/main/client_context_file_opener.hpp +3 -2
- package/src/duckdb/src/include/duckdb/main/client_data.hpp +1 -0
- package/src/duckdb/src/include/duckdb/main/client_properties.hpp +2 -1
- package/src/duckdb/src/include/duckdb/main/config.hpp +14 -5
- package/src/duckdb/src/include/duckdb/main/connection.hpp +27 -26
- package/src/duckdb/src/include/duckdb/main/database.hpp +19 -3
- package/src/duckdb/src/include/duckdb/main/database_file_opener.hpp +58 -0
- package/src/duckdb/src/include/duckdb/main/database_path_and_type.hpp +2 -2
- package/src/duckdb/src/include/duckdb/main/error_manager.hpp +6 -6
- package/src/duckdb/src/include/duckdb/main/extension_entries.hpp +8 -0
- package/src/duckdb/src/include/duckdb/main/extension_helper.hpp +1 -0
- package/src/duckdb/src/include/duckdb/main/external_dependencies.hpp +2 -1
- package/src/duckdb/src/include/duckdb/main/prepared_statement.hpp +8 -8
- package/src/duckdb/src/include/duckdb/main/query_profiler.hpp +2 -59
- package/src/duckdb/src/include/duckdb/main/query_result.hpp +3 -3
- package/src/duckdb/src/include/duckdb/main/relation/query_relation.hpp +1 -1
- package/src/duckdb/src/include/duckdb/main/relation.hpp +1 -1
- package/src/duckdb/src/include/duckdb/main/secret/secret.hpp +11 -7
- package/src/duckdb/src/include/duckdb/main/secret/secret_manager.hpp +2 -2
- package/src/duckdb/src/include/duckdb/main/secret/secret_storage.hpp +4 -4
- package/src/duckdb/src/include/duckdb/main/settings.hpp +78 -70
- package/src/duckdb/src/include/duckdb/optimizer/column_lifetime_analyzer.hpp +45 -0
- package/src/duckdb/src/include/duckdb/optimizer/compressed_materialization.hpp +11 -13
- package/src/duckdb/src/include/duckdb/optimizer/join_order/cardinality_estimator.hpp +2 -2
- package/src/duckdb/src/include/duckdb/optimizer/join_order/cost_model.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/join_order/join_node.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/join_order/query_graph.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/join_order/query_graph_manager.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/join_order/relation_manager.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/matcher/expression_matcher.hpp +7 -7
- package/src/duckdb/src/include/duckdb/optimizer/matcher/function_matcher.hpp +7 -7
- package/src/duckdb/src/include/duckdb/optimizer/matcher/type_matcher.hpp +1 -1
- package/src/duckdb/src/include/duckdb/optimizer/optimizer.hpp +3 -0
- package/src/duckdb/src/include/duckdb/optimizer/statistics_propagator.hpp +32 -30
- package/src/duckdb/src/include/duckdb/optimizer/unnest_rewriter.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parallel/event.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parallel/executor_task.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parallel/interrupt.hpp +2 -2
- package/src/duckdb/src/include/duckdb/parallel/pipeline_event.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/column_list.hpp +4 -4
- package/src/duckdb/src/include/duckdb/parser/constraints/unique_constraint.hpp +49 -8
- package/src/duckdb/src/include/duckdb/parser/expression/bound_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/expression/positional_reference_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/expression/star_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_scalar_function_info.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_table_function_info.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/alter_table_info.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/copy_database_info.hpp +40 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_function_info.hpp +2 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_index_info.hpp +1 -0
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_info.hpp +2 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_macro_info.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_pragma_function_info.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parsed_data/create_secret_info.hpp +2 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/extra_drop_info.hpp +3 -3
- package/src/duckdb/src/include/duckdb/parser/parsed_data/parse_info.hpp +3 -2
- package/src/duckdb/src/include/duckdb/parser/parsed_data/vacuum_info.hpp +2 -5
- package/src/duckdb/src/include/duckdb/parser/parser.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/parser_extension.hpp +3 -3
- package/src/duckdb/src/include/duckdb/parser/query_error_context.hpp +1 -1
- package/src/duckdb/src/include/duckdb/parser/transformer.hpp +3 -5
- package/src/duckdb/src/include/duckdb/planner/bind_context.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/binder.hpp +16 -9
- package/src/duckdb/src/include/duckdb/planner/expression/bound_case_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/expression/bound_cast_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/expression/bound_default_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/expression/bound_expanded_expression.hpp +34 -0
- package/src/duckdb/src/include/duckdb/planner/expression/bound_subquery_expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/expression.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/expression_binder/base_select_binder.hpp +5 -8
- package/src/duckdb/src/include/duckdb/planner/expression_binder/column_alias_binder.hpp +3 -4
- package/src/duckdb/src/include/duckdb/planner/expression_binder/group_binder.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/expression_binder/having_binder.hpp +3 -5
- package/src/duckdb/src/include/duckdb/planner/expression_binder/order_binder.hpp +6 -14
- package/src/duckdb/src/include/duckdb/planner/expression_binder/qualify_binder.hpp +3 -6
- package/src/duckdb/src/include/duckdb/planner/expression_binder/select_bind_state.hpp +52 -0
- package/src/duckdb/src/include/duckdb/planner/expression_binder/select_binder.hpp +4 -10
- package/src/duckdb/src/include/duckdb/planner/expression_binder/table_function_binder.hpp +5 -2
- package/src/duckdb/src/include/duckdb/planner/expression_binder.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/expression_iterator.hpp +2 -0
- package/src/duckdb/src/include/duckdb/planner/filter/conjunction_filter.hpp +3 -6
- package/src/duckdb/src/include/duckdb/planner/logical_operator.hpp +2 -0
- package/src/duckdb/src/include/duckdb/planner/logical_tokens.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/operator/list.hpp +1 -0
- package/src/duckdb/src/include/duckdb/planner/operator/logical_copy_database.hpp +4 -12
- package/src/duckdb/src/include/duckdb/planner/operator/logical_create_secret.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_cteref.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_delim_get.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_dummy_scan.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_explain.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_export.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_expression_get.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_extension_operator.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_materialized_cte.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_pragma.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_prepare.hpp +3 -2
- package/src/duckdb/src/include/duckdb/planner/operator/logical_recursive_cte.hpp +3 -3
- package/src/duckdb/src/include/duckdb/planner/operator/logical_reset.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_set.hpp +2 -1
- package/src/duckdb/src/include/duckdb/planner/operator/logical_vacuum.hpp +52 -0
- package/src/duckdb/src/include/duckdb/planner/operator_extension.hpp +1 -1
- package/src/duckdb/src/include/duckdb/planner/parsed_data/bound_create_table_info.hpp +2 -2
- package/src/duckdb/src/include/duckdb/planner/query_node/bound_select_node.hpp +5 -4
- package/src/duckdb/src/include/duckdb/planner/subquery/flatten_dependent_join.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/arena_allocator.hpp +4 -1
- package/src/duckdb/src/include/duckdb/storage/buffer/block_handle.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/buffer_manager.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/checkpoint/row_group_writer.hpp +2 -3
- package/src/duckdb/src/include/duckdb/storage/checkpoint/string_checkpoint_state.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/checkpoint/table_data_writer.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/checkpoint_manager.hpp +5 -5
- package/src/duckdb/src/include/duckdb/storage/compression/alp/alp_analyze.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alp/alp_compress.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alp/alp_fetch.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alp/alp_scan.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alprd/algorithm/alprd.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/compression/alprd/alprd_analyze.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/compression/alprd/alprd_compress.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alprd/alprd_fetch.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/alprd/alprd_scan.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/algorithm/flag_buffer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/algorithm/leading_zero_buffer.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/chimp.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/chimp_analyze.hpp +0 -1
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/chimp_fetch.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/chimp/chimp_scan.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/compression/patas/patas.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/compression/patas/patas_analyze.hpp +0 -1
- package/src/duckdb/src/include/duckdb/storage/compression/patas/patas_fetch.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/compression/patas/patas_scan.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/data_pointer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/index.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/magic_bytes.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/object_cache.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/optimistic_data_writer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/partial_block_manager.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/single_file_block_manager.hpp +4 -1
- package/src/duckdb/src/include/duckdb/storage/standard_buffer_manager.hpp +24 -24
- package/src/duckdb/src/include/duckdb/storage/statistics/numeric_stats_union.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/statistics/segment_statistics.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/storage_info.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/storage_manager.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/string_uncompressed.hpp +9 -6
- package/src/duckdb/src/include/duckdb/storage/table/append_state.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/chunk_info.hpp +2 -2
- package/src/duckdb/src/include/duckdb/storage/table/column_checkpoint_state.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/column_data.hpp +10 -1
- package/src/duckdb/src/include/duckdb/storage/table/data_table_info.hpp +3 -2
- package/src/duckdb/src/include/duckdb/storage/table/row_group.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/row_group_segment_tree.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/row_version_manager.hpp +2 -1
- package/src/duckdb/src/include/duckdb/storage/table/scan_state.hpp +3 -3
- package/src/duckdb/src/include/duckdb/storage/table/segment_lock.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/segment_tree.hpp +4 -4
- package/src/duckdb/src/include/duckdb/storage/table/standard_column_data.hpp +2 -0
- package/src/duckdb/src/include/duckdb/storage/table/table_index_list.hpp +3 -2
- package/src/duckdb/src/include/duckdb/storage/table/table_statistics.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table/update_segment.hpp +1 -1
- package/src/duckdb/src/include/duckdb/storage/table_storage_info.hpp +2 -1
- package/src/duckdb/src/include/duckdb/storage/write_ahead_log.hpp +1 -1
- package/src/duckdb/src/include/duckdb/transaction/delete_info.hpp +20 -1
- package/src/duckdb/src/include/duckdb/transaction/transaction.hpp +1 -1
- package/src/duckdb/src/include/duckdb/transaction/transaction_data.hpp +1 -1
- package/src/duckdb/src/include/duckdb/transaction/undo_buffer.hpp +1 -1
- package/src/duckdb/src/include/duckdb/transaction/update_info.hpp +1 -1
- package/src/duckdb/src/main/appender.cpp +1 -1
- package/src/duckdb/src/main/attached_database.cpp +11 -3
- package/src/duckdb/src/main/capi/arrow-c.cpp +6 -2
- package/src/duckdb/src/main/capi/cast/utils-c.cpp +1 -1
- package/src/duckdb/src/main/capi/duckdb-c.cpp +1 -1
- package/src/duckdb/src/main/capi/pending-c.cpp +1 -1
- package/src/duckdb/src/main/capi/prepared-c.cpp +2 -2
- package/src/duckdb/src/main/capi/result-c.cpp +4 -4
- package/src/duckdb/src/main/client_context.cpp +4 -12
- package/src/duckdb/src/main/client_context_file_opener.cpp +15 -3
- package/src/duckdb/src/main/client_data.cpp +5 -0
- package/src/duckdb/src/main/config.cpp +82 -82
- package/src/duckdb/src/main/database.cpp +31 -7
- package/src/duckdb/src/main/database_manager.cpp +3 -2
- package/src/duckdb/src/main/database_path_and_type.cpp +4 -4
- package/src/duckdb/src/main/error_manager.cpp +1 -1
- package/src/duckdb/src/main/extension/extension_alias.cpp +9 -9
- package/src/duckdb/src/main/extension/extension_helper.cpp +10 -5
- package/src/duckdb/src/main/extension/extension_install.cpp +1 -1
- package/src/duckdb/src/main/extension/extension_load.cpp +111 -37
- package/src/duckdb/src/main/query_profiler.cpp +1 -118
- package/src/duckdb/src/main/secret/secret_manager.cpp +1 -2
- package/src/duckdb/src/main/secret/secret_storage.cpp +1 -1
- package/src/duckdb/src/main/settings/settings.cpp +81 -65
- package/src/duckdb/src/optimizer/column_lifetime_analyzer.cpp +8 -1
- package/src/duckdb/src/optimizer/compressed_materialization/compress_aggregate.cpp +3 -0
- package/src/duckdb/src/optimizer/compressed_materialization.cpp +26 -28
- package/src/duckdb/src/optimizer/cse_optimizer.cpp +5 -5
- package/src/duckdb/src/optimizer/join_order/cardinality_estimator.cpp +10 -6
- package/src/duckdb/src/optimizer/optimizer.cpp +14 -17
- package/src/duckdb/src/optimizer/pushdown/pushdown_cross_product.cpp +16 -5
- package/src/duckdb/src/optimizer/pushdown/pushdown_inner_join.cpp +7 -4
- package/src/duckdb/src/optimizer/pushdown/pushdown_set_operation.cpp +2 -2
- package/src/duckdb/src/optimizer/remove_unused_columns.cpp +3 -3
- package/src/duckdb/src/optimizer/rule/ordered_aggregate_optimizer.cpp +2 -2
- package/src/duckdb/src/optimizer/statistics/expression/propagate_aggregate.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/expression/propagate_between.cpp +8 -8
- package/src/duckdb/src/optimizer/statistics/expression/propagate_case.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/expression/propagate_cast.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/expression/propagate_columnref.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/expression/propagate_comparison.cpp +7 -7
- package/src/duckdb/src/optimizer/statistics/expression/propagate_conjunction.cpp +6 -6
- package/src/duckdb/src/optimizer/statistics/expression/propagate_constant.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/expression/propagate_function.cpp +2 -2
- package/src/duckdb/src/optimizer/statistics/expression/propagate_operator.cpp +10 -10
- package/src/duckdb/src/optimizer/statistics/operator/propagate_aggregate.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_cross_product.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_filter.cpp +14 -7
- package/src/duckdb/src/optimizer/statistics/operator/propagate_get.cpp +2 -2
- package/src/duckdb/src/optimizer/statistics/operator/propagate_join.cpp +9 -9
- package/src/duckdb/src/optimizer/statistics/operator/propagate_limit.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_order.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_projection.cpp +2 -2
- package/src/duckdb/src/optimizer/statistics/operator/propagate_set_operation.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics/operator/propagate_window.cpp +1 -1
- package/src/duckdb/src/optimizer/statistics_propagator.cpp +39 -18
- package/src/duckdb/src/parallel/pipeline_finish_event.cpp +1 -1
- package/src/duckdb/src/parallel/task_scheduler.cpp +8 -1
- package/src/duckdb/src/parser/constraints/unique_constraint.cpp +4 -2
- package/src/duckdb/src/parser/parsed_data/create_index_info.cpp +64 -0
- package/src/duckdb/src/parser/parsed_data/vacuum_info.cpp +1 -0
- package/src/duckdb/src/parser/transform/expression/transform_function.cpp +13 -5
- package/src/duckdb/src/parser/transform/expression/transform_subquery.cpp +24 -0
- package/src/duckdb/src/parser/transform/helpers/transform_cte.cpp +1 -8
- package/src/duckdb/src/parser/transform/statement/transform_create_function.cpp +2 -1
- package/src/duckdb/src/parser/transform/statement/transform_create_index.cpp +3 -0
- package/src/duckdb/src/parser/transform/statement/transform_delete.cpp +2 -6
- package/src/duckdb/src/parser/transform/statement/transform_insert.cpp +2 -6
- package/src/duckdb/src/parser/transform/statement/transform_pivot_stmt.cpp +2 -6
- package/src/duckdb/src/parser/transform/statement/transform_pragma.cpp +1 -1
- package/src/duckdb/src/parser/transform/statement/transform_select.cpp +5 -2
- package/src/duckdb/src/parser/transform/statement/transform_select_node.cpp +2 -8
- package/src/duckdb/src/parser/transform/statement/transform_update.cpp +1 -6
- package/src/duckdb/src/parser/transform/statement/transform_use.cpp +3 -2
- package/src/duckdb/src/parser/transformer.cpp +14 -2
- package/src/duckdb/src/planner/binder/expression/bind_aggregate_expression.cpp +40 -17
- package/src/duckdb/src/planner/binder/expression/bind_unnest_expression.cpp +8 -3
- package/src/duckdb/src/planner/binder/expression/bind_window_expression.cpp +32 -30
- package/src/duckdb/src/planner/binder/query_node/bind_cte_node.cpp +28 -17
- package/src/duckdb/src/planner/binder/query_node/bind_select_node.cpp +146 -101
- package/src/duckdb/src/planner/binder/query_node/bind_setop_node.cpp +28 -26
- package/src/duckdb/src/planner/binder/query_node/plan_cte_node.cpp +29 -0
- package/src/duckdb/src/planner/binder/query_node/plan_subquery.cpp +10 -10
- package/src/duckdb/src/planner/binder/statement/bind_copy.cpp +3 -2
- package/src/duckdb/src/planner/binder/statement/bind_copy_database.cpp +23 -28
- package/src/duckdb/src/planner/binder/statement/bind_create.cpp +11 -12
- package/src/duckdb/src/planner/binder/statement/bind_create_table.cpp +9 -11
- package/src/duckdb/src/planner/binder/statement/bind_insert.cpp +10 -13
- package/src/duckdb/src/planner/binder/statement/bind_pragma.cpp +3 -3
- package/src/duckdb/src/planner/binder/statement/bind_set.cpp +3 -0
- package/src/duckdb/src/planner/binder/statement/bind_vacuum.cpp +66 -65
- package/src/duckdb/src/planner/binder/tableref/bind_basetableref.cpp +54 -46
- package/src/duckdb/src/planner/binder/tableref/bind_pivot.cpp +3 -0
- package/src/duckdb/src/planner/binder/tableref/bind_subqueryref.cpp +1 -1
- package/src/duckdb/src/planner/binder/tableref/bind_table_function.cpp +5 -5
- package/src/duckdb/src/planner/binder.cpp +78 -6
- package/src/duckdb/src/planner/expression/bound_cast_expression.cpp +11 -3
- package/src/duckdb/src/planner/expression/bound_expanded_expression.cpp +22 -0
- package/src/duckdb/src/planner/expression_binder/base_select_binder.cpp +11 -58
- package/src/duckdb/src/planner/expression_binder/column_alias_binder.cpp +5 -8
- package/src/duckdb/src/planner/expression_binder/group_binder.cpp +5 -4
- package/src/duckdb/src/planner/expression_binder/having_binder.cpp +5 -19
- package/src/duckdb/src/planner/expression_binder/lateral_binder.cpp +8 -8
- package/src/duckdb/src/planner/expression_binder/order_binder.cpp +42 -26
- package/src/duckdb/src/planner/expression_binder/qualify_binder.cpp +3 -22
- package/src/duckdb/src/planner/expression_binder/select_bind_state.cpp +52 -0
- package/src/duckdb/src/planner/expression_binder/select_binder.cpp +43 -5
- package/src/duckdb/src/planner/expression_binder/table_function_binder.cpp +19 -7
- package/src/duckdb/src/planner/logical_operator.cpp +20 -3
- package/src/duckdb/src/planner/operator/logical_copy_database.cpp +4 -14
- package/src/duckdb/src/planner/operator/logical_delete.cpp +1 -1
- package/src/duckdb/src/planner/operator/logical_get.cpp +1 -1
- package/src/duckdb/src/planner/operator/logical_insert.cpp +1 -1
- package/src/duckdb/src/planner/operator/logical_update.cpp +1 -1
- package/src/duckdb/src/planner/operator/logical_vacuum.cpp +65 -0
- package/src/duckdb/src/planner/planner.cpp +4 -4
- package/src/duckdb/src/planner/subquery/flatten_dependent_join.cpp +26 -27
- package/src/duckdb/src/storage/arena_allocator.cpp +9 -0
- package/src/duckdb/src/storage/buffer/buffer_pool_reservation.cpp +1 -1
- package/src/duckdb/src/storage/buffer_manager.cpp +2 -10
- package/src/duckdb/src/storage/checkpoint/table_data_writer.cpp +2 -3
- package/src/duckdb/src/storage/checkpoint_manager.cpp +15 -8
- package/src/duckdb/src/storage/compression/bitpacking.cpp +6 -1
- package/src/duckdb/src/storage/compression/string_uncompressed.cpp +1 -1
- package/src/duckdb/src/storage/data_pointer.cpp +1 -1
- package/src/duckdb/src/storage/data_table.cpp +18 -7
- package/src/duckdb/src/storage/local_storage.cpp +8 -5
- package/src/duckdb/src/storage/magic_bytes.cpp +6 -5
- package/src/duckdb/src/storage/partial_block_manager.cpp +1 -1
- package/src/duckdb/src/storage/serialization/serialize_logical_operator.cpp +20 -9
- package/src/duckdb/src/storage/serialization/serialize_nodes.cpp +12 -10
- package/src/duckdb/src/storage/serialization/serialize_parse_info.cpp +23 -0
- package/src/duckdb/src/storage/single_file_block_manager.cpp +46 -19
- package/src/duckdb/src/storage/standard_buffer_manager.cpp +21 -5
- package/src/duckdb/src/storage/statistics/array_stats.cpp +1 -1
- package/src/duckdb/src/storage/statistics/base_statistics.cpp +2 -3
- package/src/duckdb/src/storage/statistics/list_stats.cpp +1 -1
- package/src/duckdb/src/storage/statistics/struct_stats.cpp +1 -1
- package/src/duckdb/src/storage/storage_info.cpp +19 -19
- package/src/duckdb/src/storage/storage_manager.cpp +18 -13
- package/src/duckdb/src/storage/table/chunk_info.cpp +11 -3
- package/src/duckdb/src/storage/table/column_data.cpp +88 -66
- package/src/duckdb/src/storage/table/row_group.cpp +7 -7
- package/src/duckdb/src/storage/table/row_version_manager.cpp +2 -2
- package/src/duckdb/src/storage/table/standard_column_data.cpp +4 -0
- package/src/duckdb/src/storage/table/update_segment.cpp +3 -1
- package/src/duckdb/src/storage/table_index_list.cpp +6 -1
- package/src/duckdb/src/storage/temporary_file_manager.cpp +1 -1
- package/src/duckdb/src/storage/wal_replay.cpp +8 -7
- package/src/duckdb/src/storage/write_ahead_log.cpp +3 -4
- package/src/duckdb/src/transaction/cleanup_state.cpp +10 -3
- package/src/duckdb/src/transaction/commit_state.cpp +11 -4
- package/src/duckdb/src/transaction/duck_transaction.cpp +23 -3
- package/src/duckdb/src/transaction/rollback_state.cpp +1 -1
- package/src/duckdb/src/transaction/transaction_context.cpp +1 -1
- package/src/duckdb/src/transaction/undo_buffer.cpp +3 -1
- package/src/duckdb/third_party/fmt/include/fmt/core.h +0 -5
- package/src/duckdb/third_party/fsst/fsst.h +1 -1
- package/src/duckdb/third_party/fsst/libfsst.cpp +1 -140
- package/src/duckdb/third_party/fsst/libfsst.hpp +0 -13
- package/src/duckdb/third_party/hyperloglog/hyperloglog.hpp +4 -0
- package/src/duckdb/third_party/libpg_query/include/nodes/parsenodes.hpp +8 -1
- package/src/duckdb/third_party/libpg_query/include/parser/gram.hpp +2 -1
- package/src/duckdb/third_party/libpg_query/src_backend_parser_gram.cpp +15401 -15354
- package/src/duckdb/third_party/libpg_query/src_backend_parser_scan.cpp +299 -538
- package/src/duckdb/third_party/lz4/lz4.cpp +2605 -0
- package/src/duckdb/third_party/lz4/lz4.hpp +843 -0
- package/src/duckdb/third_party/parquet/parquet_types.cpp +3 -0
- package/src/duckdb/third_party/parquet/parquet_types.h +2 -1
- package/src/duckdb/third_party/re2/re2/bitmap256.cc +44 -0
- package/src/duckdb/third_party/re2/re2/bitmap256.h +3 -35
- package/src/duckdb/third_party/re2/re2/bitstate.cc +31 -24
- package/src/duckdb/third_party/re2/re2/compile.cc +146 -164
- package/src/duckdb/third_party/re2/re2/dfa.cc +174 -181
- package/src/duckdb/third_party/re2/re2/filtered_re2.cc +19 -3
- package/src/duckdb/third_party/re2/re2/filtered_re2.h +27 -23
- package/src/duckdb/third_party/re2/re2/mimics_pcre.cc +21 -11
- package/src/duckdb/third_party/re2/re2/nfa.cc +91 -131
- package/src/duckdb/third_party/re2/re2/onepass.cc +11 -10
- package/src/duckdb/third_party/re2/re2/parse.cc +171 -154
- package/src/duckdb/third_party/re2/re2/perl_groups.cc +35 -35
- package/src/duckdb/third_party/re2/re2/pod_array.h +55 -0
- package/src/duckdb/third_party/re2/re2/prefilter.cc +40 -40
- package/src/duckdb/third_party/re2/re2/prefilter.h +24 -2
- package/src/duckdb/third_party/re2/re2/prefilter_tree.cc +70 -84
- package/src/duckdb/third_party/re2/re2/prefilter_tree.h +5 -4
- package/src/duckdb/third_party/re2/re2/prog.cc +315 -58
- package/src/duckdb/third_party/re2/re2/prog.h +77 -44
- package/src/duckdb/third_party/re2/re2/re2.cc +333 -221
- package/src/duckdb/third_party/re2/re2/re2.h +277 -201
- package/src/duckdb/third_party/re2/re2/regexp.cc +137 -105
- package/src/duckdb/third_party/re2/re2/regexp.h +45 -40
- package/src/duckdb/third_party/re2/re2/set.cc +40 -17
- package/src/duckdb/third_party/re2/re2/set.h +11 -6
- package/src/duckdb/third_party/re2/re2/simplify.cc +50 -41
- package/src/duckdb/third_party/re2/re2/sparse_array.h +392 -0
- package/src/duckdb/third_party/re2/re2/sparse_set.h +264 -0
- package/src/duckdb/third_party/re2/re2/stringpiece.cc +1 -1
- package/src/duckdb/third_party/re2/re2/stringpiece.h +11 -8
- package/src/duckdb/third_party/re2/re2/tostring.cc +8 -6
- package/src/duckdb/third_party/re2/re2/unicode_casefold.cc +39 -10
- package/src/duckdb/third_party/re2/re2/unicode_casefold.h +1 -1
- package/src/duckdb/third_party/re2/re2/unicode_groups.cc +5019 -4566
- package/src/duckdb/third_party/re2/re2/unicode_groups.h +1 -1
- package/src/duckdb/third_party/re2/re2/walker-inl.h +21 -20
- package/src/duckdb/third_party/re2/util/logging.h +14 -18
- package/src/duckdb/third_party/re2/util/mix.h +4 -4
- package/src/duckdb/third_party/re2/util/mutex.h +48 -15
- package/src/duckdb/third_party/re2/util/rune.cc +5 -5
- package/src/duckdb/third_party/re2/util/strutil.cc +1 -16
- package/src/duckdb/third_party/re2/util/strutil.h +1 -3
- package/src/duckdb/third_party/re2/util/utf.h +1 -1
- package/src/duckdb/third_party/re2/util/util.h +9 -1
- package/src/duckdb/third_party/utf8proc/include/utf8proc_wrapper.hpp +2 -0
- package/src/duckdb/third_party/utf8proc/utf8proc_wrapper.cpp +36 -1
- package/src/duckdb/ub_src_common.cpp +0 -2
- package/src/duckdb/ub_src_execution_physical_plan.cpp +2 -0
- package/src/duckdb/ub_src_planner_expression.cpp +2 -0
- package/src/duckdb/ub_src_planner_expression_binder.cpp +2 -0
- package/src/duckdb/ub_src_planner_operator.cpp +2 -0
|
@@ -9,23 +9,56 @@
|
|
|
9
9
|
#pragma once
|
|
10
10
|
|
|
11
11
|
#include "duckdb/catalog/catalog_entry_map.hpp"
|
|
12
|
+
#include "duckdb/common/types/hash.hpp"
|
|
13
|
+
#include "duckdb/common/enums/catalog_type.hpp"
|
|
14
|
+
#include "duckdb/catalog/dependency.hpp"
|
|
12
15
|
|
|
13
16
|
namespace duckdb {
|
|
14
17
|
class Catalog;
|
|
15
18
|
class CatalogEntry;
|
|
16
|
-
|
|
19
|
+
struct CreateInfo;
|
|
20
|
+
class SchemaCatalogEntry;
|
|
21
|
+
struct CatalogTransaction;
|
|
22
|
+
class LogicalDependencyList;
|
|
17
23
|
|
|
18
|
-
//!
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
24
|
+
//! A minimal representation of a CreateInfo / CatalogEntry
|
|
25
|
+
//! enough to look up the entry inside SchemaCatalogEntry::GetEntry
|
|
26
|
+
struct LogicalDependency {
|
|
27
|
+
public:
|
|
28
|
+
CatalogEntryInfo entry;
|
|
29
|
+
string catalog;
|
|
30
|
+
|
|
31
|
+
public:
|
|
32
|
+
explicit LogicalDependency(CatalogEntry &entry);
|
|
33
|
+
LogicalDependency();
|
|
34
|
+
bool operator==(const LogicalDependency &other) const;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
struct LogicalDependencyHashFunction {
|
|
38
|
+
uint64_t operator()(const LogicalDependency &a) const;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
struct LogicalDependencyEquality {
|
|
42
|
+
bool operator()(const LogicalDependency &a, const LogicalDependency &b) const;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
//! The DependencyList containing LogicalDependency objects, not looked up in the catalog yet
|
|
46
|
+
class LogicalDependencyList {
|
|
47
|
+
using create_info_set_t =
|
|
48
|
+
unordered_set<LogicalDependency, LogicalDependencyHashFunction, LogicalDependencyEquality>;
|
|
22
49
|
|
|
23
50
|
public:
|
|
24
51
|
DUCKDB_API void AddDependency(CatalogEntry &entry);
|
|
52
|
+
DUCKDB_API void AddDependency(const LogicalDependency &entry);
|
|
53
|
+
DUCKDB_API bool Contains(CatalogEntry &entry);
|
|
25
54
|
|
|
55
|
+
public:
|
|
26
56
|
DUCKDB_API void VerifyDependencies(Catalog &catalog, const string &name);
|
|
57
|
+
bool operator==(const LogicalDependencyList &other) const;
|
|
58
|
+
const create_info_set_t &Set() const;
|
|
27
59
|
|
|
28
60
|
private:
|
|
29
|
-
|
|
61
|
+
create_info_set_t set;
|
|
30
62
|
};
|
|
63
|
+
|
|
31
64
|
} // namespace duckdb
|
|
@@ -13,21 +13,16 @@
|
|
|
13
13
|
#include "duckdb/catalog/dependency.hpp"
|
|
14
14
|
#include "duckdb/catalog/catalog_entry_map.hpp"
|
|
15
15
|
#include "duckdb/catalog/catalog_transaction.hpp"
|
|
16
|
+
#include "duckdb/common/stack.hpp"
|
|
17
|
+
#include "duckdb/common/string_util.hpp"
|
|
16
18
|
|
|
17
19
|
#include <functional>
|
|
18
20
|
|
|
19
21
|
namespace duckdb {
|
|
20
22
|
class DuckCatalog;
|
|
21
23
|
class ClientContext;
|
|
22
|
-
class DependencyList;
|
|
23
24
|
class DependencyEntry;
|
|
24
|
-
class
|
|
25
|
-
|
|
26
|
-
struct CatalogEntryInfo {
|
|
27
|
-
CatalogType type;
|
|
28
|
-
string schema;
|
|
29
|
-
string name;
|
|
30
|
-
};
|
|
25
|
+
class LogicalDependencyList;
|
|
31
26
|
|
|
32
27
|
// The subject of this dependency
|
|
33
28
|
struct DependencySubject {
|
|
@@ -57,12 +52,20 @@ public:
|
|
|
57
52
|
|
|
58
53
|
struct MangledEntryName {
|
|
59
54
|
public:
|
|
60
|
-
MangledEntryName(const CatalogEntryInfo &info);
|
|
55
|
+
explicit MangledEntryName(const CatalogEntryInfo &info);
|
|
61
56
|
MangledEntryName() = delete;
|
|
62
57
|
|
|
63
58
|
public:
|
|
64
59
|
//! Format: Type\0Schema\0Name
|
|
65
60
|
string name;
|
|
61
|
+
|
|
62
|
+
public:
|
|
63
|
+
bool operator==(const MangledEntryName &other) const {
|
|
64
|
+
return StringUtil::CIEquals(other.name, name);
|
|
65
|
+
}
|
|
66
|
+
bool operator!=(const MangledEntryName &other) const {
|
|
67
|
+
return !(*this == other);
|
|
68
|
+
}
|
|
66
69
|
};
|
|
67
70
|
|
|
68
71
|
struct MangledDependencyName {
|
|
@@ -78,7 +81,6 @@ public:
|
|
|
78
81
|
//! The DependencyManager is in charge of managing dependencies between catalog entries
|
|
79
82
|
class DependencyManager {
|
|
80
83
|
friend class CatalogSet;
|
|
81
|
-
friend class DependencySetCatalogEntry;
|
|
82
84
|
|
|
83
85
|
public:
|
|
84
86
|
explicit DependencyManager(DuckCatalog &catalog);
|
|
@@ -96,24 +98,27 @@ private:
|
|
|
96
98
|
|
|
97
99
|
private:
|
|
98
100
|
bool IsSystemEntry(CatalogEntry &entry) const;
|
|
101
|
+
optional_ptr<CatalogEntry> LookupEntry(CatalogTransaction transaction, const LogicalDependency &dependency);
|
|
99
102
|
optional_ptr<CatalogEntry> LookupEntry(CatalogTransaction transaction, CatalogEntry &dependency);
|
|
100
103
|
|
|
101
104
|
void CleanupDependencies(CatalogTransaction transaction, CatalogEntry &entry);
|
|
102
105
|
|
|
103
106
|
public:
|
|
104
|
-
static string GetSchema(CatalogEntry &entry);
|
|
107
|
+
static string GetSchema(const CatalogEntry &entry);
|
|
105
108
|
static MangledEntryName MangleName(const CatalogEntryInfo &info);
|
|
106
|
-
static MangledEntryName MangleName(CatalogEntry &entry);
|
|
107
|
-
static CatalogEntryInfo GetLookupProperties(CatalogEntry &entry);
|
|
109
|
+
static MangledEntryName MangleName(const CatalogEntry &entry);
|
|
110
|
+
static CatalogEntryInfo GetLookupProperties(const CatalogEntry &entry);
|
|
108
111
|
|
|
109
112
|
private:
|
|
110
|
-
void AddObject(CatalogTransaction transaction, CatalogEntry &object, const
|
|
113
|
+
void AddObject(CatalogTransaction transaction, CatalogEntry &object, const LogicalDependencyList &dependencies);
|
|
111
114
|
void DropObject(CatalogTransaction transaction, CatalogEntry &object, bool cascade);
|
|
112
115
|
void AlterObject(CatalogTransaction transaction, CatalogEntry &old_obj, CatalogEntry &new_obj);
|
|
113
116
|
|
|
114
117
|
private:
|
|
115
118
|
void RemoveDependency(CatalogTransaction transaction, const DependencyInfo &info);
|
|
116
119
|
void CreateDependency(CatalogTransaction transaction, DependencyInfo &info);
|
|
120
|
+
void CreateDependencies(CatalogTransaction transaction, const CatalogEntry &object,
|
|
121
|
+
const LogicalDependencyList &dependencies);
|
|
117
122
|
using dependency_entry_func_t = const std::function<unique_ptr<DependencyEntry>(
|
|
118
123
|
Catalog &catalog, const DependencyDependent &dependent, const DependencySubject &dependency)>;
|
|
119
124
|
|
|
@@ -9,6 +9,7 @@
|
|
|
9
9
|
#pragma once
|
|
10
10
|
|
|
11
11
|
#include "duckdb/catalog/catalog_entry.hpp"
|
|
12
|
+
#include "duckdb/catalog/dependency_list.hpp"
|
|
12
13
|
|
|
13
14
|
namespace duckdb {
|
|
14
15
|
class SchemaCatalogEntry;
|
|
@@ -29,6 +30,9 @@ public:
|
|
|
29
30
|
SchemaCatalogEntry &ParentSchema() override {
|
|
30
31
|
return schema;
|
|
31
32
|
}
|
|
33
|
+
const SchemaCatalogEntry &ParentSchema() const override {
|
|
34
|
+
return schema;
|
|
35
|
+
}
|
|
32
36
|
};
|
|
33
37
|
|
|
34
38
|
} // namespace duckdb
|
|
@@ -36,7 +36,7 @@ struct PrivateAllocatorData {
|
|
|
36
36
|
}
|
|
37
37
|
template <class TARGET>
|
|
38
38
|
const TARGET &Cast() const {
|
|
39
|
-
|
|
39
|
+
DynamicCastCheck<TARGET>(this);
|
|
40
40
|
return reinterpret_cast<const TARGET &>(*this);
|
|
41
41
|
}
|
|
42
42
|
};
|
|
@@ -58,10 +58,10 @@ public:
|
|
|
58
58
|
DUCKDB_API AllocatedData(AllocatedData &&other) noexcept;
|
|
59
59
|
DUCKDB_API AllocatedData &operator=(AllocatedData &&) noexcept;
|
|
60
60
|
|
|
61
|
-
data_ptr_t get() {
|
|
61
|
+
data_ptr_t get() { // NOLINT: matching std style
|
|
62
62
|
return pointer;
|
|
63
63
|
}
|
|
64
|
-
const_data_ptr_t get() const {
|
|
64
|
+
const_data_ptr_t get() const { // NOLINT: matching std style
|
|
65
65
|
return pointer;
|
|
66
66
|
}
|
|
67
67
|
idx_t GetSize() const {
|
|
@@ -35,7 +35,7 @@ public:
|
|
|
35
35
|
arrow_array.length = 0;
|
|
36
36
|
arrow_array.release = nullptr;
|
|
37
37
|
}
|
|
38
|
-
ArrowArrayWrapper(ArrowArrayWrapper &&other) : arrow_array(other.arrow_array) {
|
|
38
|
+
ArrowArrayWrapper(ArrowArrayWrapper &&other) noexcept : arrow_array(other.arrow_array) {
|
|
39
39
|
other.arrow_array.release = nullptr;
|
|
40
40
|
}
|
|
41
41
|
~ArrowArrayWrapper();
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
#include "duckdb/common/hugeint.hpp"
|
|
12
12
|
#include "duckdb/common/uhugeint.hpp"
|
|
13
13
|
|
|
14
|
-
#
|
|
14
|
+
#if defined(_MSC_VER) && !defined(__clang__)
|
|
15
15
|
#define __restrict__
|
|
16
16
|
#define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__
|
|
17
17
|
#define __ORDER_LITTLE_ENDIAN__ 2
|
|
@@ -37,22 +37,22 @@ struct BoxRendererConfig {
|
|
|
37
37
|
RenderMode render_mode = RenderMode::ROWS;
|
|
38
38
|
|
|
39
39
|
#ifndef DUCKDB_ASCII_TREE_RENDERER
|
|
40
|
-
const char *LTCORNER = "\342\224\214"; // "┌";
|
|
41
|
-
const char *RTCORNER = "\342\224\220"; // "┐";
|
|
42
|
-
const char *LDCORNER = "\342\224\224"; // "└";
|
|
43
|
-
const char *RDCORNER = "\342\224\230"; // "┘";
|
|
44
|
-
|
|
45
|
-
const char *MIDDLE = "\342\224\274"; // "┼";
|
|
46
|
-
const char *TMIDDLE = "\342\224\254"; // "┬";
|
|
47
|
-
const char *LMIDDLE = "\342\224\234"; // "├";
|
|
48
|
-
const char *RMIDDLE = "\342\224\244"; // "┤";
|
|
49
|
-
const char *DMIDDLE = "\342\224\264"; // "┴";
|
|
50
|
-
|
|
51
|
-
const char *VERTICAL = "\342\224\202"; // "│";
|
|
52
|
-
const char *HORIZONTAL = "\342\224\200"; // "─";
|
|
53
|
-
|
|
54
|
-
const char *DOTDOTDOT = "\xE2\x80\xA6"; // "…";
|
|
55
|
-
const char *DOT = "\xC2\xB7"; // "·";
|
|
40
|
+
const char *LTCORNER = "\342\224\214"; // NOLINT: "┌";
|
|
41
|
+
const char *RTCORNER = "\342\224\220"; // NOLINT: "┐";
|
|
42
|
+
const char *LDCORNER = "\342\224\224"; // NOLINT: "└";
|
|
43
|
+
const char *RDCORNER = "\342\224\230"; // NOLINT: "┘";
|
|
44
|
+
|
|
45
|
+
const char *MIDDLE = "\342\224\274"; // NOLINT: "┼";
|
|
46
|
+
const char *TMIDDLE = "\342\224\254"; // NOLINT: "┬";
|
|
47
|
+
const char *LMIDDLE = "\342\224\234"; // NOLINT: "├";
|
|
48
|
+
const char *RMIDDLE = "\342\224\244"; // NOLINT: "┤";
|
|
49
|
+
const char *DMIDDLE = "\342\224\264"; // NOLINT: "┴";
|
|
50
|
+
|
|
51
|
+
const char *VERTICAL = "\342\224\202"; // NOLINT: "│";
|
|
52
|
+
const char *HORIZONTAL = "\342\224\200"; // NOLINT: "─";
|
|
53
|
+
|
|
54
|
+
const char *DOTDOTDOT = "\xE2\x80\xA6"; // NOLINT: "…";
|
|
55
|
+
const char *DOT = "\xC2\xB7"; // NOLINT: "·";
|
|
56
56
|
const idx_t DOTDOTDOT_LENGTH = 1;
|
|
57
57
|
|
|
58
58
|
#else
|
|
@@ -58,6 +58,8 @@ enum class AppenderType : uint8_t;
|
|
|
58
58
|
|
|
59
59
|
enum class ArrowDateTimeType : uint8_t;
|
|
60
60
|
|
|
61
|
+
enum class ArrowOffsetSize : uint8_t;
|
|
62
|
+
|
|
61
63
|
enum class ArrowVariableSizeType : uint8_t;
|
|
62
64
|
|
|
63
65
|
enum class BindingMode : uint8_t;
|
|
@@ -112,6 +114,8 @@ enum class ErrorType : uint16_t;
|
|
|
112
114
|
|
|
113
115
|
enum class ExceptionFormatValueType : uint8_t;
|
|
114
116
|
|
|
117
|
+
enum class ExceptionType : uint8_t;
|
|
118
|
+
|
|
115
119
|
enum class ExplainOutputType : uint8_t;
|
|
116
120
|
|
|
117
121
|
enum class ExplainType : uint8_t;
|
|
@@ -122,6 +126,8 @@ enum class ExpressionType : uint8_t;
|
|
|
122
126
|
|
|
123
127
|
enum class ExtensionLoadResult : uint8_t;
|
|
124
128
|
|
|
129
|
+
enum class ExternalDependenciesType : uint8_t;
|
|
130
|
+
|
|
125
131
|
enum class ExtraDropInfoType : uint8_t;
|
|
126
132
|
|
|
127
133
|
enum class ExtraTypeInfoType : uint8_t;
|
|
@@ -236,6 +242,8 @@ enum class ResultModifierType : uint8_t;
|
|
|
236
242
|
|
|
237
243
|
enum class SampleMethod : uint8_t;
|
|
238
244
|
|
|
245
|
+
enum class ScanType : uint8_t;
|
|
246
|
+
|
|
239
247
|
enum class SecretDisplayType : uint8_t;
|
|
240
248
|
|
|
241
249
|
enum class SecretPersistType : uint8_t;
|
|
@@ -356,6 +364,9 @@ const char* EnumUtil::ToChars<AppenderType>(AppenderType value);
|
|
|
356
364
|
template<>
|
|
357
365
|
const char* EnumUtil::ToChars<ArrowDateTimeType>(ArrowDateTimeType value);
|
|
358
366
|
|
|
367
|
+
template<>
|
|
368
|
+
const char* EnumUtil::ToChars<ArrowOffsetSize>(ArrowOffsetSize value);
|
|
369
|
+
|
|
359
370
|
template<>
|
|
360
371
|
const char* EnumUtil::ToChars<ArrowVariableSizeType>(ArrowVariableSizeType value);
|
|
361
372
|
|
|
@@ -437,6 +448,9 @@ const char* EnumUtil::ToChars<ErrorType>(ErrorType value);
|
|
|
437
448
|
template<>
|
|
438
449
|
const char* EnumUtil::ToChars<ExceptionFormatValueType>(ExceptionFormatValueType value);
|
|
439
450
|
|
|
451
|
+
template<>
|
|
452
|
+
const char* EnumUtil::ToChars<ExceptionType>(ExceptionType value);
|
|
453
|
+
|
|
440
454
|
template<>
|
|
441
455
|
const char* EnumUtil::ToChars<ExplainOutputType>(ExplainOutputType value);
|
|
442
456
|
|
|
@@ -452,6 +466,9 @@ const char* EnumUtil::ToChars<ExpressionType>(ExpressionType value);
|
|
|
452
466
|
template<>
|
|
453
467
|
const char* EnumUtil::ToChars<ExtensionLoadResult>(ExtensionLoadResult value);
|
|
454
468
|
|
|
469
|
+
template<>
|
|
470
|
+
const char* EnumUtil::ToChars<ExternalDependenciesType>(ExternalDependenciesType value);
|
|
471
|
+
|
|
455
472
|
template<>
|
|
456
473
|
const char* EnumUtil::ToChars<ExtraDropInfoType>(ExtraDropInfoType value);
|
|
457
474
|
|
|
@@ -623,6 +640,9 @@ const char* EnumUtil::ToChars<ResultModifierType>(ResultModifierType value);
|
|
|
623
640
|
template<>
|
|
624
641
|
const char* EnumUtil::ToChars<SampleMethod>(SampleMethod value);
|
|
625
642
|
|
|
643
|
+
template<>
|
|
644
|
+
const char* EnumUtil::ToChars<ScanType>(ScanType value);
|
|
645
|
+
|
|
626
646
|
template<>
|
|
627
647
|
const char* EnumUtil::ToChars<SecretDisplayType>(SecretDisplayType value);
|
|
628
648
|
|
|
@@ -783,6 +803,9 @@ AppenderType EnumUtil::FromString<AppenderType>(const char *value);
|
|
|
783
803
|
template<>
|
|
784
804
|
ArrowDateTimeType EnumUtil::FromString<ArrowDateTimeType>(const char *value);
|
|
785
805
|
|
|
806
|
+
template<>
|
|
807
|
+
ArrowOffsetSize EnumUtil::FromString<ArrowOffsetSize>(const char *value);
|
|
808
|
+
|
|
786
809
|
template<>
|
|
787
810
|
ArrowVariableSizeType EnumUtil::FromString<ArrowVariableSizeType>(const char *value);
|
|
788
811
|
|
|
@@ -864,6 +887,9 @@ ErrorType EnumUtil::FromString<ErrorType>(const char *value);
|
|
|
864
887
|
template<>
|
|
865
888
|
ExceptionFormatValueType EnumUtil::FromString<ExceptionFormatValueType>(const char *value);
|
|
866
889
|
|
|
890
|
+
template<>
|
|
891
|
+
ExceptionType EnumUtil::FromString<ExceptionType>(const char *value);
|
|
892
|
+
|
|
867
893
|
template<>
|
|
868
894
|
ExplainOutputType EnumUtil::FromString<ExplainOutputType>(const char *value);
|
|
869
895
|
|
|
@@ -879,6 +905,9 @@ ExpressionType EnumUtil::FromString<ExpressionType>(const char *value);
|
|
|
879
905
|
template<>
|
|
880
906
|
ExtensionLoadResult EnumUtil::FromString<ExtensionLoadResult>(const char *value);
|
|
881
907
|
|
|
908
|
+
template<>
|
|
909
|
+
ExternalDependenciesType EnumUtil::FromString<ExternalDependenciesType>(const char *value);
|
|
910
|
+
|
|
882
911
|
template<>
|
|
883
912
|
ExtraDropInfoType EnumUtil::FromString<ExtraDropInfoType>(const char *value);
|
|
884
913
|
|
|
@@ -1050,6 +1079,9 @@ ResultModifierType EnumUtil::FromString<ResultModifierType>(const char *value);
|
|
|
1050
1079
|
template<>
|
|
1051
1080
|
SampleMethod EnumUtil::FromString<SampleMethod>(const char *value);
|
|
1052
1081
|
|
|
1082
|
+
template<>
|
|
1083
|
+
ScanType EnumUtil::FromString<ScanType>(const char *value);
|
|
1084
|
+
|
|
1053
1085
|
template<>
|
|
1054
1086
|
SecretDisplayType EnumUtil::FromString<SecretDisplayType>(const char *value);
|
|
1055
1087
|
|
|
@@ -145,7 +145,8 @@ enum class ExpressionType : uint8_t {
|
|
|
145
145
|
COLLATE = 230,
|
|
146
146
|
LAMBDA = 231,
|
|
147
147
|
POSITIONAL_REFERENCE = 232,
|
|
148
|
-
BOUND_LAMBDA_REF = 233
|
|
148
|
+
BOUND_LAMBDA_REF = 233,
|
|
149
|
+
BOUND_EXPANDED = 234
|
|
149
150
|
};
|
|
150
151
|
|
|
151
152
|
//===--------------------------------------------------------------------===//
|
|
@@ -199,7 +200,8 @@ enum class ExpressionClass : uint8_t {
|
|
|
199
200
|
//===--------------------------------------------------------------------===//
|
|
200
201
|
// Miscellaneous
|
|
201
202
|
//===--------------------------------------------------------------------===//
|
|
202
|
-
BOUND_EXPRESSION = 50
|
|
203
|
+
BOUND_EXPRESSION = 50,
|
|
204
|
+
BOUND_EXPANDED = 51
|
|
203
205
|
};
|
|
204
206
|
|
|
205
207
|
DUCKDB_API string ExpressionTypeToString(ExpressionType type);
|
|
@@ -18,23 +18,27 @@ public:
|
|
|
18
18
|
DUCKDB_API explicit BinderException(const string &msg, const unordered_map<string, string> &extra_info);
|
|
19
19
|
DUCKDB_API explicit BinderException(const string &msg);
|
|
20
20
|
|
|
21
|
-
template <typename...
|
|
22
|
-
explicit BinderException(const string &msg,
|
|
21
|
+
template <typename... ARGS>
|
|
22
|
+
explicit BinderException(const string &msg, ARGS... params) : BinderException(ConstructMessage(msg, params...)) {
|
|
23
23
|
}
|
|
24
|
-
template <typename...
|
|
25
|
-
explicit BinderException(const TableRef &ref, const string &msg,
|
|
24
|
+
template <typename... ARGS>
|
|
25
|
+
explicit BinderException(const TableRef &ref, const string &msg, ARGS... params)
|
|
26
26
|
: BinderException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(ref)) {
|
|
27
27
|
}
|
|
28
|
-
template <typename...
|
|
29
|
-
explicit BinderException(const ParsedExpression &expr, const string &msg,
|
|
28
|
+
template <typename... ARGS>
|
|
29
|
+
explicit BinderException(const ParsedExpression &expr, const string &msg, ARGS... params)
|
|
30
30
|
: BinderException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(expr)) {
|
|
31
31
|
}
|
|
32
|
-
template <typename...
|
|
33
|
-
explicit BinderException(
|
|
32
|
+
template <typename... ARGS>
|
|
33
|
+
explicit BinderException(const Expression &expr, const string &msg, ARGS... params)
|
|
34
|
+
: BinderException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(expr)) {
|
|
35
|
+
}
|
|
36
|
+
template <typename... ARGS>
|
|
37
|
+
explicit BinderException(QueryErrorContext error_context, const string &msg, ARGS... params)
|
|
34
38
|
: BinderException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(error_context)) {
|
|
35
39
|
}
|
|
36
|
-
template <typename...
|
|
37
|
-
explicit BinderException(optional_idx error_location, const string &msg,
|
|
40
|
+
template <typename... ARGS>
|
|
41
|
+
explicit BinderException(optional_idx error_location, const string &msg, ARGS... params)
|
|
38
42
|
: BinderException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(error_location)) {
|
|
39
43
|
}
|
|
40
44
|
|
|
@@ -20,11 +20,11 @@ public:
|
|
|
20
20
|
DUCKDB_API explicit CatalogException(const string &msg);
|
|
21
21
|
DUCKDB_API explicit CatalogException(const string &msg, const unordered_map<string, string> &extra_info);
|
|
22
22
|
|
|
23
|
-
template <typename...
|
|
24
|
-
explicit CatalogException(const string &msg,
|
|
23
|
+
template <typename... ARGS>
|
|
24
|
+
explicit CatalogException(const string &msg, ARGS... params) : CatalogException(ConstructMessage(msg, params...)) {
|
|
25
25
|
}
|
|
26
|
-
template <typename...
|
|
27
|
-
explicit CatalogException(QueryErrorContext error_context, const string &msg,
|
|
26
|
+
template <typename... ARGS>
|
|
27
|
+
explicit CatalogException(QueryErrorContext error_context, const string &msg, ARGS... params)
|
|
28
28
|
: CatalogException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(error_context)) {
|
|
29
29
|
}
|
|
30
30
|
|
|
@@ -17,15 +17,15 @@ class ConversionException : public Exception {
|
|
|
17
17
|
public:
|
|
18
18
|
DUCKDB_API explicit ConversionException(const string &msg);
|
|
19
19
|
DUCKDB_API explicit ConversionException(optional_idx error_location, const string &msg);
|
|
20
|
-
DUCKDB_API ConversionException(const PhysicalType
|
|
21
|
-
DUCKDB_API ConversionException(const LogicalType &
|
|
20
|
+
DUCKDB_API ConversionException(const PhysicalType orig_type, const PhysicalType new_type);
|
|
21
|
+
DUCKDB_API ConversionException(const LogicalType &orig_type, const LogicalType &new_type);
|
|
22
22
|
|
|
23
|
-
template <typename...
|
|
24
|
-
explicit ConversionException(const string &msg,
|
|
23
|
+
template <typename... ARGS>
|
|
24
|
+
explicit ConversionException(const string &msg, ARGS... params)
|
|
25
25
|
: ConversionException(ConstructMessage(msg, params...)) {
|
|
26
26
|
}
|
|
27
|
-
template <typename...
|
|
28
|
-
explicit ConversionException(optional_idx error_location, const string &msg,
|
|
27
|
+
template <typename... ARGS>
|
|
28
|
+
explicit ConversionException(optional_idx error_location, const string &msg, ARGS... params)
|
|
29
29
|
: ConversionException(error_location, ConstructMessage(msg, params...)) {
|
|
30
30
|
}
|
|
31
31
|
};
|
|
@@ -17,10 +17,10 @@ class HTTPException : public Exception {
|
|
|
17
17
|
public:
|
|
18
18
|
template <typename>
|
|
19
19
|
struct ResponseShape {
|
|
20
|
-
typedef int status;
|
|
20
|
+
typedef int status; // NOLINT
|
|
21
21
|
};
|
|
22
22
|
|
|
23
|
-
explicit HTTPException(string message) : Exception(ExceptionType::HTTP,
|
|
23
|
+
explicit HTTPException(const string &message) : Exception(ExceptionType::HTTP, message) {
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
template <class RESPONSE, typename ResponseShape<decltype(RESPONSE::status)>::status = 0, typename... ARGS>
|
|
@@ -30,7 +30,7 @@ public:
|
|
|
30
30
|
|
|
31
31
|
template <typename>
|
|
32
32
|
struct ResponseWrapperShape {
|
|
33
|
-
typedef int code;
|
|
33
|
+
typedef int code; // NOLINT
|
|
34
34
|
};
|
|
35
35
|
|
|
36
36
|
template <class RESPONSE, typename ResponseWrapperShape<decltype(RESPONSE::code)>::code = 0, typename... ARGS>
|
|
@@ -19,11 +19,11 @@ public:
|
|
|
19
19
|
DUCKDB_API explicit ParserException(const string &msg);
|
|
20
20
|
DUCKDB_API explicit ParserException(const string &msg, const unordered_map<string, string> &extra_info);
|
|
21
21
|
|
|
22
|
-
template <typename...
|
|
23
|
-
explicit ParserException(const string &msg,
|
|
22
|
+
template <typename... ARGS>
|
|
23
|
+
explicit ParserException(const string &msg, ARGS... params) : ParserException(ConstructMessage(msg, params...)) {
|
|
24
24
|
}
|
|
25
|
-
template <typename...
|
|
26
|
-
explicit ParserException(optional_idx error_location, const string &msg,
|
|
25
|
+
template <typename... ARGS>
|
|
26
|
+
explicit ParserException(optional_idx error_location, const string &msg, ARGS... params)
|
|
27
27
|
: ParserException(ConstructMessage(msg, params...), Exception::InitializeExtraInfo(error_location)) {
|
|
28
28
|
}
|
|
29
29
|
|
|
@@ -16,8 +16,8 @@ class TransactionException : public Exception {
|
|
|
16
16
|
public:
|
|
17
17
|
DUCKDB_API explicit TransactionException(const string &msg);
|
|
18
18
|
|
|
19
|
-
template <typename...
|
|
20
|
-
explicit TransactionException(const string &msg,
|
|
19
|
+
template <typename... ARGS>
|
|
20
|
+
explicit TransactionException(const string &msg, ARGS... params)
|
|
21
21
|
: TransactionException(ConstructMessage(msg, params...)) {
|
|
22
22
|
}
|
|
23
23
|
};
|