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 140 141
|
/* methods_bug737222.c generated by valac, the Vala compiler
* generated from methods_bug737222.vala, do not modify */
#include <glib.h>
#include <stdlib.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 _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);
VALA_EXTERN gint* foo (gint* result_length1);
VALA_EXTERN gchar** bar (void);
static void _vala_main (void);
static void _vala_array_destroy (gpointer array,
gssize array_length,
GDestroyNotify destroy_func);
static void _vala_array_free (gpointer array,
gssize array_length,
GDestroyNotify destroy_func);
static gssize _vala_array_length (gpointer array);
gint*
foo (gint* result_length1)
{
gint* _tmp0_;
gint* _tmp1_;
gint _tmp1__length1;
gint* result;
_tmp0_ = g_new0 (gint, 1);
_tmp1_ = _tmp0_;
_tmp1__length1 = 1;
if (result_length1) {
*result_length1 = _tmp1__length1;
}
result = _tmp1_;
_vala_warn_if_fail (((*result_length1) == 0) || ((*result_length1) == 1), "result.length == 0 || result.length == 1");
return result;
}
gchar**
bar (void)
{
gchar* _tmp0_;
gchar** _tmp1_;
const gchar* _tmp2_;
gchar** result;
_tmp0_ = g_strdup ("bar");
_tmp1_ = g_new0 (gchar*, 1 + 1);
_tmp1_[0] = _tmp0_;
result = _tmp1_;
_tmp2_ = result[0];
_vala_warn_if_fail (g_strcmp0 (_tmp2_, "bar") == 0, "result[0] == \"bar\"");
return result;
}
static void
_vala_main (void)
{
gint _tmp0_ = 0;
gint* _tmp1_;
gint* _tmp2_;
gint _tmp2__length1;
gchar** _tmp3_;
gchar** _tmp4_;
gchar** _tmp5_;
gint _tmp5__length1;
_tmp1_ = foo (&_tmp0_);
_tmp2_ = _tmp1_;
_tmp2__length1 = _tmp0_;
_tmp2_ = (g_free (_tmp2_), NULL);
_tmp4_ = _tmp3_ = bar ();
_tmp5_ = _tmp4_;
_tmp5__length1 = _vala_array_length (_tmp3_);
_tmp5_ = (_vala_array_free (_tmp5_, _tmp5__length1, (GDestroyNotify) g_free), NULL);
}
int
main (int argc,
char ** argv)
{
_vala_main ();
return 0;
}
static void
_vala_array_destroy (gpointer array,
gssize array_length,
GDestroyNotify destroy_func)
{
if ((array != NULL) && (destroy_func != NULL)) {
gssize i;
for (i = 0; i < array_length; i = i + 1) {
if (((gpointer*) array)[i] != NULL) {
destroy_func (((gpointer*) array)[i]);
}
}
}
}
static void
_vala_array_free (gpointer array,
gssize array_length,
GDestroyNotify destroy_func)
{
_vala_array_destroy (array, array_length, destroy_func);
g_free (array);
}
static gssize
_vala_array_length (gpointer array)
{
gssize length;
length = 0;
if (array) {
while (((gpointer*) array)[length]) {
length++;
}
}
return length;
}
|