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 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285
|
/*
* File: sort_IntegerContainer_Impl.c
* Symbol: sort.IntegerContainer-v0.1
* Symbol Type: class
* Babel Version: 0.10.2
* Description: Server-side implementation for sort.IntegerContainer
*
* WARNING: Automatically generated; only changes within splicers preserved
*
* babel-version = 0.10.2
*/
/*
* DEVELOPERS ARE EXPECTED TO PROVIDE IMPLEMENTATIONS
* FOR THE FOLLOWING METHODS BETWEEN SPLICER PAIRS.
*/
/*
* Symbol "sort.IntegerContainer" (version 0.1)
*
* Integer container.
*/
#include "sort_IntegerContainer_Impl.h"
#line 26 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer._includes) */
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "sort_Integer.h"
#include "synch_RegOut.h"
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer._includes) */
#line 34 "sort_IntegerContainer_Impl.c"
/*
* Static class initializer called exactly once before any user-defined method is dispatched
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer__load"
void
impl_sort_IntegerContainer__load(
void)
{
#line 45 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer._load) */
/* Insert the implementation of the static class initializer method here... */
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer._load) */
#line 51 "sort_IntegerContainer_Impl.c"
}
/*
* Class constructor called when the class is created.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer__ctor"
void
impl_sort_IntegerContainer__ctor(
/* in */ sort_IntegerContainer self)
{
#line 60 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer._ctor) */
struct sort_IntegerContainer__data *dptr =
malloc(sizeof(struct sort_IntegerContainer__data));
if (dptr) {
dptr->d_elements = NULL;
}
sort_IntegerContainer__set_data(self, dptr);
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer._ctor) */
#line 73 "sort_IntegerContainer_Impl.c"
}
/*
* Class destructor called when the class is deleted.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer__dtor"
void
impl_sort_IntegerContainer__dtor(
/* in */ sort_IntegerContainer self)
{
#line 81 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer._dtor) */
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
if (dptr) {
if (dptr->d_elements) {
sort_Integer__array_deleteRef(dptr->d_elements);
dptr->d_elements = NULL;
}
free((void *)dptr);
sort_IntegerContainer__set_data(self, NULL);
}
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer._dtor) */
#line 100 "sort_IntegerContainer_Impl.c"
}
/*
* This sets the container length and pseudo-randomly orders the
* Integer elements contained.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer_setLength"
void
impl_sort_IntegerContainer_setLength(
/* in */ sort_IntegerContainer self,
/* in */ int32_t len)
{
#line 108 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer.setLength) */
if (len >= 0) {
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
if (dptr) {
int32_t i, j;
if (dptr->d_elements) {
sort_Integer__array_deleteRef(dptr->d_elements);
}
dptr->d_elements = sort_Integer__array_create1d(len);
for(i = 0; i < len ; ++i ) {
sort_Integer iptr = sort_Integer__create();
sort_Integer_setValue(iptr, i+1);
sort_Integer__array_set1(dptr->d_elements, i, iptr);
sort_Integer_deleteRef(iptr);
}
/* shuffle the list */
for(i = len - 1; i > 0; --i) {
j = random() % (i + 1);
if (j != i) {
sort_IntegerContainer_swap(self, i, j);
}
}
}
}
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer.setLength) */
#line 143 "sort_IntegerContainer_Impl.c"
}
/*
* Return the number of elements in the container.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer_getLength"
int32_t
impl_sort_IntegerContainer_getLength(
/* in */ sort_IntegerContainer self)
{
#line 147 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer.getLength) */
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
return (dptr && dptr->d_elements) ?
(sort_Integer__array_upper(dptr->d_elements, 0) -
sort_Integer__array_lower(dptr->d_elements, 0) + 1) : 0;
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer.getLength) */
#line 165 "sort_IntegerContainer_Impl.c"
}
/*
* Return -1 if element i is less than element j, 0 if element i
* is equal to element j, or otherwise 1.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer_compare"
int32_t
impl_sort_IntegerContainer_compare(
/* in */ sort_IntegerContainer self,
/* in */ int32_t i,
/* in */ int32_t j,
/* in */ sort_Comparator comp)
{
#line 171 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer.compare) */
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
int result = 0;
if (dptr && dptr->d_elements) {
sort_Integer i1 = sort_Integer__array_get1(dptr->d_elements, i);
sort_Integer i2 = sort_Integer__array_get1(dptr->d_elements, j);
result = sort_Comparator_compare(comp,
(sidl_BaseInterface)i1,
(sidl_BaseInterface)i2);
sort_Integer_deleteRef(i1);
sort_Integer_deleteRef(i2);
}
return result;
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer.compare) */
#line 199 "sort_IntegerContainer_Impl.c"
}
/*
* Swap elements i and j.
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer_swap"
void
impl_sort_IntegerContainer_swap(
/* in */ sort_IntegerContainer self,
/* in */ int32_t i,
/* in */ int32_t j)
{
#line 201 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer.swap) */
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
if (dptr && dptr->d_elements) {
const int32_t len = sort_IntegerContainer_getLength(self);
if ((i >= 0) && (j >= 0) && (i < len) && (j < len)) {
sort_Integer i1 = sort_Integer__array_get1(dptr->d_elements, i);
sort_Integer i2 = sort_Integer__array_get1(dptr->d_elements, j);
sort_Integer__array_set1(dptr->d_elements, i, i2);
sort_Integer__array_set1(dptr->d_elements, j, i1);
sort_Integer_deleteRef(i1);
sort_Integer_deleteRef(i2);
}
else {
synch_RegOut tracker = synch_RegOut_getInstance();
fprintf(stderr, "\
sort::IntegerContainer::swap index out of bounds swap(%d, %d) len (%d)\n",
i, j, len);
synch_RegOut_forceFailure(tracker);
}
}
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer.swap) */
#line 238 "sort_IntegerContainer_Impl.c"
}
/*
* Print elements s through e-1
*/
#undef __FUNC__
#define __FUNC__ "impl_sort_IntegerContainer_output"
void
impl_sort_IntegerContainer_output(
/* in */ sort_IntegerContainer self,
/* in */ int32_t s,
/* in */ int32_t e)
{
#line 238 "../../../../babel/regression/sort/libC/sort_IntegerContainer_Impl.c"
/* DO-NOT-DELETE splicer.begin(sort.IntegerContainer.output) */
struct sort_IntegerContainer__data *dptr =
sort_IntegerContainer__get_data(self);
if (dptr && dptr->d_elements) {
static const char text[] = "list";
const size_t bufsize = 14*(e-s) + 6;
size_t entry_len;
char *buffer = malloc(bufsize), entry[15];
int current = sizeof(text)-1;
synch_RegOut tracker = synch_RegOut_getInstance();
strcpy(buffer, text);
while (s < e && (current < bufsize)) {
sort_Integer i = sort_Integer__array_get1(dptr->d_elements, s++);
sprintf(entry, " %d", sort_Integer_getValue(i));
entry_len = strlen(entry);
if ((current + entry_len) < bufsize) {
strcpy(buffer + current, entry);
current += entry_len;
}
else {
current = bufsize + 1;
}
sort_Integer_deleteRef(i);
}
synch_RegOut_writeComment(tracker, buffer);
synch_RegOut_deleteRef(tracker);
free(buffer);
}
/* DO-NOT-DELETE splicer.end(sort.IntegerContainer.output) */
#line 284 "sort_IntegerContainer_Impl.c"
}
|