From 7fc5a59826ee1e1dee3236b1e43180cc22cfb496 Mon Sep 17 00:00:00 2001 From: Emanuele Sabellico Date: Wed, 9 Oct 2024 21:52:53 +0200 Subject: [PATCH] [KIP-460] Remove duplicate ElectLeaders result type (#4867) from external API and avoid exposing internal destructor --- examples/elect_leaders.c | 5 +---- src/rdkafka.h | 27 ++------------------------- src/rdkafka_admin.c | 26 +++++++++++++++++--------- src/rdkafka_admin.h | 4 ++-- 4 files changed, 22 insertions(+), 40 deletions(-) diff --git a/examples/elect_leaders.c b/examples/elect_leaders.c index 8e4e5ecd2..84015580c 100644 --- a/examples/elect_leaders.c +++ b/examples/elect_leaders.c @@ -123,11 +123,8 @@ print_elect_leaders_result(const rd_kafka_ElectLeaders_result_t *result) { const rd_kafka_topic_partition_result_t **results; size_t results_cnt; size_t i; - const rd_kafka_ElectLeadersResult_t *res; - res = rd_kafka_ElectLeaders_result(result); - - results = rd_kafka_ElectLeadersResult_partitions(res, &results_cnt); + results = rd_kafka_ElectLeaders_result_partitions(result, &results_cnt); printf("ElectLeaders response has %zu partition(s):\n", results_cnt); for (i = 0; i < results_cnt; i++) { const rd_kafka_topic_partition_t *partition = diff --git a/src/rdkafka.h b/src/rdkafka.h index 507d791e0..5f9a6a8f1 100644 --- a/src/rdkafka.h +++ b/src/rdkafka.h @@ -10039,21 +10039,6 @@ RD_EXPORT void rd_kafka_ElectLeaders(rd_kafka_t *rk, const rd_kafka_AdminOptions_t *options, rd_kafka_queue_t *rkqu); -/** - * @brief A struct representing result of elect leaders admin operation. - */ -typedef struct rd_kafka_ElectLeadersResult_s rd_kafka_ElectLeadersResult_t; - -/** - * @brief Get the elect leaders result from the elect leaders result event. - * - * @param result The elect leaders result event. - * - * @returns the elect leaders result from the elect leaders result event. - */ -RD_EXPORT const rd_kafka_ElectLeadersResult_t * -rd_kafka_ElectLeaders_result(const rd_kafka_ElectLeaders_result_t *result); - /** * @brief Get the array of topic partition result objects from the * elect leaders result event and populates the size of the @@ -10066,18 +10051,10 @@ rd_kafka_ElectLeaders_result(const rd_kafka_ElectLeaders_result_t *result); * elect leaders result event. */ RD_EXPORT const rd_kafka_topic_partition_result_t ** -rd_kafka_ElectLeadersResult_partitions( - const rd_kafka_ElectLeadersResult_t *result, +rd_kafka_ElectLeaders_result_partitions( + const rd_kafka_ElectLeaders_result_t *result, size_t *cntp); -/** - * @brief Destroy and free a rd_kafka_ElectLeadersResult_t object. - * - * @param result The rd_kafka_ElectLeadersResult_t object to be destroyed. - */ -RD_EXPORT void -rd_kafka_ElectLeadersResult_destroy(rd_kafka_ElectLeadersResult_t *result); - /**@}*/ /** diff --git a/src/rdkafka_admin.c b/src/rdkafka_admin.c index 12734e1ed..41934e349 100644 --- a/src/rdkafka_admin.c +++ b/src/rdkafka_admin.c @@ -9187,13 +9187,7 @@ rd_kafka_ElectLeadersResult_new(rd_list_t *partitions) { return result; } -const rd_kafka_ElectLeadersResult_t * -rd_kafka_ElectLeaders_result(const rd_kafka_ElectLeaders_result_t *result) { - return (const rd_kafka_ElectLeadersResult_t *)rd_list_elem( - &result->rko_u.admin_result.results, 0); -} - -const rd_kafka_topic_partition_result_t ** +static const rd_kafka_topic_partition_result_t ** rd_kafka_ElectLeadersResult_partitions( const rd_kafka_ElectLeadersResult_t *result, size_t *cntp) { @@ -9202,8 +9196,8 @@ rd_kafka_ElectLeadersResult_partitions( result->partitions.rl_elems; } -void rd_kafka_ElectLeadersResult_destroy( - rd_kafka_ElectLeadersResult_t *result) { +static void +rd_kafka_ElectLeadersResult_destroy(rd_kafka_ElectLeadersResult_t *result) { rd_list_destroy(&result->partitions); rd_free(result); } @@ -9212,6 +9206,20 @@ static void rd_kafka_ElectLeadersResult_free(void *ptr) { rd_kafka_ElectLeadersResult_destroy(ptr); } +static const rd_kafka_ElectLeadersResult_t *rd_kafka_ElectLeaders_result_result( + const rd_kafka_ElectLeaders_result_t *result) { + return (const rd_kafka_ElectLeadersResult_t *)rd_list_elem( + &result->rko_u.admin_result.results, 0); +} + +const rd_kafka_topic_partition_result_t ** +rd_kafka_ElectLeaders_result_partitions( + const rd_kafka_ElectLeaders_result_t *result, + size_t *cntp) { + return rd_kafka_ElectLeadersResult_partitions( + rd_kafka_ElectLeaders_result_result(result), cntp); +} + /** * @brief Parse ElectLeadersResponse and create ADMIN_RESULT op. */ diff --git a/src/rdkafka_admin.h b/src/rdkafka_admin.h index 608a74eee..04c498bf8 100644 --- a/src/rdkafka_admin.h +++ b/src/rdkafka_admin.h @@ -610,9 +610,9 @@ struct rd_kafka_ElectLeaders_s { /** * @struct ElectLeaders result object */ -struct rd_kafka_ElectLeadersResult_s { +typedef struct rd_kafka_ElectLeadersResult_s { rd_list_t partitions; /**< Type (rd_kafka_topic_partition_result_t *) */ -}; +} rd_kafka_ElectLeadersResult_t; /**@}*/