xref: /freebsd/contrib/libevent/test/regress.gen.c (revision 2e3507c25e42292b45a5482e116d278f5515d04d)
1 
2 /*
3  * Automatically generated from ../test/regress.rpc
4  * by event_rpcgen.py/0.1.  DO NOT EDIT THIS FILE.
5  */
6 
7 #include <stdlib.h>
8 #include <string.h>
9 #include <assert.h>
10 #include <event2/event-config.h>
11 #include <event2/event.h>
12 #include <event2/buffer.h>
13 #include <event2/tag.h>
14 
15 #if defined(EVENT__HAVE___func__)
16 # ifndef __func__
17 #  define __func__ __func__
18 # endif
19 #elif defined(EVENT__HAVE___FUNCTION__)
20 # define __func__ __FUNCTION__
21 #else
22 # define __func__ __FILE__
23 #endif
24 
25 
26 #include "regress.gen.h"
27 
28 void event_warn(const char *fmt, ...);
29 void event_warnx(const char *fmt, ...);
30 
31 /*
32  * Implementation of msg
33  */
34 
35 static struct msg_access_ msg_base__ = {
36   msg_from_name_assign,
37   msg_from_name_get,
38   msg_to_name_assign,
39   msg_to_name_get,
40   msg_attack_assign,
41   msg_attack_get,
42   msg_run_assign,
43   msg_run_get,
44   msg_run_add,
45 };
46 
47 struct msg *
48 msg_new(void)
49 {
50   return msg_new_with_arg(NULL);
51 }
52 
53 struct msg *
54 msg_new_with_arg(void *unused)
55 {
56   struct msg *tmp;
57   if ((tmp = malloc(sizeof(struct msg))) == NULL) {
58     event_warn("%s: malloc", __func__);
59     return (NULL);
60   }
61   tmp->base = &msg_base__;
62 
63   tmp->from_name_data = NULL;
64   tmp->from_name_set = 0;
65 
66   tmp->to_name_data = NULL;
67   tmp->to_name_set = 0;
68 
69   tmp->attack_data = NULL;
70   tmp->attack_set = 0;
71 
72   tmp->run_data = NULL;
73   tmp->run_length = 0;
74   tmp->run_num_allocated = 0;
75   tmp->run_set = 0;
76 
77   return (tmp);
78 }
79 
80 
81 
82 
83 static int
84 msg_run_expand_to_hold_more(struct msg *msg)
85 {
86   int tobe_allocated = msg->run_num_allocated;
87   struct run** new_data = NULL;
88   tobe_allocated = !tobe_allocated ? 1 : tobe_allocated << 1;
89   new_data = (struct run**) realloc(msg->run_data,
90       tobe_allocated * sizeof(struct run*));
91   if (new_data == NULL)
92     return -1;
93   msg->run_data = new_data;
94   msg->run_num_allocated = tobe_allocated;
95   return 0;
96 }
97 
98 struct run*
99 msg_run_add(struct msg *msg)
100 {
101   if (++msg->run_length >= msg->run_num_allocated) {
102     if (msg_run_expand_to_hold_more(msg)<0)
103       goto error;
104   }
105   msg->run_data[msg->run_length - 1] = run_new();
106   if (msg->run_data[msg->run_length - 1] == NULL)
107     goto error;
108   msg->run_set = 1;
109   return (msg->run_data[msg->run_length - 1]);
110 error:
111   --msg->run_length;
112   return (NULL);
113 }
114 
115 int
116 msg_from_name_assign(struct msg *msg,
117     const char * value)
118 {
119   if (msg->from_name_data != NULL)
120     free(msg->from_name_data);
121   if ((msg->from_name_data = strdup(value)) == NULL)
122     return (-1);
123   msg->from_name_set = 1;
124   return (0);
125 }
126 
127 int
128 msg_to_name_assign(struct msg *msg,
129     const char * value)
130 {
131   if (msg->to_name_data != NULL)
132     free(msg->to_name_data);
133   if ((msg->to_name_data = strdup(value)) == NULL)
134     return (-1);
135   msg->to_name_set = 1;
136   return (0);
137 }
138 
139 int
140 msg_attack_assign(struct msg *msg,
141     const struct kill* value)
142 {
143    struct evbuffer *tmp = NULL;
144    if (msg->attack_set) {
145      kill_clear(msg->attack_data);
146      msg->attack_set = 0;
147    } else {
148      msg->attack_data = kill_new();
149      if (msg->attack_data == NULL) {
150        event_warn("%s: kill_new()", __func__);
151        goto error;
152      }
153    }
154    if ((tmp = evbuffer_new()) == NULL) {
155      event_warn("%s: evbuffer_new()", __func__);
156      goto error;
157    }
158    kill_marshal(tmp, value);
159    if (kill_unmarshal(msg->attack_data, tmp) == -1) {
160      event_warnx("%s: kill_unmarshal", __func__);
161      goto error;
162    }
163    msg->attack_set = 1;
164    evbuffer_free(tmp);
165    return (0);
166  error:
167    if (tmp != NULL)
168      evbuffer_free(tmp);
169    if (msg->attack_data != NULL) {
170      kill_free(msg->attack_data);
171      msg->attack_data = NULL;
172    }
173    return (-1);
174 }
175 
176 int
177 msg_run_assign(struct msg *msg, int off,
178   const struct run* value)
179 {
180   if (!msg->run_set || off < 0 || off >= msg->run_length)
181     return (-1);
182 
183   {
184     int had_error = 0;
185     struct evbuffer *tmp = NULL;
186     run_clear(msg->run_data[off]);
187     if ((tmp = evbuffer_new()) == NULL) {
188       event_warn("%s: evbuffer_new()", __func__);
189       had_error = 1;
190       goto done;
191     }
192     run_marshal(tmp, value);
193     if (run_unmarshal(msg->run_data[off], tmp) == -1) {
194       event_warnx("%s: run_unmarshal", __func__);
195       had_error = 1;
196       goto done;
197     }
198     done:
199     if (tmp != NULL)
200       evbuffer_free(tmp);
201     if (had_error) {
202       run_clear(msg->run_data[off]);
203       return (-1);
204     }
205   }
206   return (0);
207 }
208 
209 int
210 msg_from_name_get(struct msg *msg, char * *value)
211 {
212   if (msg->from_name_set != 1)
213     return (-1);
214   *value = msg->from_name_data;
215   return (0);
216 }
217 
218 int
219 msg_to_name_get(struct msg *msg, char * *value)
220 {
221   if (msg->to_name_set != 1)
222     return (-1);
223   *value = msg->to_name_data;
224   return (0);
225 }
226 
227 int
228 msg_attack_get(struct msg *msg, struct kill* *value)
229 {
230   if (msg->attack_set != 1) {
231     msg->attack_data = kill_new();
232     if (msg->attack_data == NULL)
233       return (-1);
234     msg->attack_set = 1;
235   }
236   *value = msg->attack_data;
237   return (0);
238 }
239 
240 int
241 msg_run_get(struct msg *msg, int offset,
242     struct run* *value)
243 {
244   if (!msg->run_set || offset < 0 || offset >= msg->run_length)
245     return (-1);
246   *value = msg->run_data[offset];
247   return (0);
248 }
249 
250 void
251 msg_clear(struct msg *tmp)
252 {
253   if (tmp->from_name_set == 1) {
254     free(tmp->from_name_data);
255     tmp->from_name_data = NULL;
256     tmp->from_name_set = 0;
257   }
258   if (tmp->to_name_set == 1) {
259     free(tmp->to_name_data);
260     tmp->to_name_data = NULL;
261     tmp->to_name_set = 0;
262   }
263   if (tmp->attack_set == 1) {
264     kill_free(tmp->attack_data);
265     tmp->attack_data = NULL;
266     tmp->attack_set = 0;
267   }
268   if (tmp->run_set == 1) {
269     int i;
270     for (i = 0; i < tmp->run_length; ++i) {
271       run_free(tmp->run_data[i]);
272     }
273     free(tmp->run_data);
274     tmp->run_data = NULL;
275     tmp->run_set = 0;
276     tmp->run_length = 0;
277     tmp->run_num_allocated = 0;
278   }
279 }
280 
281 void
282 msg_free(struct msg *tmp)
283 {
284   if (tmp->from_name_data != NULL)
285       free (tmp->from_name_data);
286   if (tmp->to_name_data != NULL)
287       free (tmp->to_name_data);
288   if (tmp->attack_data != NULL)
289       kill_free(tmp->attack_data);
290   if (tmp->run_set == 1) {
291     int i;
292     for (i = 0; i < tmp->run_length; ++i) {
293       run_free(tmp->run_data[i]);
294     }
295     free(tmp->run_data);
296     tmp->run_data = NULL;
297     tmp->run_set = 0;
298     tmp->run_length = 0;
299     tmp->run_num_allocated = 0;
300   }
301   free(tmp->run_data);
302   free(tmp);
303 }
304 
305 void
306 msg_marshal(struct evbuffer *evbuf, const struct msg *tmp) {
307   evtag_marshal_string(evbuf, MSG_FROM_NAME, tmp->from_name_data);
308   evtag_marshal_string(evbuf, MSG_TO_NAME, tmp->to_name_data);
309   if (tmp->attack_set) {
310     evtag_marshal_kill(evbuf, MSG_ATTACK, tmp->attack_data);
311   }
312   if (tmp->run_set) {
313     {
314       int i;
315       for (i = 0; i < tmp->run_length; ++i) {
316     evtag_marshal_run(evbuf, MSG_RUN, tmp->run_data[i]);
317       }
318     }
319   }
320 }
321 
322 int
323 msg_unmarshal(struct msg *tmp, struct evbuffer *evbuf)
324 {
325   ev_uint32_t tag;
326   while (evbuffer_get_length(evbuf) > 0) {
327     if (evtag_peek(evbuf, &tag) == -1)
328       return (-1);
329     switch (tag) {
330 
331       case MSG_FROM_NAME:
332         if (tmp->from_name_set)
333           return (-1);
334         if (evtag_unmarshal_string(evbuf, MSG_FROM_NAME, &tmp->from_name_data) == -1) {
335           event_warnx("%s: failed to unmarshal from_name", __func__);
336           return (-1);
337         }
338         tmp->from_name_set = 1;
339         break;
340       case MSG_TO_NAME:
341         if (tmp->to_name_set)
342           return (-1);
343         if (evtag_unmarshal_string(evbuf, MSG_TO_NAME, &tmp->to_name_data) == -1) {
344           event_warnx("%s: failed to unmarshal to_name", __func__);
345           return (-1);
346         }
347         tmp->to_name_set = 1;
348         break;
349       case MSG_ATTACK:
350         if (tmp->attack_set)
351           return (-1);
352         tmp->attack_data = kill_new();
353         if (tmp->attack_data == NULL)
354           return (-1);
355         if (evtag_unmarshal_kill(evbuf, MSG_ATTACK,
356             tmp->attack_data) == -1) {
357           event_warnx("%s: failed to unmarshal attack", __func__);
358           return (-1);
359         }
360         tmp->attack_set = 1;
361         break;
362       case MSG_RUN:
363         if (tmp->run_length >= tmp->run_num_allocated &&
364             msg_run_expand_to_hold_more(tmp) < 0) {
365           puts("HEY NOW");
366           return (-1);
367         }
368         tmp->run_data[tmp->run_length] = run_new();
369         if (tmp->run_data[tmp->run_length] == NULL)
370           return (-1);
371         if (evtag_unmarshal_run(evbuf, MSG_RUN,
372             tmp->run_data[tmp->run_length]) == -1) {
373           event_warnx("%s: failed to unmarshal run", __func__);
374           return (-1);
375         }
376         ++tmp->run_length;
377         tmp->run_set = 1;
378         break;
379       default:
380         return -1;
381     }
382   }
383 
384   if (msg_complete(tmp) == -1)
385     return (-1);
386   return (0);
387 }
388 
389 int
390 msg_complete(struct msg *msg)
391 {
392   if (!msg->from_name_set)
393     return (-1);
394   if (!msg->to_name_set)
395     return (-1);
396   if (msg->attack_set && kill_complete(msg->attack_data) == -1)
397     return (-1);
398   {
399     int i;
400     for (i = 0; i < msg->run_length; ++i) {
401       if (msg->run_set && run_complete(msg->run_data[i]) == -1)
402         return (-1);
403     }
404   }
405   return (0);
406 }
407 
408 int
409 evtag_unmarshal_msg(struct evbuffer *evbuf, ev_uint32_t need_tag,
410   struct msg *msg)
411 {
412   ev_uint32_t tag;
413   int res = -1;
414 
415   struct evbuffer *tmp = evbuffer_new();
416 
417   if (evtag_unmarshal(evbuf, &tag, tmp) == -1 || tag != need_tag)
418     goto error;
419 
420   if (msg_unmarshal(msg, tmp) == -1)
421     goto error;
422 
423   res = 0;
424 
425  error:
426   evbuffer_free(tmp);
427   return (res);
428 }
429 
430 void
431 evtag_marshal_msg(struct evbuffer *evbuf, ev_uint32_t tag,
432     const struct msg *msg)
433 {
434   struct evbuffer *buf_ = evbuffer_new();
435   assert(buf_ != NULL);
436   msg_marshal(buf_, msg);
437   evtag_marshal_buffer(evbuf, tag, buf_);
438   evbuffer_free(buf_);
439 }
440 
441 /*
442  * Implementation of kill
443  */
444 
445 static struct kill_access_ kill_base__ = {
446   kill_weapon_assign,
447   kill_weapon_get,
448   kill_action_assign,
449   kill_action_get,
450   kill_how_often_assign,
451   kill_how_often_get,
452   kill_how_often_add,
453 };
454 
455 struct kill *
456 kill_new(void)
457 {
458   return kill_new_with_arg(NULL);
459 }
460 
461 struct kill *
462 kill_new_with_arg(void *unused)
463 {
464   struct kill *tmp;
465   if ((tmp = malloc(sizeof(struct kill))) == NULL) {
466     event_warn("%s: malloc", __func__);
467     return (NULL);
468   }
469   tmp->base = &kill_base__;
470 
471   tmp->weapon_data = NULL;
472   tmp->weapon_set = 0;
473 
474   tmp->action_data = NULL;
475   tmp->action_set = 0;
476 
477   tmp->how_often_data = NULL;
478   tmp->how_often_length = 0;
479   tmp->how_often_num_allocated = 0;
480   tmp->how_often_set = 0;
481 
482   return (tmp);
483 }
484 
485 
486 
487 static int
488 kill_how_often_expand_to_hold_more(struct kill *msg)
489 {
490   int tobe_allocated = msg->how_often_num_allocated;
491   ev_uint32_t* new_data = NULL;
492   tobe_allocated = !tobe_allocated ? 1 : tobe_allocated << 1;
493   new_data = (ev_uint32_t*) realloc(msg->how_often_data,
494       tobe_allocated * sizeof(ev_uint32_t));
495   if (new_data == NULL)
496     return -1;
497   msg->how_often_data = new_data;
498   msg->how_often_num_allocated = tobe_allocated;
499   return 0;
500 }
501 
502 ev_uint32_t *
503 kill_how_often_add(struct kill *msg, const ev_uint32_t value)
504 {
505   if (++msg->how_often_length >= msg->how_often_num_allocated) {
506     if (kill_how_often_expand_to_hold_more(msg)<0)
507       goto error;
508   }
509   msg->how_often_data[msg->how_often_length - 1] = value;
510   msg->how_often_set = 1;
511   return &(msg->how_often_data[msg->how_often_length - 1]);
512 error:
513   --msg->how_often_length;
514   return (NULL);
515 }
516 
517 int
518 kill_weapon_assign(struct kill *msg,
519     const char * value)
520 {
521   if (msg->weapon_data != NULL)
522     free(msg->weapon_data);
523   if ((msg->weapon_data = strdup(value)) == NULL)
524     return (-1);
525   msg->weapon_set = 1;
526   return (0);
527 }
528 
529 int
530 kill_action_assign(struct kill *msg,
531     const char * value)
532 {
533   if (msg->action_data != NULL)
534     free(msg->action_data);
535   if ((msg->action_data = strdup(value)) == NULL)
536     return (-1);
537   msg->action_set = 1;
538   return (0);
539 }
540 
541 int
542 kill_how_often_assign(struct kill *msg, int off,
543   const ev_uint32_t value)
544 {
545   if (!msg->how_often_set || off < 0 || off >= msg->how_often_length)
546     return (-1);
547 
548   {
549     msg->how_often_data[off] = value;
550   }
551   return (0);
552 }
553 
554 int
555 kill_weapon_get(struct kill *msg, char * *value)
556 {
557   if (msg->weapon_set != 1)
558     return (-1);
559   *value = msg->weapon_data;
560   return (0);
561 }
562 
563 int
564 kill_action_get(struct kill *msg, char * *value)
565 {
566   if (msg->action_set != 1)
567     return (-1);
568   *value = msg->action_data;
569   return (0);
570 }
571 
572 int
573 kill_how_often_get(struct kill *msg, int offset,
574     ev_uint32_t *value)
575 {
576   if (!msg->how_often_set || offset < 0 || offset >= msg->how_often_length)
577     return (-1);
578   *value = msg->how_often_data[offset];
579   return (0);
580 }
581 
582 void
583 kill_clear(struct kill *tmp)
584 {
585   if (tmp->weapon_set == 1) {
586     free(tmp->weapon_data);
587     tmp->weapon_data = NULL;
588     tmp->weapon_set = 0;
589   }
590   if (tmp->action_set == 1) {
591     free(tmp->action_data);
592     tmp->action_data = NULL;
593     tmp->action_set = 0;
594   }
595   if (tmp->how_often_set == 1) {
596     free(tmp->how_often_data);
597     tmp->how_often_data = NULL;
598     tmp->how_often_set = 0;
599     tmp->how_often_length = 0;
600     tmp->how_often_num_allocated = 0;
601   }
602 }
603 
604 void
605 kill_free(struct kill *tmp)
606 {
607   if (tmp->weapon_data != NULL)
608       free (tmp->weapon_data);
609   if (tmp->action_data != NULL)
610       free (tmp->action_data);
611   if (tmp->how_often_set == 1) {
612     free(tmp->how_often_data);
613     tmp->how_often_data = NULL;
614     tmp->how_often_set = 0;
615     tmp->how_often_length = 0;
616     tmp->how_often_num_allocated = 0;
617   }
618   free(tmp->how_often_data);
619   free(tmp);
620 }
621 
622 void
623 kill_marshal(struct evbuffer *evbuf, const struct kill *tmp) {
624   evtag_marshal_string(evbuf, KILL_WEAPON, tmp->weapon_data);
625   evtag_marshal_string(evbuf, KILL_ACTION, tmp->action_data);
626   if (tmp->how_often_set) {
627     {
628       int i;
629       for (i = 0; i < tmp->how_often_length; ++i) {
630     evtag_marshal_int(evbuf, KILL_HOW_OFTEN, tmp->how_often_data[i]);
631       }
632     }
633   }
634 }
635 
636 int
637 kill_unmarshal(struct kill *tmp, struct evbuffer *evbuf)
638 {
639   ev_uint32_t tag;
640   while (evbuffer_get_length(evbuf) > 0) {
641     if (evtag_peek(evbuf, &tag) == -1)
642       return (-1);
643     switch (tag) {
644 
645       case KILL_WEAPON:
646         if (tmp->weapon_set)
647           return (-1);
648         if (evtag_unmarshal_string(evbuf, KILL_WEAPON, &tmp->weapon_data) == -1) {
649           event_warnx("%s: failed to unmarshal weapon", __func__);
650           return (-1);
651         }
652         tmp->weapon_set = 1;
653         break;
654       case KILL_ACTION:
655         if (tmp->action_set)
656           return (-1);
657         if (evtag_unmarshal_string(evbuf, KILL_ACTION, &tmp->action_data) == -1) {
658           event_warnx("%s: failed to unmarshal action", __func__);
659           return (-1);
660         }
661         tmp->action_set = 1;
662         break;
663       case KILL_HOW_OFTEN:
664         if (tmp->how_often_length >= tmp->how_often_num_allocated &&
665             kill_how_often_expand_to_hold_more(tmp) < 0) {
666           puts("HEY NOW");
667           return (-1);
668         }
669         if (evtag_unmarshal_int(evbuf, KILL_HOW_OFTEN, &tmp->how_often_data[tmp->how_often_length]) == -1) {
670           event_warnx("%s: failed to unmarshal how_often", __func__);
671           return (-1);
672         }
673         ++tmp->how_often_length;
674         tmp->how_often_set = 1;
675         break;
676       default:
677         return -1;
678     }
679   }
680 
681   if (kill_complete(tmp) == -1)
682     return (-1);
683   return (0);
684 }
685 
686 int
687 kill_complete(struct kill *msg)
688 {
689   if (!msg->weapon_set)
690     return (-1);
691   if (!msg->action_set)
692     return (-1);
693   return (0);
694 }
695 
696 int
697 evtag_unmarshal_kill(struct evbuffer *evbuf, ev_uint32_t need_tag,
698   struct kill *msg)
699 {
700   ev_uint32_t tag;
701   int res = -1;
702 
703   struct evbuffer *tmp = evbuffer_new();
704 
705   if (evtag_unmarshal(evbuf, &tag, tmp) == -1 || tag != need_tag)
706     goto error;
707 
708   if (kill_unmarshal(msg, tmp) == -1)
709     goto error;
710 
711   res = 0;
712 
713  error:
714   evbuffer_free(tmp);
715   return (res);
716 }
717 
718 void
719 evtag_marshal_kill(struct evbuffer *evbuf, ev_uint32_t tag,
720     const struct kill *msg)
721 {
722   struct evbuffer *buf_ = evbuffer_new();
723   assert(buf_ != NULL);
724   kill_marshal(buf_, msg);
725   evtag_marshal_buffer(evbuf, tag, buf_);
726   evbuffer_free(buf_);
727 }
728 
729 /*
730  * Implementation of run
731  */
732 
733 static struct run_access_ run_base__ = {
734   run_how_assign,
735   run_how_get,
736   run_some_bytes_assign,
737   run_some_bytes_get,
738   run_fixed_bytes_assign,
739   run_fixed_bytes_get,
740   run_notes_assign,
741   run_notes_get,
742   run_notes_add,
743   run_large_number_assign,
744   run_large_number_get,
745   run_other_numbers_assign,
746   run_other_numbers_get,
747   run_other_numbers_add,
748 };
749 
750 struct run *
751 run_new(void)
752 {
753   return run_new_with_arg(NULL);
754 }
755 
756 struct run *
757 run_new_with_arg(void *unused)
758 {
759   struct run *tmp;
760   if ((tmp = malloc(sizeof(struct run))) == NULL) {
761     event_warn("%s: malloc", __func__);
762     return (NULL);
763   }
764   tmp->base = &run_base__;
765 
766   tmp->how_data = NULL;
767   tmp->how_set = 0;
768 
769   tmp->some_bytes_data = NULL;
770   tmp->some_bytes_length = 0;
771   tmp->some_bytes_set = 0;
772 
773   memset(tmp->fixed_bytes_data, 0, sizeof(tmp->fixed_bytes_data));
774   tmp->fixed_bytes_set = 0;
775 
776   tmp->notes_data = NULL;
777   tmp->notes_length = 0;
778   tmp->notes_num_allocated = 0;
779   tmp->notes_set = 0;
780 
781   tmp->large_number_data = 0;
782   tmp->large_number_set = 0;
783 
784   tmp->other_numbers_data = NULL;
785   tmp->other_numbers_length = 0;
786   tmp->other_numbers_num_allocated = 0;
787   tmp->other_numbers_set = 0;
788 
789   return (tmp);
790 }
791 
792 
793 
794 
795 static int
796 run_notes_expand_to_hold_more(struct run *msg)
797 {
798   int tobe_allocated = msg->notes_num_allocated;
799   char ** new_data = NULL;
800   tobe_allocated = !tobe_allocated ? 1 : tobe_allocated << 1;
801   new_data = (char **) realloc(msg->notes_data,
802       tobe_allocated * sizeof(char *));
803   if (new_data == NULL)
804     return -1;
805   msg->notes_data = new_data;
806   msg->notes_num_allocated = tobe_allocated;
807   return 0;
808 }
809 
810 char * *
811 run_notes_add(struct run *msg, const char * value)
812 {
813   if (++msg->notes_length >= msg->notes_num_allocated) {
814     if (run_notes_expand_to_hold_more(msg)<0)
815       goto error;
816   }
817   if (value != NULL) {
818     msg->notes_data[msg->notes_length - 1] = strdup(value);
819     if (msg->notes_data[msg->notes_length - 1] == NULL) {
820       goto error;
821     }
822   } else {
823     msg->notes_data[msg->notes_length - 1] = NULL;
824   }
825   msg->notes_set = 1;
826   return &(msg->notes_data[msg->notes_length - 1]);
827 error:
828   --msg->notes_length;
829   return (NULL);
830 }
831 
832 
833 static int
834 run_other_numbers_expand_to_hold_more(struct run *msg)
835 {
836   int tobe_allocated = msg->other_numbers_num_allocated;
837   ev_uint32_t* new_data = NULL;
838   tobe_allocated = !tobe_allocated ? 1 : tobe_allocated << 1;
839   new_data = (ev_uint32_t*) realloc(msg->other_numbers_data,
840       tobe_allocated * sizeof(ev_uint32_t));
841   if (new_data == NULL)
842     return -1;
843   msg->other_numbers_data = new_data;
844   msg->other_numbers_num_allocated = tobe_allocated;
845   return 0;
846 }
847 
848 ev_uint32_t *
849 run_other_numbers_add(struct run *msg, const ev_uint32_t value)
850 {
851   if (++msg->other_numbers_length >= msg->other_numbers_num_allocated) {
852     if (run_other_numbers_expand_to_hold_more(msg)<0)
853       goto error;
854   }
855   msg->other_numbers_data[msg->other_numbers_length - 1] = value;
856   msg->other_numbers_set = 1;
857   return &(msg->other_numbers_data[msg->other_numbers_length - 1]);
858 error:
859   --msg->other_numbers_length;
860   return (NULL);
861 }
862 
863 int
864 run_how_assign(struct run *msg,
865     const char * value)
866 {
867   if (msg->how_data != NULL)
868     free(msg->how_data);
869   if ((msg->how_data = strdup(value)) == NULL)
870     return (-1);
871   msg->how_set = 1;
872   return (0);
873 }
874 
875 int
876 run_some_bytes_assign(struct run *msg, const ev_uint8_t * value, ev_uint32_t len)
877 {
878   if (msg->some_bytes_data != NULL)
879     free (msg->some_bytes_data);
880   msg->some_bytes_data = malloc(len);
881   if (msg->some_bytes_data == NULL)
882     return (-1);
883   msg->some_bytes_set = 1;
884   msg->some_bytes_length = len;
885   memcpy(msg->some_bytes_data, value, len);
886   return (0);
887 }
888 
889 int
890 run_fixed_bytes_assign(struct run *msg, const ev_uint8_t *value)
891 {
892   msg->fixed_bytes_set = 1;
893   memcpy(msg->fixed_bytes_data, value, 24);
894   return (0);
895 }
896 
897 int
898 run_notes_assign(struct run *msg, int off,
899   const char * value)
900 {
901   if (!msg->notes_set || off < 0 || off >= msg->notes_length)
902     return (-1);
903 
904   {
905     if (msg->notes_data[off] != NULL)
906       free(msg->notes_data[off]);
907     msg->notes_data[off] = strdup(value);
908     if (msg->notes_data[off] == NULL) {
909       event_warnx("%s: strdup", __func__);
910       return (-1);
911     }
912   }
913   return (0);
914 }
915 
916 int
917 run_large_number_assign(struct run *msg, const ev_uint64_t value)
918 {
919   msg->large_number_set = 1;
920   msg->large_number_data = value;
921   return (0);
922 }
923 
924 int
925 run_other_numbers_assign(struct run *msg, int off,
926   const ev_uint32_t value)
927 {
928   if (!msg->other_numbers_set || off < 0 || off >= msg->other_numbers_length)
929     return (-1);
930 
931   {
932     msg->other_numbers_data[off] = value;
933   }
934   return (0);
935 }
936 
937 int
938 run_how_get(struct run *msg, char * *value)
939 {
940   if (msg->how_set != 1)
941     return (-1);
942   *value = msg->how_data;
943   return (0);
944 }
945 
946 int
947 run_some_bytes_get(struct run *msg, ev_uint8_t * *value, ev_uint32_t *plen)
948 {
949   if (msg->some_bytes_set != 1)
950     return (-1);
951   *value = msg->some_bytes_data;
952   *plen = msg->some_bytes_length;
953   return (0);
954 }
955 
956 int
957 run_fixed_bytes_get(struct run *msg, ev_uint8_t **value)
958 {
959   if (msg->fixed_bytes_set != 1)
960     return (-1);
961   *value = msg->fixed_bytes_data;
962   return (0);
963 }
964 
965 int
966 run_notes_get(struct run *msg, int offset,
967     char * *value)
968 {
969   if (!msg->notes_set || offset < 0 || offset >= msg->notes_length)
970     return (-1);
971   *value = msg->notes_data[offset];
972   return (0);
973 }
974 
975 int
976 run_large_number_get(struct run *msg, ev_uint64_t *value)
977 {
978   if (msg->large_number_set != 1)
979     return (-1);
980   *value = msg->large_number_data;
981   return (0);
982 }
983 
984 int
985 run_other_numbers_get(struct run *msg, int offset,
986     ev_uint32_t *value)
987 {
988   if (!msg->other_numbers_set || offset < 0 || offset >= msg->other_numbers_length)
989     return (-1);
990   *value = msg->other_numbers_data[offset];
991   return (0);
992 }
993 
994 void
995 run_clear(struct run *tmp)
996 {
997   if (tmp->how_set == 1) {
998     free(tmp->how_data);
999     tmp->how_data = NULL;
1000     tmp->how_set = 0;
1001   }
1002   if (tmp->some_bytes_set == 1) {
1003     free (tmp->some_bytes_data);
1004     tmp->some_bytes_data = NULL;
1005     tmp->some_bytes_length = 0;
1006     tmp->some_bytes_set = 0;
1007   }
1008   tmp->fixed_bytes_set = 0;
1009   memset(tmp->fixed_bytes_data, 0, sizeof(tmp->fixed_bytes_data));
1010   if (tmp->notes_set == 1) {
1011     int i;
1012     for (i = 0; i < tmp->notes_length; ++i) {
1013       if (tmp->notes_data[i] != NULL) free(tmp->notes_data[i]);
1014     }
1015     free(tmp->notes_data);
1016     tmp->notes_data = NULL;
1017     tmp->notes_set = 0;
1018     tmp->notes_length = 0;
1019     tmp->notes_num_allocated = 0;
1020   }
1021   tmp->large_number_set = 0;
1022   if (tmp->other_numbers_set == 1) {
1023     free(tmp->other_numbers_data);
1024     tmp->other_numbers_data = NULL;
1025     tmp->other_numbers_set = 0;
1026     tmp->other_numbers_length = 0;
1027     tmp->other_numbers_num_allocated = 0;
1028   }
1029 }
1030 
1031 void
1032 run_free(struct run *tmp)
1033 {
1034   if (tmp->how_data != NULL)
1035       free (tmp->how_data);
1036   if (tmp->some_bytes_data != NULL)
1037       free(tmp->some_bytes_data);
1038   if (tmp->notes_set == 1) {
1039     int i;
1040     for (i = 0; i < tmp->notes_length; ++i) {
1041       if (tmp->notes_data[i] != NULL) free(tmp->notes_data[i]);
1042     }
1043     free(tmp->notes_data);
1044     tmp->notes_data = NULL;
1045     tmp->notes_set = 0;
1046     tmp->notes_length = 0;
1047     tmp->notes_num_allocated = 0;
1048   }
1049   free(tmp->notes_data);
1050   if (tmp->other_numbers_set == 1) {
1051     free(tmp->other_numbers_data);
1052     tmp->other_numbers_data = NULL;
1053     tmp->other_numbers_set = 0;
1054     tmp->other_numbers_length = 0;
1055     tmp->other_numbers_num_allocated = 0;
1056   }
1057   free(tmp->other_numbers_data);
1058   free(tmp);
1059 }
1060 
1061 void
1062 run_marshal(struct evbuffer *evbuf, const struct run *tmp) {
1063   evtag_marshal_string(evbuf, RUN_HOW, tmp->how_data);
1064   if (tmp->some_bytes_set) {
1065     evtag_marshal(evbuf, RUN_SOME_BYTES, tmp->some_bytes_data, tmp->some_bytes_length);
1066   }
1067   evtag_marshal(evbuf, RUN_FIXED_BYTES, tmp->fixed_bytes_data, (24));
1068   if (tmp->notes_set) {
1069     {
1070       int i;
1071       for (i = 0; i < tmp->notes_length; ++i) {
1072     evtag_marshal_string(evbuf, RUN_NOTES, tmp->notes_data[i]);
1073       }
1074     }
1075   }
1076   if (tmp->large_number_set) {
1077     evtag_marshal_int64(evbuf, RUN_LARGE_NUMBER, tmp->large_number_data);
1078   }
1079   if (tmp->other_numbers_set) {
1080     {
1081       int i;
1082       for (i = 0; i < tmp->other_numbers_length; ++i) {
1083     evtag_marshal_int(evbuf, RUN_OTHER_NUMBERS, tmp->other_numbers_data[i]);
1084       }
1085     }
1086   }
1087 }
1088 
1089 int
1090 run_unmarshal(struct run *tmp, struct evbuffer *evbuf)
1091 {
1092   ev_uint32_t tag;
1093   while (evbuffer_get_length(evbuf) > 0) {
1094     if (evtag_peek(evbuf, &tag) == -1)
1095       return (-1);
1096     switch (tag) {
1097 
1098       case RUN_HOW:
1099         if (tmp->how_set)
1100           return (-1);
1101         if (evtag_unmarshal_string(evbuf, RUN_HOW, &tmp->how_data) == -1) {
1102           event_warnx("%s: failed to unmarshal how", __func__);
1103           return (-1);
1104         }
1105         tmp->how_set = 1;
1106         break;
1107       case RUN_SOME_BYTES:
1108         if (tmp->some_bytes_set)
1109           return (-1);
1110         if (evtag_payload_length(evbuf, &tmp->some_bytes_length) == -1)
1111           return (-1);
1112         if (tmp->some_bytes_length > evbuffer_get_length(evbuf))
1113           return (-1);
1114         if ((tmp->some_bytes_data = malloc(tmp->some_bytes_length)) == NULL)
1115           return (-1);
1116         if (evtag_unmarshal_fixed(evbuf, RUN_SOME_BYTES, tmp->some_bytes_data, tmp->some_bytes_length) == -1) {
1117           event_warnx("%s: failed to unmarshal some_bytes", __func__);
1118           return (-1);
1119         }
1120         tmp->some_bytes_set = 1;
1121         break;
1122       case RUN_FIXED_BYTES:
1123         if (tmp->fixed_bytes_set)
1124           return (-1);
1125         if (evtag_unmarshal_fixed(evbuf, RUN_FIXED_BYTES, tmp->fixed_bytes_data, (24)) == -1) {
1126           event_warnx("%s: failed to unmarshal fixed_bytes", __func__);
1127           return (-1);
1128         }
1129         tmp->fixed_bytes_set = 1;
1130         break;
1131       case RUN_NOTES:
1132         if (tmp->notes_length >= tmp->notes_num_allocated &&
1133             run_notes_expand_to_hold_more(tmp) < 0) {
1134           puts("HEY NOW");
1135           return (-1);
1136         }
1137         if (evtag_unmarshal_string(evbuf, RUN_NOTES, &tmp->notes_data[tmp->notes_length]) == -1) {
1138           event_warnx("%s: failed to unmarshal notes", __func__);
1139           return (-1);
1140         }
1141         ++tmp->notes_length;
1142         tmp->notes_set = 1;
1143         break;
1144       case RUN_LARGE_NUMBER:
1145         if (tmp->large_number_set)
1146           return (-1);
1147         if (evtag_unmarshal_int64(evbuf, RUN_LARGE_NUMBER, &tmp->large_number_data) == -1) {
1148           event_warnx("%s: failed to unmarshal large_number", __func__);
1149           return (-1);
1150         }
1151         tmp->large_number_set = 1;
1152         break;
1153       case RUN_OTHER_NUMBERS:
1154         if (tmp->other_numbers_length >= tmp->other_numbers_num_allocated &&
1155             run_other_numbers_expand_to_hold_more(tmp) < 0) {
1156           puts("HEY NOW");
1157           return (-1);
1158         }
1159         if (evtag_unmarshal_int(evbuf, RUN_OTHER_NUMBERS, &tmp->other_numbers_data[tmp->other_numbers_length]) == -1) {
1160           event_warnx("%s: failed to unmarshal other_numbers", __func__);
1161           return (-1);
1162         }
1163         ++tmp->other_numbers_length;
1164         tmp->other_numbers_set = 1;
1165         break;
1166       default:
1167         return -1;
1168     }
1169   }
1170 
1171   if (run_complete(tmp) == -1)
1172     return (-1);
1173   return (0);
1174 }
1175 
1176 int
1177 run_complete(struct run *msg)
1178 {
1179   if (!msg->how_set)
1180     return (-1);
1181   if (!msg->fixed_bytes_set)
1182     return (-1);
1183   return (0);
1184 }
1185 
1186 int
1187 evtag_unmarshal_run(struct evbuffer *evbuf, ev_uint32_t need_tag,
1188   struct run *msg)
1189 {
1190   ev_uint32_t tag;
1191   int res = -1;
1192 
1193   struct evbuffer *tmp = evbuffer_new();
1194 
1195   if (evtag_unmarshal(evbuf, &tag, tmp) == -1 || tag != need_tag)
1196     goto error;
1197 
1198   if (run_unmarshal(msg, tmp) == -1)
1199     goto error;
1200 
1201   res = 0;
1202 
1203  error:
1204   evbuffer_free(tmp);
1205   return (res);
1206 }
1207 
1208 void
1209 evtag_marshal_run(struct evbuffer *evbuf, ev_uint32_t tag,
1210     const struct run *msg)
1211 {
1212   struct evbuffer *buf_ = evbuffer_new();
1213   assert(buf_ != NULL);
1214   run_marshal(buf_, msg);
1215   evtag_marshal_buffer(evbuf, tag, buf_);
1216   evbuffer_free(buf_);
1217 }
1218 
1219