Simplify Pin<T> to T
cbindgen already simplifies `MaybeUninit<T>` and `ManuallyDrop<T>` to `T`. This adds `Pin<T>` as well.
This commit is contained in:
parent
ccd1f0e9ec
commit
63c1043dfb
2
docs.md
2
docs.md
@ -161,6 +161,8 @@ cbindgen contains the following hardcoded mappings (again completely ignoring na
|
||||
* PhantomData => *evaporates*, can only appear as the field of a type
|
||||
* PhantomPinned => *evaporates*, can only appear as the field of a type
|
||||
* () => *evaporates*, can only appear as the field of a type
|
||||
* MaybeUninit<T>, ManuallyDrop<T>, and Pin<T> => T
|
||||
|
||||
|
||||
|
||||
|
||||
|
@ -630,7 +630,7 @@ impl Type {
|
||||
is_ref: false,
|
||||
}),
|
||||
"Cell" => Some(generic.into_owned()),
|
||||
"ManuallyDrop" | "MaybeUninit" if config.language != Language::Cxx => {
|
||||
"ManuallyDrop" | "MaybeUninit" | "Pin" if config.language != Language::Cxx => {
|
||||
Some(generic.into_owned())
|
||||
}
|
||||
_ => None,
|
||||
|
27
tests/expectations/pin.both.c
Normal file
27
tests/expectations/pin.both.c
Normal file
@ -0,0 +1,27 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
typedef struct PinTest {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
} PinTest;
|
||||
|
||||
void root(int32_t *s, struct PinTest p);
|
35
tests/expectations/pin.both.compat.c
Normal file
35
tests/expectations/pin.both.compat.c
Normal file
@ -0,0 +1,35 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
typedef struct PinTest {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
} PinTest;
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif // __cplusplus
|
||||
|
||||
void root(int32_t *s, struct PinTest p);
|
||||
|
||||
#ifdef __cplusplus
|
||||
} // extern "C"
|
||||
#endif // __cplusplus
|
27
tests/expectations/pin.c
Normal file
27
tests/expectations/pin.c
Normal file
@ -0,0 +1,27 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
typedef struct {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
} PinTest;
|
||||
|
||||
void root(int32_t *s, PinTest p);
|
35
tests/expectations/pin.compat.c
Normal file
35
tests/expectations/pin.compat.c
Normal file
@ -0,0 +1,35 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
typedef struct {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
} PinTest;
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif // __cplusplus
|
||||
|
||||
void root(int32_t *s, PinTest p);
|
||||
|
||||
#ifdef __cplusplus
|
||||
} // extern "C"
|
||||
#endif // __cplusplus
|
32
tests/expectations/pin.cpp
Normal file
32
tests/expectations/pin.cpp
Normal file
@ -0,0 +1,32 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <cstdarg>
|
||||
#include <cstdint>
|
||||
#include <cstdlib>
|
||||
#include <ostream>
|
||||
#include <new>
|
||||
|
||||
struct PinTest {
|
||||
Pin<Box<int32_t>> pinned_box;
|
||||
Pin<int32_t*> pinned_ref;
|
||||
};
|
||||
|
||||
extern "C" {
|
||||
|
||||
void root(Pin<int32_t*> s, PinTest p);
|
||||
|
||||
} // extern "C"
|
29
tests/expectations/pin.pyx
Normal file
29
tests/expectations/pin.pyx
Normal file
@ -0,0 +1,29 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
from libc.stdint cimport int8_t, int16_t, int32_t, int64_t, intptr_t
|
||||
from libc.stdint cimport uint8_t, uint16_t, uint32_t, uint64_t, uintptr_t
|
||||
cdef extern from *:
|
||||
ctypedef bint bool
|
||||
ctypedef struct va_list
|
||||
|
||||
cdef extern from *:
|
||||
|
||||
ctypedef struct PinTest:
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
|
||||
void root(int32_t *s, PinTest p);
|
27
tests/expectations/pin.tag.c
Normal file
27
tests/expectations/pin.tag.c
Normal file
@ -0,0 +1,27 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
struct PinTest {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
};
|
||||
|
||||
void root(int32_t *s, struct PinTest p);
|
35
tests/expectations/pin.tag.compat.c
Normal file
35
tests/expectations/pin.tag.compat.c
Normal file
@ -0,0 +1,35 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
#include <stdarg.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
struct PinTest {
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
};
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif // __cplusplus
|
||||
|
||||
void root(int32_t *s, struct PinTest p);
|
||||
|
||||
#ifdef __cplusplus
|
||||
} // extern "C"
|
||||
#endif // __cplusplus
|
29
tests/expectations/pin.tag.pyx
Normal file
29
tests/expectations/pin.tag.pyx
Normal file
@ -0,0 +1,29 @@
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
|
||||
|
||||
from libc.stdint cimport int8_t, int16_t, int32_t, int64_t, intptr_t
|
||||
from libc.stdint cimport uint8_t, uint16_t, uint32_t, uint64_t, uintptr_t
|
||||
cdef extern from *:
|
||||
ctypedef bint bool
|
||||
ctypedef struct va_list
|
||||
|
||||
cdef extern from *:
|
||||
|
||||
cdef struct PinTest:
|
||||
int32_t *pinned_box;
|
||||
int32_t *pinned_ref;
|
||||
|
||||
void root(int32_t *s, PinTest p);
|
8
tests/rust/pin.rs
Normal file
8
tests/rust/pin.rs
Normal file
@ -0,0 +1,8 @@
|
||||
#[repr(C)]
|
||||
struct PinTest {
|
||||
pinned_box: Pin<Box<i32>>,
|
||||
pinned_ref: Pin<&mut i32>
|
||||
}
|
||||
|
||||
#[no_mangle]
|
||||
pub extern "C" fn root(s: Pin<&mut i32>, p: PinTest) {}
|
21
tests/rust/pin.toml
Normal file
21
tests/rust/pin.toml
Normal file
@ -0,0 +1,21 @@
|
||||
header = """
|
||||
#if 0
|
||||
''' '
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
template <typename T>
|
||||
using Pin = T;
|
||||
template <typename T>
|
||||
using Box = T*;
|
||||
#endif
|
||||
|
||||
#if 0
|
||||
' '''
|
||||
#endif
|
||||
"""
|
||||
[export]
|
||||
exclude = [
|
||||
"Pin",
|
||||
"Box"
|
||||
]
|
Loading…
x
Reference in New Issue
Block a user