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 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158
|
/* methods_parameter_ref_array_resize_captured.c generated by valac, the Vala compiler
* generated from methods_parameter_ref_array_resize_captured.vala, do not modify */
#include <glib.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
typedef void (*FooFunc) (gpointer user_data);
typedef struct _Block1Data Block1Data;
struct _Block1Data {
int _ref_count_;
gint* a;
gint a_length1;
gint _a_size_;
};
VALA_EXTERN void foo (gint** a,
gint* a_length1);
static void _vala_main (void);
static Block1Data* block1_data_ref (Block1Data* _data1_);
static void block1_data_unref (void * _userdata_);
static void __lambda4_ (Block1Data* _data1_);
static void ___lambda4__foo_func (gpointer self);
static void _vala_array_add1 (gint* * array,
gint* length,
gint* size,
gint value);
void
foo (gint** a,
gint* a_length1)
{
gint* _tmp0_;
_tmp0_ = g_new0 (gint, 1);
*a = (g_free (*a), NULL);
*a = _tmp0_;
*a_length1 = 1;
}
static Block1Data*
block1_data_ref (Block1Data* _data1_)
{
g_atomic_int_inc (&_data1_->_ref_count_);
return _data1_;
}
static void
block1_data_unref (void * _userdata_)
{
Block1Data* _data1_;
_data1_ = (Block1Data*) _userdata_;
if (g_atomic_int_dec_and_test (&_data1_->_ref_count_)) {
_data1_->a = (g_free (_data1_->a), NULL);
g_slice_free (Block1Data, _data1_);
}
}
static void
__lambda4_ (Block1Data* _data1_)
{
foo (&_data1_->a, (gint*) (&_data1_->a_length1));
_data1_->_a_size_ = _data1_->a_length1;
}
static void
___lambda4__foo_func (gpointer self)
{
__lambda4_ (self);
}
static void
_vala_array_add1 (gint* * array,
gint* length,
gint* size,
gint value)
{
if ((*length) == (*size)) {
*size = (*size) ? (2 * (*size)) : 4;
*array = g_renew (gint, *array, *size);
}
(*array)[(*length)++] = value;
}
static void
_vala_main (void)
{
Block1Data* _data1_;
gint* _tmp0_;
FooFunc func = NULL;
gpointer func_target;
GDestroyNotify func_target_destroy_notify;
FooFunc _tmp1_;
gpointer _tmp1__target;
_data1_ = g_slice_new0 (Block1Data);
_data1_->_ref_count_ = 1;
_tmp0_ = g_new0 (gint, (10 * 1024) * 1024);
_data1_->a = _tmp0_;
_data1_->a_length1 = (10 * 1024) * 1024;
_data1_->_a_size_ = _data1_->a_length1;
func = ___lambda4__foo_func;
func_target = block1_data_ref (_data1_);
func_target_destroy_notify = block1_data_unref;
_tmp1_ = func;
_tmp1__target = func_target;
_tmp1_ (_tmp1__target);
{
gint i = 0;
i = 1;
{
gboolean _tmp2_ = FALSE;
_tmp2_ = TRUE;
while (TRUE) {
if (!_tmp2_) {
gint _tmp3_;
_tmp3_ = i;
i = _tmp3_ + 1;
}
_tmp2_ = FALSE;
if (!(i < ((10 * 1024) * 1024))) {
break;
}
_vala_array_add1 (&_data1_->a, &_data1_->a_length1, &_data1_->_a_size_, 4711);
}
}
}
(func_target_destroy_notify == NULL) ? NULL : (func_target_destroy_notify (func_target), NULL);
func = NULL;
func_target = NULL;
func_target_destroy_notify = NULL;
block1_data_unref (_data1_);
_data1_ = NULL;
}
int
main (int argc,
char ** argv)
{
_vala_main ();
return 0;
}
|