| version 1.19, 2003/05/29 15:50:49 | version 1.33, 2005/10/12 04:03:37 | 
|  |  | 
| /* -*- mode: C -*- */ | /* -*- mode: C -*- */ | 
| /* $OpenXM: OpenXM/src/ox_toolkit/ox_toolkit.h,v 1.18 2003/05/28 08:43:59 ohara Exp $ */ | /* $OpenXM: OpenXM/src/ox_toolkit/ox_toolkit.h,v 1.32 2005/07/26 12:52:05 ohara Exp $ */ | 
|  |  | 
| #ifndef _OX_TOOLKIT_H_ | #ifndef _OX_TOOLKIT_H_ | 
|  |  | 
|  |  | 
| #endif | #endif | 
|  |  | 
| #include <stdio.h> | #include <stdio.h> | 
| #if defined(WITH_GMP) |  | 
| #include <gmp.h> | #include <gmp.h> | 
| #else |  | 
| #include "gmp_fake.h" |  | 
| #endif /* WITH_GMP */ |  | 
| #include <ox/cmotag.h> | #include <ox/cmotag.h> | 
| #include <ox/oxMessageTag.h> | #include <ox/oxMessageTag.h> | 
| #include <ox/smCommand.h> | #include <ox/smCommand.h> | 
|  | #include <gc/gc.h> | 
|  |  | 
|  | #define MALLOC(x) GC_MALLOC((x)) | 
|  | #define MALLOC_ATOMIC(x) GC_MALLOC_ATOMIC((x)) | 
|  | #define ALLOCA(x) alloca((x)) | 
|  | /* #define FREE(x)   free((x)) */ | 
|  | #define FREE(x) | 
|  |  | 
| #if !defined(__GNUC__) && !defined(__inline__) | #if !defined(__GNUC__) && !defined(__inline__) | 
| #define __inline__ | #define __inline__ | 
| #endif | #endif | 
| 
| Line 47  typedef struct OXFILE{ |  | 
| Line 50  typedef struct OXFILE{ |  | 
| char *wbuf; | char *wbuf; | 
| int wbuf_size; | int wbuf_size; | 
| int wbuf_count; | int wbuf_count; | 
|  | int (*send_double)(struct OXFILE *oxfp, double int64); | 
|  | double (*receive_double)(struct OXFILE *oxfp); | 
| } OXFILE; | } OXFILE; | 
|  |  | 
| typedef struct cmo { | typedef struct cmo { | 
| 
| Line 87  typedef struct cell { |  | 
| Line 92  typedef struct cell { |  | 
| struct cmo *cmo; | struct cmo *cmo; | 
| struct cell *next; | struct cell *next; | 
| struct cell *prev; | struct cell *prev; | 
|  | int exp; | 
| } cell; | } cell; | 
|  |  | 
| typedef struct { | typedef struct { | 
| 
| Line 127  typedef struct { |  | 
| Line 133  typedef struct { |  | 
| cmo *ringdef; | cmo *ringdef; | 
| } cmo_distributed_polynomial; | } cmo_distributed_polynomial; | 
|  |  | 
|  | /* The following is a derived class from cmo_list. | 
|  | that is, list_append can be used. */ | 
|  | typedef struct { | 
|  | int tag; | 
|  | int length;   /* number of monomials */ | 
|  | cell head[1]; /* list of monomials */ | 
|  | int var;      /* name of the main variable */ | 
|  | } cmo_polynomial_in_one_variable; | 
|  |  | 
|  | typedef struct { | 
|  | int tag; | 
|  | cmo_list *ringdef; /* list of variables */ | 
|  | cmo *coef;  /* ZZ, QQ, int32, Poly_in_1var, Tree, Zero, DPoly */ | 
|  | } cmo_recursive_polynomial; | 
|  |  | 
|  | typedef struct { | 
|  | int tag; | 
|  | cmo_string *name; | 
|  | cmo_list *attributes; | 
|  | cmo_list *leaves; | 
|  | } cmo_tree; | 
|  |  | 
|  | typedef struct { | 
|  | int tag; | 
|  | cmo_list *args; | 
|  | cmo_tree *body; | 
|  | } cmo_lambda; | 
|  |  | 
| typedef cmo ox; | typedef cmo ox; | 
|  |  | 
| typedef ox ox_sync_ball; | typedef ox ox_sync_ball; | 
| 
| Line 146  cmo_int32*         new_cmo_int32(int i); |  | 
| Line 180  cmo_int32*         new_cmo_int32(int i); |  | 
| cmo_string*        new_cmo_string(char* s); | cmo_string*        new_cmo_string(char* s); | 
| cmo_mathcap*       new_cmo_mathcap(cmo* ob); | cmo_mathcap*       new_cmo_mathcap(cmo* ob); | 
| cmo_list*          new_cmo_list(); | cmo_list*          new_cmo_list(); | 
|  | cmo_list*          new_cmo_list_array(void *a[], int n); | 
|  | cmo_list*          new_cmo_list_array_map(void *a[], int n, void *(* mapf)(void *)); | 
| cmo_monomial32*    new_cmo_monomial32(); | cmo_monomial32*    new_cmo_monomial32(); | 
| cmo_monomial32*    new_cmo_monomial32_size(int size); | cmo_monomial32*    new_cmo_monomial32_size(int size); | 
| cmo_zz*            new_cmo_zz(); | cmo_zz*            new_cmo_zz(); | 
| 
| Line 154  cmo_zz*            new_cmo_zz_set_si(int integer); |  | 
| Line 190  cmo_zz*            new_cmo_zz_set_si(int integer); |  | 
| cmo_zz*            new_cmo_zz_set_mpz(mpz_ptr z); | cmo_zz*            new_cmo_zz_set_mpz(mpz_ptr z); | 
| cmo_zz*            new_cmo_zz_noinit(); | cmo_zz*            new_cmo_zz_noinit(); | 
| cmo_zz*            new_cmo_zz_set_string(char* s); | cmo_zz*            new_cmo_zz_set_string(char* s); | 
|  | cmo_qq*            new_cmo_qq_noinit(); | 
|  | cmo_qq*            new_cmo_qq_set_mpq(mpq_ptr q); | 
|  | cmo_qq*            new_cmo_qq_set_mpz(mpz_ptr num, mpz_ptr den); | 
| cmo_zero*          new_cmo_zero(); | cmo_zero*          new_cmo_zero(); | 
| cmo_double*        new_cmo_double(double d); | cmo_double*        new_cmo_double(double d); | 
| cmo_distributed_polynomial* new_cmo_distributed_polynomial(); | cmo_distributed_polynomial* new_cmo_distributed_polynomial(); | 
| cmo_dms_generic*   new_cmo_dms_generic(); | cmo_dms_generic*   new_cmo_dms_generic(); | 
| cmo_ring_by_name*  new_cmo_ring_by_name(cmo* ob); | cmo_ring_by_name*  new_cmo_ring_by_name(cmo* ob); | 
| cmo_indeterminate* new_cmo_indeterminate(cmo* ob); | cmo_indeterminate* new_cmo_indeterminate(cmo* ob); | 
|  | cmo_polynomial_in_one_variable* new_cmo_polynomial_in_one_variable(int var); | 
|  | cmo_recursive_polynomial* new_cmo_recursive_polynomial(cmo_list* ringdef, cmo* coef); | 
|  | cmo_tree*          new_cmo_tree(cmo_string* name, cmo_list *attributes, cmo_list *leaves); | 
|  | cmo_lambda*        new_cmo_lambda(cmo_list* args, cmo_tree* body); | 
| cmo_error2*        new_cmo_error2(cmo* ob); | cmo_error2*        new_cmo_error2(cmo* ob); | 
|  |  | 
| ox_data*           new_ox_data(cmo* c); | ox_data*           new_ox_data(cmo* c); | 
| 
| Line 170  char*              new_string_set_cmo(cmo* m); |  | 
| Line 213  char*              new_string_set_cmo(cmo* m); |  | 
|  |  | 
| cmo_error2*        make_error_object(int err_code, cmo* ob); | cmo_error2*        make_error_object(int err_code, cmo* ob); | 
|  |  | 
|  | cmo*               ox_parse_lisp(char *s); | 
|  |  | 
| /* Low level API */ | /* Low level API */ | 
| cmo*               receive_cmo(OXFILE *fp); | cmo*               receive_cmo(OXFILE *fp); | 
| cmo*               receive_cmo_tag(OXFILE *fp, int tag); | cmo*               receive_cmo_tag(OXFILE *fp, int tag); | 
| 
| Line 204  cell*              list_first(cmo_list *); |  | 
| Line 249  cell*              list_first(cmo_list *); |  | 
| int                list_endof(cmo_list *, cell *el); | int                list_endof(cmo_list *, cell *el); | 
| cell*              list_next(cell *el); | cell*              list_next(cell *el); | 
| cmo_list*          list_append(cmo_list*, cmo *ob); | cmo_list*          list_append(cmo_list*, cmo *ob); | 
|  | cmo_list*          list_append_monomial(cmo_list* , cmo* coef, int exp); | 
| cmo_list*          list_appendl(cmo_list*, ...); | cmo_list*          list_appendl(cmo_list*, ...); | 
| int                list_length(cmo_list* ); | int                list_length(cmo_list* ); | 
| cmo*               list_nth(cmo_list* , int n); | cmo*               list_nth(cmo_list* , int n); | 
| 
| Line 228  int add_hook_after_send_cmo(hook_t func); |  | 
| Line 274  int add_hook_after_send_cmo(hook_t func); |  | 
|  |  | 
| typedef struct symbol *symbol_t; | typedef struct symbol *symbol_t; | 
|  |  | 
| void setflag_parse(int flag); |  | 
| cmo *parse(); |  | 
| void init_parser(char *s); |  | 
|  |  | 
| symbol_t lookup_by_symbol(char *key); | symbol_t lookup_by_symbol(char *key); | 
| symbol_t lookup_by_token(int tok); | symbol_t lookup_by_token(int tok); | 
| symbol_t lookup_by_tag(int tag); | symbol_t lookup_by_tag(int tag); | 
| 
| Line 249  int oxf_read(void *buffer, size_t size, size_t num, OX |  | 
| Line 291  int oxf_read(void *buffer, size_t size, size_t num, OX |  | 
| int oxf_write(void *buffer, size_t size, size_t num, OXFILE *oxfp); | int oxf_write(void *buffer, size_t size, size_t num, OXFILE *oxfp); | 
|  |  | 
| /* for OXFILE */ | /* for OXFILE */ | 
| int oxf_listen(short *portp); | int oxf_listen(int *portp); | 
| OXFILE *oxf_connect_active(char *hostname, short port); | OXFILE *oxf_connect_active(char *hostname, short port); | 
| OXFILE *oxf_connect_passive(int listened); | OXFILE *oxf_connect_passive(int listened); | 
| OXFILE *oxf_open(int fd); | OXFILE *oxf_open(int fd); |