From 81998d091699bbe6d859d70c9931cb469666f6c5 Mon Sep 17 00:00:00 2001 From: "Sean T. Allen" Date: Sat, 13 Jan 2024 23:39:27 +0000 Subject: [PATCH 1/2] Clarify that `struct` is always a pointer It wasn't clear that a struct as a return value from C should be read as "pointer to struct". --- docs/c-ffi/calling-c.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/docs/c-ffi/calling-c.md b/docs/c-ffi/calling-c.md index 83e45b25..c7e03162 100644 --- a/docs/c-ffi/calling-c.md +++ b/docs/c-ffi/calling-c.md @@ -153,6 +153,20 @@ env.out.print(size.height.string()) A `NullablePointer` type can only be used with `structs`, and is only intended for output parameters (like in the example above) or for return types from C. You don't need to use a `NullablePointer` if you are only passing a `struct` as a regular input parameter. +If you are using a C function that returns a struct, remember, that you need to return a pointer to the struct. The following in Pony should be read as **returns a pointer to struct `Rect`**: + +```pony +use @from_c[Rect]() + +struct Rect + var length: U16 + var width: U16 +``` + +As we saw earlier, you can also use a `Pointer[(U16, U16)]` as well. It is the equivalent to our `Rect`. + +**Can I return struct types by value, instead of passing a pointer?** Not at the moment. This is a known limitation of the current FFI system, but it is something the Pony team is interested in fixing. If you'd like to work on adding support for returning structs by value, contact us [on the Zulip](https://ponylang.zulipchat.com/#narrow/stream/192795-contribute-to-Pony). + ### Return-type Polymorphism We mentioned before that you should use the `Pointer[None]` type in Pony when dealing with values of `void*` type in C. This is very useful for function parameters, but when we use `Pointer[None]` for the return type of a C function, we won't be able to access the value that the pointer points to. Let's imagine a generic list in C: From 5f62931b2d32c8ea258456cdd44515a6f84bccf8 Mon Sep 17 00:00:00 2001 From: Joe Eli McIlvain Date: Tue, 16 Jan 2024 11:31:45 -0800 Subject: [PATCH 2/2] Update docs/c-ffi/calling-c.md --- docs/c-ffi/calling-c.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/c-ffi/calling-c.md b/docs/c-ffi/calling-c.md index c7e03162..60980d88 100644 --- a/docs/c-ffi/calling-c.md +++ b/docs/c-ffi/calling-c.md @@ -153,7 +153,7 @@ env.out.print(size.height.string()) A `NullablePointer` type can only be used with `structs`, and is only intended for output parameters (like in the example above) or for return types from C. You don't need to use a `NullablePointer` if you are only passing a `struct` as a regular input parameter. -If you are using a C function that returns a struct, remember, that you need to return a pointer to the struct. The following in Pony should be read as **returns a pointer to struct `Rect`**: +If you are using a C function that returns a struct, remember, that the C function needs to return a pointer to the struct. The following in Pony should be read as **returns a pointer to struct `Rect`**: ```pony use @from_c[Rect]()