Add methods for converting between Collections (asBag, asSet, etc)
[panda.git] / src / st-large-integer.c
blobd8de6ad66fb399cbe03827e010af015195f03042
1 /*
2 * st-large-integer.c
4 * Copyright (C) 2008 Vincent Geddes
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to deal
8 * in the Software without restriction, including without limitation the rights
9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 * copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22 * THE SOFTWARE.
25 #include "st-large-integer.h"
26 #include "st-universe.h"
27 #include "st-types.h"
28 #include "math.h"
30 #define VALUE(oop) (&(ST_LARGE_INTEGER(oop)->value))
32 st_oop
33 st_large_integer_new_from_string (const char *string, st_uint radix)
35 mp_int value;
36 int result;
38 st_assert (string != NULL);
40 result = mp_init (&value);
41 if (result != MP_OKAY)
42 goto out;
44 result = mp_read_radix (&value, string, radix);
45 if (result != MP_OKAY)
46 goto out;
48 return st_large_integer_new (&value);
50 out:
51 mp_clear (&value);
52 fprintf (stderr, mp_error_to_string (result));
53 return ST_NIL;
56 char *
57 st_large_integer_to_string (st_oop integer, st_uint radix)
59 int result;
60 int size;
62 result = mp_radix_size (VALUE (integer), radix, &size);
63 if (result != MP_OKAY)
64 goto out;
66 char *str = st_malloc (size);
68 mp_toradix (VALUE (integer), str, radix);
69 if (result != MP_OKAY)
70 goto out;
72 return str;
74 out:
75 fprintf (stderr, mp_error_to_string (result));
76 return NULL;
79 st_oop
80 st_large_integer_allocate (st_oop class, mp_int *value)
82 st_oop object;
83 st_uint size;
85 size = ST_SIZE_OOPS (struct st_large_integer);
86 object = st_memory_allocate (size);
87 if (object == 0) {
88 st_memory_perform_gc ();
89 class = st_memory_remap_reference (class);
90 object = st_memory_allocate (size);
91 st_assert (object != 0);
94 st_object_initialize_header (object, class);
96 if (value)
97 *VALUE (object) = *value;
99 return object;
102 st_oop
103 st_large_integer_new (mp_int * value)
105 return st_large_integer_allocate (ST_LARGE_INTEGER_CLASS, value);