cbindgen/tests/expectations/both/asserted-cast.compat.c
Emilio Cobos Álvarez 9b5dd80d84 Stop including <uchar.h>, and instead map Rust char to uint32_t.
This is technically a breaking change for C++, unfortunately.

Fixes #423.
2019-12-04 00:03:38 +01:00

110 lines
1.4 KiB
C

#define MY_ASSERT(...) do { } while (0)
#include <stdarg.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdlib.h>
typedef struct I I;
enum H_Tag
#ifdef __cplusplus
: uint8_t
#endif // __cplusplus
{
H_Foo,
H_Bar,
H_Baz,
};
#ifndef __cplusplus
typedef uint8_t H_Tag;
#endif // __cplusplus
typedef struct H_Foo_Body {
int16_t _0;
} H_Foo_Body;
typedef struct H_Bar_Body {
uint8_t x;
int16_t y;
} H_Bar_Body;
typedef struct H {
H_Tag tag;
union {
H_Foo_Body foo;
H_Bar_Body bar;
};
} H;
enum J_Tag
#ifdef __cplusplus
: uint8_t
#endif // __cplusplus
{
J_Foo,
J_Bar,
J_Baz,
};
#ifndef __cplusplus
typedef uint8_t J_Tag;
#endif // __cplusplus
typedef struct J_Foo_Body {
int16_t _0;
} J_Foo_Body;
typedef struct J_Bar_Body {
uint8_t x;
int16_t y;
} J_Bar_Body;
typedef struct J {
J_Tag tag;
union {
J_Foo_Body foo;
J_Bar_Body bar;
};
} J;
enum K_Tag
#ifdef __cplusplus
: uint8_t
#endif // __cplusplus
{
K_Foo,
K_Bar,
K_Baz,
};
#ifndef __cplusplus
typedef uint8_t K_Tag;
#endif // __cplusplus
typedef struct K_Foo_Body {
K_Tag tag;
int16_t _0;
} K_Foo_Body;
typedef struct K_Bar_Body {
K_Tag tag;
uint8_t x;
int16_t y;
} K_Bar_Body;
typedef union K {
K_Tag tag;
K_Foo_Body foo;
K_Bar_Body bar;
} K;
#ifdef __cplusplus
extern "C" {
#endif // __cplusplus
void foo(H h, I i, J j, K k);
#ifdef __cplusplus
} // extern "C"
#endif // __cplusplus