1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
|
/* structs_bug623092.c generated by valac, the Vala compiler
* generated from structs_bug623092.vala, do not modify */
#include <glib-object.h>
#include <glib.h>
#include <string.h>
#if !defined(VALA_STRICT_C)
#if !defined(__clang__) && defined(__GNUC__) && (__GNUC__ >= 14)
#pragma GCC diagnostic warning "-Wincompatible-pointer-types"
#elif defined(__clang__) && (__clang_major__ >= 16)
#pragma clang diagnostic ignored "-Wincompatible-function-pointer-types"
#pragma clang diagnostic ignored "-Wincompatible-pointer-types"
#endif
#endif
#if !defined(VALA_EXTERN)
#if defined(_MSC_VER)
#define VALA_EXTERN __declspec(dllexport) extern
#elif __GNUC__ >= 4
#define VALA_EXTERN __attribute__((visibility("default"))) extern
#else
#define VALA_EXTERN extern
#endif
#endif
#define TYPE_FOO (foo_get_type ())
typedef struct _Foo Foo;
#define _vala_assert(expr, msg) if G_LIKELY (expr) ; else g_assertion_message_expr (G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC, msg);
#define _vala_return_if_fail(expr, msg) if G_LIKELY (expr) ; else { g_return_if_fail_warning (G_LOG_DOMAIN, G_STRFUNC, msg); return; }
#define _vala_return_val_if_fail(expr, msg, val) if G_LIKELY (expr) ; else { g_return_if_fail_warning (G_LOG_DOMAIN, G_STRFUNC, msg); return val; }
#define _vala_warn_if_fail(expr, msg) if G_LIKELY (expr) ; else g_warn_message (G_LOG_DOMAIN, __FILE__, __LINE__, G_STRFUNC, msg);
struct _Foo {
gint bar;
};
VALA_EXTERN GType foo_get_type (void) G_GNUC_CONST ;
VALA_EXTERN Foo* foo_dup (const Foo* self);
VALA_EXTERN void foo_free (Foo* self);
VALA_EXTERN void foo_init (Foo *self,
gint bar);
VALA_EXTERN void make_foo (gint bar,
Foo* result);
static void _vala_main (void);
static gboolean _foo_equal (const Foo * s1,
const Foo * s2);
void
foo_init (Foo *self,
gint bar)
{
memset (self, 0, sizeof (Foo));
(*self).bar = bar;
}
Foo*
foo_dup (const Foo* self)
{
Foo* dup;
dup = g_new0 (Foo, 1);
memcpy (dup, self, sizeof (Foo));
return dup;
}
void
foo_free (Foo* self)
{
g_free (self);
}
static GType
foo_get_type_once (void)
{
GType foo_type_id;
foo_type_id = g_boxed_type_register_static ("Foo", (GBoxedCopyFunc) foo_dup, (GBoxedFreeFunc) foo_free);
return foo_type_id;
}
GType
foo_get_type (void)
{
static volatile gsize foo_type_id__once = 0;
if (g_once_init_enter (&foo_type_id__once)) {
GType foo_type_id;
foo_type_id = foo_get_type_once ();
g_once_init_leave (&foo_type_id__once, foo_type_id);
}
return foo_type_id__once;
}
void
make_foo (gint bar,
Foo* result)
{
Foo _tmp0_ = {0};
foo_init (&_tmp0_, bar);
*result = _tmp0_;
return;
}
static gboolean
_foo_equal (const Foo * s1,
const Foo * s2)
{
if (s1 == s2) {
return TRUE;
}
if (s1 == NULL) {
return FALSE;
}
if (s2 == NULL) {
return FALSE;
}
if (s1->bar != s2->bar) {
return FALSE;
}
return TRUE;
}
static void
_vala_main (void)
{
Foo foo = {0};
Foo _tmp0_;
Foo _tmp1_ = {0};
foo_init (&foo, 10);
_tmp0_ = foo;
make_foo (10, &_tmp1_);
_vala_assert (_foo_equal (&_tmp0_, &_tmp1_) == TRUE, "foo == make_foo (10)");
}
int
main (int argc,
char ** argv)
{
_vala_main ();
return 0;
}
|