From c3e6119c6ead822b2d2e618d5ca88c7c203a37ea Mon Sep 17 00:00:00 2001 From: Sarah Gilmore Date: Fri, 10 May 2024 09:37:36 -0400 Subject: [PATCH] Add exportToC method on Array proxy --- .../src/cpp/arrow/matlab/array/proxy/array.cc | 17 +++++++++++++++++ matlab/src/cpp/arrow/matlab/array/proxy/array.h | 2 ++ 2 files changed, 19 insertions(+) diff --git a/matlab/src/cpp/arrow/matlab/array/proxy/array.cc b/matlab/src/cpp/arrow/matlab/array/proxy/array.cc index b8f85b08632a3..64161b1378963 100644 --- a/matlab/src/cpp/arrow/matlab/array/proxy/array.cc +++ b/matlab/src/cpp/arrow/matlab/array/proxy/array.cc @@ -17,6 +17,8 @@ #include "arrow/util/utf8.h" +#include "arrow/c/bridge.h" + #include "arrow/matlab/array/proxy/array.h" #include "arrow/matlab/array/proxy/wrap.h" #include "arrow/matlab/bit/unpack.h" @@ -178,4 +180,19 @@ void Array::slice(libmexclass::proxy::method::Context& context) { output[0]["TypeID"] = factory.createScalar(type_id); context.outputs[0] = output; } + +void Array::exportToC(libmexclass::proxy::method::Context& context) { + namespace mda = ::matlab::data; + mda::StructArray opts = context.inputs[0]; + const mda::TypedArray array_address_mda = opts[0]["ArrowArrayAddress"]; + const mda::TypedArray schema_address_mda = opts[0]["ArrowSchemaAddress"]; + + struct ArrowArray* arrow_array = reinterpret_cast(uint64_t(array_address_mda[0])); + struct ArrowSchema* arrow_schema = reinterpret_cast(uint64_t(schema_address_mda[0])); + + MATLAB_ERROR_IF_NOT_OK_WITH_CONTEXT(arrow::ExportArray(*array, arrow_array, arrow_schema), context, "arrow:c:export:Failed"); + +} + + } // namespace arrow::matlab::array::proxy diff --git a/matlab/src/cpp/arrow/matlab/array/proxy/array.h b/matlab/src/cpp/arrow/matlab/array/proxy/array.h index 61ba06a503bc4..c249693ac2797 100644 --- a/matlab/src/cpp/arrow/matlab/array/proxy/array.h +++ b/matlab/src/cpp/arrow/matlab/array/proxy/array.h @@ -45,6 +45,8 @@ class Array : public libmexclass::proxy::Proxy { void slice(libmexclass::proxy::method::Context& context); + void exportToC(libmexclass::proxy::method::Context& context); + std::shared_ptr array; };