Messing around with C.

This commit is contained in:
Simon Forman 2023-02-01 14:23:54 -08:00
parent 109cddae12
commit 28fa767593
2 changed files with 40 additions and 35 deletions

Binary file not shown.

View File

@ -3,27 +3,27 @@
enum JoyTypeType { enum JoyTypeType {
joySymbol, joySymbol,
joyTrue, joyTrue,
joyFalse, joyFalse,
joyInt, joyInt,
joyList joyList
}; };
typedef struct list_node* JoyList; typedef struct list_node* JoyList;
typedef struct JoyType { typedef struct JoyType {
enum JoyTypeType kind; enum JoyTypeType kind;
union { union {
int b; // bool int b; // bool
mpz_t i; mpz_t i;
JoyList el; JoyList el;
}; };
} name ; } name ;
typedef struct list_node { typedef struct list_node {
struct JoyType head; struct JoyType head;
struct list_node* tail; struct list_node* tail;
} *JoyList; } *JoyList;
@ -54,16 +54,17 @@ typedef struct list_node {
/*};*/ /*};*/
void* reallocate_function (void *ptr, size_t old_size, size_t new_size) { void* reallocate_function (void *ptr, size_t old_size, size_t new_size) {
return GC_realloc(ptr, new_size); return GC_REALLOC(ptr, new_size);
} }
void deallocate_function (void *ptr, size_t size) { void deallocate_function (void *ptr, size_t size) {
GC_free(ptr); GC_FREE(ptr);
} }
void my_callback(GC_PTR void_obj, GC_PTR void_environment) { void my_callback(GC_PTR void_obj, GC_PTR void_environment) {
//MY_ENVIRONMENT *env = (MY_ENVIRONMENT)void_environment; //MY_ENVIRONMENT *env = (MY_ENVIRONMENT)void_environment;
mpz_t *obj = (mpz_t*)void_obj; mpz_t *obj = (mpz_t*)void_obj;
mpz_clear(*obj); mpz_clear(*obj);
} }
/*sexpr new_int(void) {*/ /*sexpr new_int(void) {*/
@ -74,24 +75,28 @@ void my_callback(GC_PTR void_obj, GC_PTR void_environment) {
/*}*/ /*}*/
int main(void) int
main(void)
{ {
mp_set_memory_functions( mp_set_memory_functions(
&GC_malloc, &GC_malloc,
&reallocate_function, &reallocate_function,
&deallocate_function &deallocate_function
); );
mpz_t pi; mpz_t pi;
//mpz_init_set_str (pi, "3141592653589793238462643383279502884", 10); mpz_init_set_str(pi, "3141592653589793238462643383279502884", 10);
mpz_init_set_str (pi, "25d0c79fe247f31777d922627a74624", 16); //mpz_init_set_str(pi, "25d0c79fe247f31777d922627a74624", 16);
gmp_printf ("%Zd = %Zx\n", pi, pi); GC_register_finalizer(pi, my_callback, NULL, NULL, NULL);
GC_register_finalizer(pi, my_callback, NULL, NULL, NULL);
/*sexpr i = new_int();*/ gmp_printf("%Zd = %Zx\n", pi, pi);
/*mpz_add(i.i, pi, pi);*/ mpz_mul(pi, pi, pi);
/*gmp_printf ("%Zd\n", i.i);*/ gmp_printf("%Zd = %Zx\n", pi, pi);
return 0;
//return to_i(car(cons(from_i(0),from_i(1))));
/*sexpr i = new_int();*/
/*mpz_add(i.i, pi, pi);*/
/*gmp_printf ("%Zd\n", i.i);*/
return 0;
//return to_i(car(cons(from_i(0),from_i(1))));
} }