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
25 #include "st-large-integer.h"
26 #include "st-universe.h"
30 #define VALUE(oop) (&(ST_LARGE_INTEGER(oop)->value))
33 st_large_integer_new_from_string (const char *string
, st_uint radix
)
38 st_assert (string
!= NULL
);
40 result
= mp_init (&value
);
41 if (result
!= MP_OKAY
)
44 result
= mp_read_radix (&value
, string
, radix
);
45 if (result
!= MP_OKAY
)
48 return st_large_integer_new (&value
);
52 fprintf (stderr
, mp_error_to_string (result
));
57 st_large_integer_to_string (st_oop integer
, st_uint radix
)
62 result
= mp_radix_size (VALUE (integer
), radix
, &size
);
63 if (result
!= MP_OKAY
)
66 char *str
= st_malloc (size
);
68 mp_toradix (VALUE (integer
), str
, radix
);
69 if (result
!= MP_OKAY
)
75 fprintf (stderr
, mp_error_to_string (result
));
80 st_large_integer_allocate (st_oop
class, mp_int
*value
)
85 size
= ST_SIZE_OOPS (struct st_large_integer
);
86 object
= st_memory_allocate (size
);
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);
97 *VALUE (object
) = *value
;
103 st_large_integer_new (mp_int
* value
)
105 return st_large_integer_allocate (ST_LARGE_INTEGER_CLASS
, value
);