libamxc  1.10.3
C Generic Data Containers
variant_char.c
Go to the documentation of this file.
1 /****************************************************************************
2 **
3 ** SPDX-License-Identifier: BSD-2-Clause-Patent
4 **
5 ** SPDX-FileCopyrightText: Copyright (c) 2023 SoftAtHome
6 **
7 ** Redistribution and use in source and binary forms, with or without modification,
8 ** are permitted provided that the following conditions are met:
9 **
10 ** 1. Redistributions of source code must retain the above copyright notice,
11 ** this list of conditions and the following disclaimer.
12 **
13 ** 2. Redistributions in binary form must reproduce the above copyright notice,
14 ** this list of conditions and the following disclaimer in the documentation
15 ** and/or other materials provided with the distribution.
16 **
17 ** Subject to the terms and conditions of this license, each copyright holder
18 ** and contributor hereby grants to those receiving rights under this license
19 ** a perpetual, worldwide, non-exclusive, no-charge, royalty-free, irrevocable
20 ** (except for failure to satisfy the conditions of this license) patent license
21 ** to make, have made, use, offer to sell, sell, import, and otherwise transfer
22 ** this software, where such license applies only to those patent claims, already
23 ** acquired or hereafter acquired, licensable by such copyright holder or contributor
24 ** that are necessarily infringed by:
25 **
26 ** (a) their Contribution(s) (the licensed copyrights of copyright holders and
27 ** non-copyrightable additions of contributors, in source or binary form) alone;
28 ** or
29 **
30 ** (b) combination of their Contribution(s) with the work of authorship to which
31 ** such Contribution(s) was added by such copyright holder or contributor, if,
32 ** at the time the Contribution is added, such addition causes such combination
33 ** to be necessarily infringed. The patent license shall not apply to any other
34 ** combinations which include the Contribution.
35 **
36 ** Except as expressly stated above, no rights or licenses from any copyright
37 ** holder or contributor is granted under this license, whether expressly, by
38 ** implication, estoppel or otherwise.
39 **
40 ** DISCLAIMER
41 **
42 ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
43 ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
44 ** IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
45 ** ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
46 ** LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
47 ** DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
48 ** SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
49 ** CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
50 ** OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
51 ** USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
52 **
53 ****************************************************************************/
54 
55 #ifndef _GNU_SOURCE
56 #define _GNU_SOURCE
57 #endif
58 
59 #include <stdlib.h>
60 #include <string.h>
61 #include <limits.h>
62 #include <ctype.h>
63 #include <errno.h>
64 
65 #include <amxc/amxc_string_split.h>
66 #include <amxc_variant_priv.h>
67 
68 static const char* variant_char_validate_number(const amxc_var_t* const src, int* retval) {
69  const char* buffer = NULL;
70  *retval = -1;
71  when_true((src->data.s == NULL) || (*(src->data.s) == 0), exit);
72 
73  buffer = src->data.s;
74  // skip whitespaces
75  while(isspace(*buffer)) {
76  buffer++;
77  }
78 
79  when_true(!isdigit(*buffer) && *buffer != '+' && *buffer != '-', exit);
80  *retval = 0;
81 
82 exit:
83  return buffer;
84 }
85 
86 static int variant_char_to_signed_int(amxc_var_t* const dest,
87  const amxc_var_t* const src) {
88  int retval = -1;
89  amxc_var_t intermediate;
90  const char* buffer = NULL;
91  char* endptr = NULL;
92 
93  intermediate.type_id = AMXC_VAR_ID_INT64;
94  intermediate.data.i64 = 0;
95 
96  buffer = variant_char_validate_number(src, &retval);
97  when_true(retval != 0, exit);
98 
99  retval = -1;
100  errno = 0;
101  intermediate.data.i64 = strtoll(buffer, &endptr, 0);
102 
103  when_true((errno == ERANGE && (intermediate.data.i64 == LLONG_MIN ||
104  intermediate.data.i64 == LLONG_MAX)) ||
105  (errno != 0 && intermediate.data.i64 == 0), exit);
106  when_true(endptr == buffer || *endptr != '\0', exit);
107 
108  retval = amxc_var_convert(dest, &intermediate, dest->type_id);
109 
110 exit:
111  return retval;
112 }
113 
115  const amxc_var_t* const src) {
116  int retval = -1;
117  amxc_var_t intermediate;
118  const char* buffer = NULL;
119  char* endptr = NULL;
120 
121  intermediate.type_id = AMXC_VAR_ID_UINT64;
122  intermediate.data.ui64 = 0;
123 
124  buffer = variant_char_validate_number(src, &retval);
125  when_true(retval != 0, exit);
126 
127  retval = -1;
128  errno = 0;
129  intermediate.data.ui64 = llabs(strtoll(buffer, &endptr, 0));
130 
131  when_true((errno == ERANGE && (intermediate.data.ui64 == 0 ||
132  intermediate.data.ui64 == ULLONG_MAX)) ||
133  (errno != 0 && intermediate.data.ui64 == 0), exit);
134  when_true(endptr == buffer || *endptr != '\0', exit);
135 
136  retval = amxc_var_convert(dest, &intermediate, dest->type_id);
137 
138 exit:
139  return retval;
140 }
141 
142 static int variant_char_to_double(amxc_var_t* const dest,
143  const amxc_var_t* const src) {
144  int retval = -1;
145  const char* buffer = NULL;
146  char* endptr = NULL;
147 
148  buffer = variant_char_validate_number(src, &retval);
149  when_true(retval != 0, exit);
150 
151  retval = -1;
152  errno = 0;
153  dest->data.d = strtod(buffer, &endptr);
154 
155  if(((errno == ERANGE) && (dest->data.d == 0)) ||
156  (( errno != 0) && ( dest->data.d == 0)) ||
157  (endptr == buffer) ||
158  (*endptr != '\0')) {
159  goto exit;
160  }
161 
162  retval = 0;
163 
164 exit:
165  return retval;
166 }
167 
168 static int variant_char_to_float(amxc_var_t* const dest,
169  const amxc_var_t* const src) {
170  int retval = -1;
171  const char* buffer = NULL;
172  char* endptr = NULL;
173 
174  buffer = variant_char_validate_number(src, &retval);
175  when_true(retval != 0, exit);
176 
177  retval = -1;
178  errno = 0;
179  dest->data.f = strtof(buffer, &endptr);
180 
181  if(((errno == ERANGE) && (dest->data.f == 0)) ||
182  (( errno != 0) && ( dest->data.f == 0)) ||
183  (endptr == buffer) ||
184  (*endptr != '\0')) {
185  goto exit;
186  }
187 
188  retval = 0;
189 
190 exit:
191  return retval;
192 }
193 
194 static int variant_char_to_bool(amxc_var_t* const dest,
195  const amxc_var_t* const src) {
196  int retval = -1;
197  char* lower_src = NULL;
198  int src_len = 0;
199  int src_pos = 0;
200  const char true_values[4][10] = { "true", "yes", "1", "on" };
201  const char false_values[4][10] = { "false", "no", "0", "off" };
202 
203  when_true((src->data.s == NULL) || (*(src->data.s) == 0), exit);
204 
205  src_len = strlen(src->data.s) + 1;
206  lower_src = (char*) calloc(1, src_len);
207  when_null(lower_src, exit);
208 
209  for(int i = 0; i < src_len; i++) {
210  if(isspace(*(src->data.s + i))) {
211  // skip white spaces
212  continue;
213  }
214  lower_src[src_pos] = tolower(*(src->data.s + i));
215  src_pos++;
216  }
217 
218  for(int index = 0; index < 4; index++) {
219  if(strcmp(lower_src, true_values[index]) == 0) {
220  dest->data.b = true;
221  retval = 0;
222  break;
223  } else if(strcmp(lower_src, false_values[index]) == 0) {
224  dest->data.b = false;
225  retval = 0;
226  break;
227  }
228  }
229 
230  free(lower_src);
231 
232 exit:
233  return retval;
234 }
235 
236 static int variant_char_to_list(amxc_var_t* const dest,
237  const amxc_var_t* const src) {
238  amxc_string_t str;
239  int retval = 0;
240 
241  amxc_string_init(&str, 0);
243  when_null(src->data.s, exit);
244 
245  if(*(src->data.s) != 0) {
246  amxc_string_push_buffer(&str, src->data.s, strlen(src->data.s) + 1);
247  if(src->type_id == AMXC_VAR_ID_SSV_STRING) {
248  retval = amxc_string_ssv_to_var(&str, dest, NULL);
249  } else {
250  retval = amxc_string_csv_to_var(&str, dest, NULL);
251  }
253  } else {
254  retval = 0;
255  }
256 
257 exit:
258  amxc_string_clean(&str);
259  return retval;
260 }
261 
262 static int variant_char_to_htable(amxc_var_t* const dest,
263  const amxc_var_t* const src) {
264  char* temp = NULL;
265  int retval = 0;
266  char* element = NULL;
267  int length = 0;
268 
270  when_true(src->data.s == NULL || src->data.s == 0, exit);
271 
272  length = strlen(src->data.s) + 1;
273  temp = (char*) calloc(1, length);
274  when_null(temp, exit);
275  memcpy(temp, src->data.s, length);
276 
277  element = strtok(temp, ",");
278  while(element) {
279  amxc_var_t* var = NULL;
280  char* key = NULL;
281  char* data = NULL;
282  when_failed(amxc_var_new(&var), exit);
283 
285  key = element;
286  while(*key) {
287  if(*key == ':') {
288  *key = 0;
289  data = key + 1;
290  break;
291  }
292  key++;
293  }
294  key = element;
295  if(data != NULL) {
296  length = strlen(data) + 1;
297  var->data.s = (char*) calloc(1, length);
298  if(var->data.s == NULL) {
301  goto exit;
302  }
303  memcpy(var->data.s, data, length);
304  }
305  amxc_htable_insert(&dest->data.vm, key, &var->hit);
306  element = strtok(NULL, ",");
307  }
308 
309  retval = 0;
310 
311 exit:
312  free(temp);
313  return retval;
314 }
315 
316 static int variant_char_to_ts(amxc_var_t* const dest,
317  const amxc_var_t* const src) {
318 
319  int retval = amxc_ts_parse(&dest->data.ts, src->data.s, strlen(src->data.s));
320  return retval;
321 }
322 
323 static int variant_char_copy(amxc_var_t* const dest,
324  const amxc_var_t* const src) {
325  int retval = -1;
326  if(src->data.s != NULL) {
327  int length = strlen(src->data.s) + 1;
328  dest->data.s = (char*) calloc(1, length);
329  when_null(dest->data.s, exit);
330  memcpy(dest->data.s, src->data.s, length);
331  }
332  retval = 0;
333 
334 exit:
335  return retval;
336 }
337 
338 static int variant_char_move(amxc_var_t* const dest,
339  amxc_var_t* const src) {
340  dest->data.s = src->data.s;
341  src->data.s = NULL;
342 
343  return 0;
344 }
345 
346 static void variant_char_delete(amxc_var_t* const var) {
347  free(var->data.s);
348  var->data.s = NULL;
349 }
350 
351 static int variant_char_auto_convert(amxc_var_t* const dest,
352  const amxc_var_t* const src) {
353  const char* str_src = src->data.s;
354  int retval = -1;
355  int src_pos = 0;
356  int src_len = 0;
357  when_true(str_src == NULL, exit);
358 
359  src_len = strlen(str_src);
360  if(src_len == 0) {
361  retval = 0;
363  goto exit;
364  }
365 
366  for(int i = 0; i < src_len; i++) {
367  if(isspace(*(src->data.s + i)) == 0) {
368  break;
369  }
370  // skip white spaces
371  src_pos++;
372  }
373 
374  switch(str_src[src_pos]) {
375  case 't':
376  case 'T':
377  case 'y':
378  case 'Y':
379  case 'f':
380  case 'F':
381  case 'n':
382  case 'N':
383  case 'o':
384  case 'O':
385  dest->type_id = AMXC_VAR_ID_BOOL;
386  retval = variant_char_to_bool(dest, src);
387  break;
388  case '+':
389  case '-':
390  dest->type_id = AMXC_VAR_ID_INT32;
391  retval = variant_char_to_signed_int(dest, src);
392  when_true(retval == 0, exit);
393  dest->type_id = AMXC_VAR_ID_INT64;
394  retval = variant_char_to_signed_int(dest, src);
395  when_true(retval == 0, exit);
396  dest->type_id = AMXC_VAR_ID_DOUBLE;
397  retval = variant_char_to_double(dest, src);
398  break;
399  default:
400  dest->type_id = AMXC_VAR_ID_UINT32;
401  retval = variant_char_to_unsigned_int(dest, src);
402  when_true(retval == 0, exit);
403  dest->type_id = AMXC_VAR_ID_UINT64;
404  retval = variant_char_to_unsigned_int(dest, src);
405  when_true(retval == 0, exit);
406  dest->type_id = AMXC_VAR_ID_DOUBLE;
407  retval = variant_char_to_double(dest, src);
408  }
409  when_true(retval == 0, exit);
410 
412  retval = variant_char_to_ts(dest, src);
413  when_true(retval == 0, exit);
414 
416  retval = variant_char_copy(dest, src);
417 
418 exit:
419  return retval;
420 }
421 
422 static int variant_char_convert_to(amxc_var_t* const dest,
423  const amxc_var_t* const src) {
424  int retval = -1;
425 
428  variant_char_copy, // c string
437  variant_char_to_float, // float
438  variant_char_to_double, // double
439  variant_char_to_bool, // bool
440  variant_char_to_list, // linked list
441  variant_char_to_htable, // hash table
442  NULL, // file descriptor
443  variant_char_to_ts, // timestamp
444  variant_char_copy, // comma separated values string
445  variant_char_copy, // space separated values string
446  variant_char_auto_convert, // any type (auto detect)
447  };
448 
449  if(dest->type_id >= AMXC_VAR_ID_CUSTOM_BASE) {
450  goto exit;
451  }
452 
453  if(convfn[dest->type_id] != NULL) {
454  retval = convfn[dest->type_id](dest, src);
455  }
456 
457 exit:
458  return retval;
459 }
460 
461 static int variant_char_compare(const amxc_var_t* const lval,
462  const amxc_var_t* const rval,
463  int* const result) {
464  *result = strcmp(lval->data.s == NULL ? "" : lval->data.s,
465  rval->data.s == NULL ? "" : rval->data.s);
466  return 0;
467 }
468 
470  .init = NULL,
471  .del = variant_char_delete,
472  .copy = variant_char_copy,
473  .move = variant_char_move,
474  .convert_from = NULL,
475  .convert_to = variant_char_convert_to,
476  .compare = variant_char_compare,
477  .get_key = NULL,
478  .set_key = NULL,
479  .get_index = NULL,
480  .set_index = NULL,
481  .type_id = 0,
482  .hit = { .ait = NULL, .key = NULL, .next = NULL },
483  .name = AMXC_VAR_NAME_CSTRING
484 };
485 
487  .init = NULL,
488  .del = variant_char_delete,
489  .copy = variant_char_copy,
490  .move = variant_char_move,
491  .convert_from = NULL,
492  .convert_to = variant_char_convert_to,
493  .compare = variant_char_compare,
494  .get_key = NULL,
495  .set_key = NULL,
496  .get_index = NULL,
497  .set_index = NULL,
498  .type_id = 0,
499  .hit = { .ait = NULL, .key = NULL, .next = NULL },
501 };
502 
504  .init = NULL,
505  .del = variant_char_delete,
506  .copy = variant_char_copy,
507  .move = variant_char_move,
508  .convert_from = NULL,
509  .convert_to = variant_char_convert_to,
510  .compare = variant_char_compare,
511  .get_key = NULL,
512  .set_key = NULL,
513  .get_index = NULL,
514  .set_index = NULL,
515  .type_id = 0,
516  .hit = { .ait = NULL, .key = NULL, .next = NULL },
518 };
519 
520 CONSTRUCTOR static void amxc_var_char_init(void) {
524 }
525 
530 }
531 
532 static int amxc_var_set_data(amxc_var_t* const var, const char* const val) {
533  int retval = -1;
534  int length = 0;
535 
536  length = strlen(val) + 1;
537  var->data.s = (char*) calloc(1, length);
538  when_null(var->data.s, exit);
539  memcpy(var->data.s, val, length);
540  retval = 0;
541 
542 exit:
543  if(retval != 0) {
545  }
546  return retval;
547 }
548 
549 int amxc_var_set_cstring_t(amxc_var_t* const var, const char* const val) {
550  int retval = -1;
551  when_null(var, exit);
552  when_null(val, exit);
554 
555  retval = amxc_var_set_data(var, val);
556 
557 exit:
558  return retval;
559 }
560 
561 int amxc_var_set_csv_string_t(amxc_var_t* const var, const char* const val) {
562  int retval = -1;
563  when_null(var, exit);
564  when_null(val, exit);
566 
567  retval = amxc_var_set_data(var, val);
568 
569 exit:
570  return retval;
571 }
572 
573 int amxc_var_set_ssv_string_t(amxc_var_t* const var, const char* const val) {
574  int retval = -1;
575  when_null(var, exit);
576  when_null(val, exit);
578 
579  retval = amxc_var_set_data(var, val);
580 
581 exit:
582  return retval;
583 }
584 
586  char* retval = NULL;
587  amxc_var_t variant;
588  when_null(var, exit);
589 
590  amxc_var_init(&variant);
592  retval = variant.data.s != NULL ? variant.data.s : strdup("");
593  variant.data.s = NULL;
594  amxc_var_clean(&variant);
595 
596 exit:
597  return retval;
598 }
599 
601  const char* retval = NULL;
602  when_null(var, exit);
606 
607  retval = var->data.s == NULL ? "" : var->data.s;
608 
609 exit:
610  return retval;
611 }
612 
614  char* retval = NULL;
615  when_null(var, exit);
619 
620  retval = var->data.s;
621 
622  var->data.s = NULL;
624 
625 exit:
626  return retval;
627 }
628 
629 int amxc_var_push_cstring_t(amxc_var_t* const var, char* val) {
630  int retval = -1;
631 
632  when_null(var, exit);
634 
636  var->data.s = val;
637 
638  retval = 0;
639 
640 exit:
641  return retval;
642 }
643 
644 int amxc_var_push_csv_string_t(amxc_var_t* const var, char* val) {
645  int retval = -1;
646 
647  retval = amxc_var_push_cstring_t(var, val);
648  if(retval == 0) {
650  }
651 
652  return retval;
653 }
654 
655 int amxc_var_push_ssv_string_t(amxc_var_t* const var, char* val) {
656  int retval = -1;
657 
658  retval = amxc_var_push_cstring_t(var, val);
659  if(retval == 0) {
661  }
662 
663  return retval;
664 }
665 
666 amxc_var_t* amxc_var_add_new_cstring_t(amxc_var_t* const var, const char* const val) {
667  amxc_var_t* subvar = NULL;
668 
669  when_null(var, exit);
670  subvar = amxc_var_add_new(var);
671  when_null(subvar, exit);
672 
673  if(amxc_var_set_cstring_t(subvar, val) != 0) {
674  amxc_var_delete(&subvar);
675  }
676 
677 exit:
678  return subvar;
679 }
680 
681 amxc_var_t* amxc_var_add_new_csv_string_t(amxc_var_t* const var, const char* const val) {
682  amxc_var_t* subvar = NULL;
683 
684  when_null(var, exit);
685  subvar = amxc_var_add_new(var);
686  when_null(subvar, exit);
687 
688  if(amxc_var_set_csv_string_t(subvar, val) != 0) {
689  amxc_var_delete(&subvar);
690  }
691 
692 exit:
693  return subvar;
694 }
695 
696 amxc_var_t* amxc_var_add_new_ssv_string_t(amxc_var_t* const var, const char* const val) {
697  amxc_var_t* subvar = NULL;
698 
699  when_null(var, exit);
700  subvar = amxc_var_add_new(var);
701  when_null(subvar, exit);
702 
703  if(amxc_var_set_csv_string_t(subvar, val) != 0) {
704  amxc_var_delete(&subvar);
705  }
706 
707 exit:
708  return subvar;
709 }
710 
712  const char* key,
713  const char* const val) {
714  amxc_var_t* subvar = NULL;
715 
716  when_null(var, exit);
717  subvar = amxc_var_add_new_key(var, key);
718  when_null(subvar, exit);
719 
720  if(amxc_var_set_cstring_t(subvar, val) != 0) {
721  amxc_var_delete(&subvar);
722  }
723 
724 exit:
725  return subvar;
726 }
727 
729  const char* key,
730  const char* const val) {
731  amxc_var_t* subvar = NULL;
732 
733  when_null(var, exit);
734  subvar = amxc_var_add_new_key(var, key);
735  when_null(subvar, exit);
736 
737  if(amxc_var_set_csv_string_t(subvar, val) != 0) {
738  amxc_var_delete(&subvar);
739  }
740 
741 exit:
742  return subvar;
743 }
744 
746  const char* key,
747  const char* const val) {
748  amxc_var_t* subvar = NULL;
749 
750  when_null(var, exit);
751  subvar = amxc_var_add_new_key(var, key);
752  when_null(subvar, exit);
753 
754  if(amxc_var_set_ssv_string_t(subvar, val) != 0) {
755  amxc_var_delete(&subvar);
756  }
757 
758 exit:
759  return subvar;
760 }
#define when_failed(x, l)
Definition: amxc_macros.h:142
#define when_true(x, l)
Definition: amxc_macros.h:134
#define CONSTRUCTOR
Definition: amxc_macros.h:86
#define when_null(x, l)
Definition: amxc_macros.h:126
#define DESTRUCTOR
Definition: amxc_macros.h:90
#define cstring_t
Convenience macro.
Definition: amxc_variant.h:584
int PRIVATE amxc_var_default_convert_to_null(amxc_var_t *const dest, const amxc_var_t *const src)
uint32_t PRIVATE amxc_var_add_type(amxc_var_type_t *const type, const uint32_t index)
int PRIVATE amxc_var_remove_type(amxc_var_type_t *const type)
int amxc_htable_insert(amxc_htable_t *const htable, const char *const key, amxc_htable_it_t *const it)
Inserts an item in the hash table.
Definition: amxc_htable.c:237
void amxc_htable_clean(amxc_htable_t *const htable, amxc_htable_it_delete_t func)
Removes all items from the hash table.
Definition: amxc_htable.c:200
amxc_string_split_status_t amxc_string_csv_to_var(const amxc_string_t *const string, amxc_var_t *var, const char **reason)
Split a string in individual parts assuming that the string contains comma separated values.
amxc_string_split_status_t amxc_string_ssv_to_var(const amxc_string_t *const string, amxc_var_t *var, const char **reason)
Split a string in individual parts assuming that the string contains space separated values.
int amxc_string_push_buffer(amxc_string_t *const string, char *buffer, size_t length)
Sets the string buffer.
Definition: amxc_string.c:372
int amxc_string_init(amxc_string_t *const string, const size_t length)
Initializes a string.
Definition: amxc_string.c:163
void amxc_string_clean(amxc_string_t *const string)
Frees the string buffer and reset length attributes.
Definition: amxc_string.c:189
char * amxc_string_take_buffer(amxc_string_t *const string)
Takes the string buffer.
Definition: amxc_string.c:356
int amxc_ts_parse(amxc_ts_t *tsp, const char *str, size_t len)
Transforms the given string in to unix epoch time.
int amxc_var_push_ssv_string_t(amxc_var_t *const var, char *val)
Pushes a value in a variant.
Definition: variant_char.c:655
amxc_var_t * amxc_var_add_new_key_csv_string_t(amxc_var_t *const var, const char *key, const char *const val)
Conversion helper function.
Definition: variant_char.c:728
int amxc_var_set_cstring_t(amxc_var_t *const var, const char *const val)
Setter helper function.
Definition: variant_char.c:549
amxc_var_t * amxc_var_add_new_key_ssv_string_t(amxc_var_t *const var, const char *key, const char *const val)
Conversion helper function.
Definition: variant_char.c:745
amxc_var_t * amxc_var_add_new_key_cstring_t(amxc_var_t *const var, const char *key, const char *const val)
Conversion helper function.
Definition: variant_char.c:711
cstring_t amxc_var_take_cstring_t(amxc_var_t *const var)
Takes a value from a variant.
Definition: variant_char.c:613
amxc_var_t * amxc_var_add_new_cstring_t(amxc_var_t *const var, const char *const val)
Conversion helper function.
Definition: variant_char.c:666
void variant_htable_it_free(const char *key, amxc_htable_it_t *it)
Helper functions, can be used as delete function for htable.
int amxc_var_push_csv_string_t(amxc_var_t *const var, char *val)
Pushes a value in a variant.
Definition: variant_char.c:644
int amxc_var_set_ssv_string_t(amxc_var_t *const var, const char *const val)
Setter helper function.
Definition: variant_char.c:573
amxc_var_t * amxc_var_add_new_csv_string_t(amxc_var_t *const var, const char *const val)
Conversion helper function.
Definition: variant_char.c:681
const cstring_t amxc_var_get_const_cstring_t(const amxc_var_t *const var)
Conversion helper function.
Definition: variant_char.c:600
cstring_t amxc_var_get_cstring_t(const amxc_var_t *const var)
Conversion helper function.
Definition: variant_char.c:585
int amxc_var_set_csv_string_t(amxc_var_t *const var, const char *const val)
Setter helper function.
Definition: variant_char.c:561
int amxc_var_push_cstring_t(amxc_var_t *const var, char *val)
Pushes a value in a variant.
Definition: variant_char.c:629
amxc_var_t * amxc_var_add_new_ssv_string_t(amxc_var_t *const var, const char *const val)
Conversion helper function.
Definition: variant_char.c:696
#define AMXC_VAR_ID_UINT32
Unsigned 32 bit integer variant id.
Definition: amxc_variant.h:176
#define AMXC_VAR_ID_CUSTOM_BASE
Base variant id for custom variants.
Definition: amxc_variant.h:257
#define AMXC_VAR_NAME_CSV_STRING
Provides a name for variant id AMXC_VAR_ID_CSV_STRING.
Definition: amxc_variant.h:372
#define AMXC_VAR_ID_NULL
Null variant type id (aka void)
Definition: amxc_variant.h:128
#define AMXC_VAR_ID_CSTRING
C-string variant id (aka char *), null terminated string.
Definition: amxc_variant.h:134
#define AMXC_VAR_NAME_CSTRING
Provides a name for variant id AMXC_VAR_ID_CSTRING.
Definition: amxc_variant.h:276
#define AMXC_VAR_ID_UINT64
Unsigned 64 bit integer variant id.
Definition: amxc_variant.h:182
#define AMXC_VAR_ID_DOUBLE
Double variant id.
Definition: amxc_variant.h:194
#define AMXC_VAR_NAME_SSV_STRING
Provides a name for variant id AMXC_VAR_ID_SSV_STRING.
Definition: amxc_variant.h:378
#define AMXC_VAR_ID_SSV_STRING
Space Separated Values string variant id.
Definition: amxc_variant.h:236
#define AMXC_VAR_ID_BOOL
Boolean variant id.
Definition: amxc_variant.h:200
#define AMXC_VAR_ID_INT32
Signed 32 bit integer variant id.
Definition: amxc_variant.h:152
#define AMXC_VAR_ID_TIMESTAMP
Ambiorix timestamp variant id.
Definition: amxc_variant.h:224
#define AMXC_VAR_ID_CSV_STRING
Comma Separated Values string variant id.
Definition: amxc_variant.h:230
#define AMXC_VAR_ID_LIST
Ambiorix Linked List variant id.
Definition: amxc_variant.h:206
#define AMXC_VAR_ID_HTABLE
Ambiorix Hash Table variant id.
Definition: amxc_variant.h:212
#define AMXC_VAR_ID_INT64
Signed 64 bit integer variant id.
Definition: amxc_variant.h:158
int(* amxc_var_convert_fn_t)(amxc_var_t *const dest, const amxc_var_t *const src)
Variant type callback function prototype for dynamically converting one type to another.
int amxc_var_set_type(amxc_var_t *const var, const uint32_t type)
Change the variant data type.
Definition: amxc_variant.c:261
int amxc_var_new(amxc_var_t **var)
Allocates a variant and initializes it to the null variant type.
Definition: amxc_variant.c:194
int amxc_var_init(amxc_var_t *const var)
Initializes a variant.
Definition: amxc_variant.c:223
amxc_var_t * amxc_var_add_new(amxc_var_t *const var)
Adds a new variant to a composite variant.
Definition: amxc_variant.c:551
void amxc_var_clean(amxc_var_t *const var)
Clean-up and reset variant.
Definition: amxc_variant.c:237
void amxc_var_delete(amxc_var_t **var)
Frees the previously allocated variant.
Definition: amxc_variant.c:207
amxc_var_t * amxc_var_add_new_key(amxc_var_t *const var, const char *key)
Adds a new variant with a key to a composite variant.
Definition: amxc_variant.c:526
int amxc_var_convert(amxc_var_t *const dest, const amxc_var_t *src, const uint32_t type_id)
Converts one variant (source) to another variant(destination) using the specified variant type id.
Definition: amxc_variant.c:333
The string structure.
Definition: amxc_string.h:103
A variant type structure.
amxc_var_new_fn_t init
The variant struct definition.
Definition: amxc_variant.h:861
void * data
Definition: amxc_variant.h:883
amxc_htable_it_t hit
Definition: amxc_variant.h:863
uint32_t type_id
Definition: amxc_variant.h:864
char data[]
static amxc_var_t * var
Definition: test_issue_58.c:77
static amxc_var_type_t amxc_variant_char
Definition: variant_char.c:469
static DESTRUCTOR void amxc_var_char_cleanup(void)
Definition: variant_char.c:526
static CONSTRUCTOR void amxc_var_char_init(void)
Definition: variant_char.c:520
static int variant_char_to_htable(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:262
static int variant_char_to_unsigned_int(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:114
static int variant_char_to_list(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:236
static amxc_var_type_t amxc_variant_ssv_char
Definition: variant_char.c:503
static int variant_char_compare(const amxc_var_t *const lval, const amxc_var_t *const rval, int *const result)
Definition: variant_char.c:461
static void variant_char_delete(amxc_var_t *const var)
Definition: variant_char.c:346
static int variant_char_move(amxc_var_t *const dest, amxc_var_t *const src)
Definition: variant_char.c:338
static int variant_char_to_bool(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:194
static int amxc_var_set_data(amxc_var_t *const var, const char *const val)
Definition: variant_char.c:532
static int variant_char_to_double(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:142
static int variant_char_to_signed_int(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:86
static int variant_char_to_ts(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:316
static const char * variant_char_validate_number(const amxc_var_t *const src, int *retval)
Definition: variant_char.c:68
static int variant_char_auto_convert(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:351
static int variant_char_convert_to(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:422
static amxc_var_type_t amxc_variant_csv_char
Definition: variant_char.c:486
static int variant_char_copy(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:323
static int variant_char_to_float(amxc_var_t *const dest, const amxc_var_t *const src)
Definition: variant_char.c:168