From 618e7ee333cc2ee4a33b0dff989eb8d735228c99 Mon Sep 17 00:00:00 2001 From: John Kerl Date: Wed, 28 Aug 2024 10:29:54 -0400 Subject: [PATCH 1/2] Support setting of schema-creation timestamp [WIP] --- .../c_api/array_schema/array_schema_api.cc | 34 +++++++++++++++++++ .../array_schema/array_schema_api_external.h | 25 ++++++++++++++ tiledb/sm/array/array.cc | 2 +- tiledb/sm/array_schema/array_schema.cc | 15 +++++--- tiledb/sm/array_schema/array_schema.h | 6 +++- tiledb/sm/cpp_api/array_schema.h | 17 ++++++++-- 6 files changed, 91 insertions(+), 8 deletions(-) diff --git a/tiledb/api/c_api/array_schema/array_schema_api.cc b/tiledb/api/c_api/array_schema/array_schema_api.cc index 3191dc75c12..64a006ca08b 100644 --- a/tiledb/api/c_api/array_schema/array_schema_api.cc +++ b/tiledb/api/c_api/array_schema/array_schema_api.cc @@ -95,6 +95,28 @@ capi_return_t tiledb_array_schema_alloc( return TILEDB_OK; } +capi_return_t tiledb_array_schema_alloc_at_timestamp( + tiledb_ctx_t* ctx, + tiledb_array_type_t array_type, + tiledb_array_schema_t** array_schema, + uint64_t t1, + uint64_t t2) { + ensure_output_pointer_is_valid(array_schema); + + // Create ArraySchema object + auto memory_tracker = ctx->resources().create_memory_tracker(); + memory_tracker->set_type(MemoryTrackerType::ARRAY_CREATE); + auto timestamp_range = std::make_pair(t1, t2); + auto opt_range = + std::optional>(timestamp_range); + *array_schema = tiledb_array_schema_t::make_handle( + static_cast(array_type), + memory_tracker, + opt_range); + + return TILEDB_OK; +} + void tiledb_array_schema_free(tiledb_array_schema_t** array_schema) { ensure_output_pointer_is_valid(array_schema); ensure_array_schema_is_valid(*array_schema); @@ -454,6 +476,18 @@ CAPI_INTERFACE( ctx, array_type, array_schema); } +CAPI_INTERFACE( + array_schema_alloc_at_timestamp, + tiledb_ctx_t* ctx, + tiledb_array_type_t array_type, + tiledb_array_schema_t** array_schema, + uint64_t t1, + uint64_t t2) { + return api_entry_with_context< + tiledb::api::tiledb_array_schema_alloc_at_timestamp>( + ctx, array_type, array_schema, t1, t2); +} + CAPI_INTERFACE_VOID(array_schema_free, tiledb_array_schema_t** array_schema) { return api_entry_void(array_schema); } diff --git a/tiledb/api/c_api/array_schema/array_schema_api_external.h b/tiledb/api/c_api/array_schema/array_schema_api_external.h index 703c25a772f..cc39cf2ff9f 100644 --- a/tiledb/api/c_api/array_schema/array_schema_api_external.h +++ b/tiledb/api/c_api/array_schema/array_schema_api_external.h @@ -121,6 +121,31 @@ TILEDB_EXPORT capi_return_t tiledb_array_schema_alloc( tiledb_array_type_t array_type, tiledb_array_schema_t** array_schema) TILEDB_NOEXCEPT; +/** + * Creates a TileDB array schema object with specified creation time. + * + * **Example:** + * + * @code{.c} + * tiledb_array_schema_t* array_schema; + * uint64_t t1 = 10; + * uint64_t t2 = 20; + * tiledb_array_schema_alloc_at_timestamp(ctx, TILEDB_DENSE, &array_schema, t1, + * t2); + * @endcode + * + * @param[in] ctx The TileDB context. + * @param[in] array_type The array type. + * @param[out] array_schema The TileDB array schema to be created. + * @return `TILEDB_OK` for success and `TILEDB_OOM` or `TILEDB_ERR` for error. + */ +TILEDB_EXPORT capi_return_t tiledb_array_schema_alloc_at_timestamp( + tiledb_ctx_t* ctx, + tiledb_array_type_t array_type, + tiledb_array_schema_t** array_schema, + uint64_t t1, + uint64_t t2); + /** * Destroys an array schema, freeing associated memory. * diff --git a/tiledb/sm/array/array.cc b/tiledb/sm/array/array.cc index 23144019733..1511030e9a5 100644 --- a/tiledb/sm/array/array.cc +++ b/tiledb/sm/array/array.cc @@ -203,7 +203,7 @@ void Array::create( std::lock_guard lock{object_mtx}; array_schema->set_array_uri(array_uri); - array_schema->generate_uri(); + array_schema->generate_uri(array_schema->timestamp_range()); array_schema->check(resources.config()); // Check current domain is specified correctly if set diff --git a/tiledb/sm/array_schema/array_schema.cc b/tiledb/sm/array_schema/array_schema.cc index 1de4e2982f8..d9a76dd6fb9 100644 --- a/tiledb/sm/array_schema/array_schema.cc +++ b/tiledb/sm/array_schema/array_schema.cc @@ -80,13 +80,20 @@ class ArraySchemaException : public StatusException { /* ****************************** */ ArraySchema::ArraySchema( - ArrayType array_type, shared_ptr memory_tracker) + ArrayType array_type, + shared_ptr memory_tracker, + std::optional> timestamp_range) : memory_tracker_(memory_tracker) , uri_(URI()) , array_uri_(URI()) , version_(constants::format_version) - , timestamp_range_(std::make_pair( - utils::time::timestamp_now_ms(), utils::time::timestamp_now_ms())) + , timestamp_range_( + timestamp_range.has_value() ? std::make_pair( + timestamp_range.value().first, + timestamp_range.value().second) : + std::make_pair( + utils::time::timestamp_now_ms(), + utils::time::timestamp_now_ms())) , name_("") , array_type_(array_type) , allows_dups_(false) @@ -121,7 +128,7 @@ ArraySchema::ArraySchema( Datatype::UINT8)); // Generate URI and name for ArraySchema - generate_uri(); + generate_uri(timestamp_range); } ArraySchema::ArraySchema( diff --git a/tiledb/sm/array_schema/array_schema.h b/tiledb/sm/array_schema/array_schema.h index 8ca8daae80d..f5e88de57ca 100644 --- a/tiledb/sm/array_schema/array_schema.h +++ b/tiledb/sm/array_schema/array_schema.h @@ -99,7 +99,11 @@ class ArraySchema { * @param memory_tracker The memory tracker of the array this fragment * metadata corresponds to. */ - ArraySchema(ArrayType array_type, shared_ptr memory_tracker); + ArraySchema( + ArrayType array_type, + shared_ptr memory_tracker, + std::optional> timestamp_range = + std::nullopt); /** Constructor with std::vector attributes. * @param uri The URI of the array schema file. diff --git a/tiledb/sm/cpp_api/array_schema.h b/tiledb/sm/cpp_api/array_schema.h index 86c113a9788..98c8db7ed63 100644 --- a/tiledb/sm/cpp_api/array_schema.h +++ b/tiledb/sm/cpp_api/array_schema.h @@ -107,10 +107,23 @@ class ArraySchema : public Schema { * @param ctx TileDB context * @param type Array type, sparse or dense. */ - explicit ArraySchema(const Context& ctx, tiledb_array_type_t type) + explicit ArraySchema( + const Context& ctx, + tiledb_array_type_t type, + std::optional> timestamp_range = std::nullopt) : Schema(ctx) { tiledb_array_schema_t* schema; - ctx.handle_error(tiledb_array_schema_alloc(ctx.ptr().get(), type, &schema)); + if (timestamp_range.has_value()) { + ctx.handle_error(tiledb_array_schema_alloc_at_timestamp( + ctx.ptr().get(), + type, + &schema, + timestamp_range.value().first, + timestamp_range.value().second)); + } else { + ctx.handle_error( + tiledb_array_schema_alloc(ctx.ptr().get(), type, &schema)); + } schema_ = std::shared_ptr(schema, deleter_); } From 3fd2a2b19c1b433927afb6d81369ecf7bcffbd60 Mon Sep 17 00:00:00 2001 From: John Kerl Date: Wed, 28 Aug 2024 11:01:26 -0400 Subject: [PATCH 2/2] iterating [skip ci] --- test/src/unit-capi-enumerations.cc | 2 ++ test/src/unit-cppapi-enumerations.cc | 2 ++ test/src/unit-rest-enumerations.cc | 2 ++ tiledb/api/c_api/array_schema/array_schema_api.cc | 10 +++++----- .../api/c_api/array_schema/array_schema_api_external.h | 8 ++++---- .../c_api/enumeration/test/unit_capi_enumeration.cc | 2 ++ tiledb/sm/cpp_api/array_schema.h | 4 ++-- 7 files changed, 19 insertions(+), 11 deletions(-) diff --git a/test/src/unit-capi-enumerations.cc b/test/src/unit-capi-enumerations.cc index 58add24ea2f..f8f2849033f 100644 --- a/test/src/unit-capi-enumerations.cc +++ b/test/src/unit-capi-enumerations.cc @@ -117,3 +117,5 @@ TEST_CASE( rc = tiledb_array_get_enumeration(ctx, array, nullptr, &enmr); REQUIRE(rc == TILEDB_ERR); } + +// XXX TOUCH diff --git a/test/src/unit-cppapi-enumerations.cc b/test/src/unit-cppapi-enumerations.cc index a020d86cd9a..1969df55f9f 100644 --- a/test/src/unit-cppapi-enumerations.cc +++ b/test/src/unit-cppapi-enumerations.cc @@ -750,3 +750,5 @@ void CPPEnumerationFx::rm_array() { vfs_.remove_dir(uri_); } } + +// XXX TOUCH diff --git a/test/src/unit-rest-enumerations.cc b/test/src/unit-rest-enumerations.cc index e93b42e4caf..da4b04b5727 100644 --- a/test/src/unit-rest-enumerations.cc +++ b/test/src/unit-rest-enumerations.cc @@ -206,3 +206,5 @@ void RESTEnumerationFx::create_array(const std::string& array_name) { query.finalize(); array.close(); } + +// XXX TOUCH diff --git a/tiledb/api/c_api/array_schema/array_schema_api.cc b/tiledb/api/c_api/array_schema/array_schema_api.cc index 64a006ca08b..03fd07a7abe 100644 --- a/tiledb/api/c_api/array_schema/array_schema_api.cc +++ b/tiledb/api/c_api/array_schema/array_schema_api.cc @@ -98,9 +98,9 @@ capi_return_t tiledb_array_schema_alloc( capi_return_t tiledb_array_schema_alloc_at_timestamp( tiledb_ctx_t* ctx, tiledb_array_type_t array_type, - tiledb_array_schema_t** array_schema, uint64_t t1, - uint64_t t2) { + uint64_t t2, + tiledb_array_schema_t** array_schema) { ensure_output_pointer_is_valid(array_schema); // Create ArraySchema object @@ -480,12 +480,12 @@ CAPI_INTERFACE( array_schema_alloc_at_timestamp, tiledb_ctx_t* ctx, tiledb_array_type_t array_type, - tiledb_array_schema_t** array_schema, uint64_t t1, - uint64_t t2) { + uint64_t t2, + tiledb_array_schema_t** array_schema) { return api_entry_with_context< tiledb::api::tiledb_array_schema_alloc_at_timestamp>( - ctx, array_type, array_schema, t1, t2); + ctx, array_type, t1, t2, array_schema); } CAPI_INTERFACE_VOID(array_schema_free, tiledb_array_schema_t** array_schema) { diff --git a/tiledb/api/c_api/array_schema/array_schema_api_external.h b/tiledb/api/c_api/array_schema/array_schema_api_external.h index cc39cf2ff9f..0246743c731 100644 --- a/tiledb/api/c_api/array_schema/array_schema_api_external.h +++ b/tiledb/api/c_api/array_schema/array_schema_api_external.h @@ -130,8 +130,8 @@ TILEDB_EXPORT capi_return_t tiledb_array_schema_alloc( * tiledb_array_schema_t* array_schema; * uint64_t t1 = 10; * uint64_t t2 = 20; - * tiledb_array_schema_alloc_at_timestamp(ctx, TILEDB_DENSE, &array_schema, t1, - * t2); + * tiledb_array_schema_alloc_at_timestamp(ctx, TILEDB_DENSE, t1, t2, + * &array_schema); * @endcode * * @param[in] ctx The TileDB context. @@ -142,9 +142,9 @@ TILEDB_EXPORT capi_return_t tiledb_array_schema_alloc( TILEDB_EXPORT capi_return_t tiledb_array_schema_alloc_at_timestamp( tiledb_ctx_t* ctx, tiledb_array_type_t array_type, - tiledb_array_schema_t** array_schema, uint64_t t1, - uint64_t t2); + uint64_t t2, + tiledb_array_schema_t** array_schema) TILEDB_NOEXCEPT; /** * Destroys an array schema, freeing associated memory. diff --git a/tiledb/api/c_api/enumeration/test/unit_capi_enumeration.cc b/tiledb/api/c_api/enumeration/test/unit_capi_enumeration.cc index a185f5e4d7a..68b75deb486 100644 --- a/tiledb/api/c_api/enumeration/test/unit_capi_enumeration.cc +++ b/tiledb/api/c_api/enumeration/test/unit_capi_enumeration.cc @@ -469,3 +469,5 @@ TEST_CASE( REQUIRE(rc == TILEDB_ERR); } } + +// XXX TOUCH diff --git a/tiledb/sm/cpp_api/array_schema.h b/tiledb/sm/cpp_api/array_schema.h index 98c8db7ed63..48acf3a9564 100644 --- a/tiledb/sm/cpp_api/array_schema.h +++ b/tiledb/sm/cpp_api/array_schema.h @@ -117,9 +117,9 @@ class ArraySchema : public Schema { ctx.handle_error(tiledb_array_schema_alloc_at_timestamp( ctx.ptr().get(), type, - &schema, timestamp_range.value().first, - timestamp_range.value().second)); + timestamp_range.value().second, + &schema)); } else { ctx.handle_error( tiledb_array_schema_alloc(ctx.ptr().get(), type, &schema));