Uploaded image for project: 'Apache Arrow'
  1. Apache Arrow
  2. ARROW-14804

[R] import_from_c() / export_to_c() methods should accept external pointers

    XMLWordPrintableJSON

Details

    • Improvement
    • Status: Resolved
    • Major
    • Resolution: Fixed
    • None
    • 7.0.0
    • R

    Description

      The import and export to C methods for Field, Shema, DataType, Array, RecordBatch, and RecordBatchReader all require the pointer to be passed as a double (casted from uintptr_t casted from *. I imagine there's good reason for this path to exist; however, the R externalptr type and 64-bit integer are more natural types and I think it would not be hard to allow pointers to be passed in this way. A short discussion of this occurred when updating the Python docs on how to pass Array pointers to R.

      The implementation lives in arrow_cpp11.h and it seems like it would be easy to allow a user to pass something more R-like while still keeping the double route open for the packages that need it.

      I see that this is getting used for pointers that R6 objects are storing for the underlying C++ objects...I imagine there's a good reason for this but I wonder if there's a way to make the places where this interacts with other packages more intuitive.

      Attachments

        Issue Links

          Activity

            People

              amol- Alessandro Molina
              paleolimbot Dewey Dunnington
              Votes:
              0 Vote for this issue
              Watchers:
              5 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved:

                Time Tracking

                  Estimated:
                  Original Estimate - Not Specified
                  Not Specified
                  Remaining:
                  Remaining Estimate - 0h
                  0h
                  Logged:
                  Time Spent - 5h 50m
                  5h 50m