[foreign-jextract] RFR: 8263018: Improve API for lifecycle of native resources [v2]

Maurizio Cimadamore mcimadamore at openjdk.java.net
Wed Mar 24 12:32:07 UTC 2021


> This contains the jextract changes required to support the new changes to the foreign memory access API.
> 
> The main change is that now NativeScope is co-generated by jextract (although, moving forward, I'm not sure how much value it adds, but that's for another day).
> 
> I had to fix the extracted libclang in few places (probably better to re-generate this code once this is pushed).
> 
> Tests needed changes to fix imports so that they pick up the generated NativeScope class.

Maurizio Cimadamore has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains 98 commits:

 - Merge branch 'foreign-jextract' into jextract+resourceScope
 - Merge branch 'foreign-memaccess+abi' into jextract+resourceScope
 - Merge branch 'foreign-jextract' into jextract+resourceScope
 - Add overloads accepting ResourceScope parameter
 - Merge branch 'resourceScope' into jextract+resourceScope
 - Add ResourceScope overloads in CLinker
   Rewrite StdLib test not to use NativeScope
   Tweak names of allocator factories
   Fix javadoc
 - All tests pass
   * Fix upcall overload taking NativeScope
   * Generate NativeScope in output package
   * Add overload for functions returning a struct so than a NativeScope can be passed
   * Removed some now unused features from RuntimeHelper (ti make scope non-transferrable)
   * Fixup vararg invoker to deal with allocator parameters
   * Fixup tests to (a) depend on the generated NativeScope and (b) not to use TWR with segments directly
   Notes:
   * the internal libclang probably needs to be re-generated
 - Merge branch 'resourceScope' into jextract+resourceScope
 - Fix javadoc of SegmentAllocator
 - Address rest of review comments from Paul
 - ... and 88 more: https://git.openjdk.java.net/panama-foreign/compare/4e696684...6316ddca

-------------

Changes: https://git.openjdk.java.net/panama-foreign/pull/474/files
 Webrev: https://webrevs.openjdk.java.net/?repo=panama-foreign&pr=474&range=01
  Stats: 520 lines in 35 files changed: 279 ins; 99 del; 142 mod
  Patch: https://git.openjdk.java.net/panama-foreign/pull/474.diff
  Fetch: git fetch https://git.openjdk.java.net/panama-foreign pull/474/head:pull/474

PR: https://git.openjdk.java.net/panama-foreign/pull/474


More information about the panama-dev mailing list