pike.git / src / bignum.c

version» Context lines:

pike.git/src/bignum.c:5:   */      #include "global.h"      #include "interpret.h"   #include "program.h"   #include "object.h"   #include "svalue.h"   #include "pike_error.h"    + #include "bignum.h" +    #define sp Pike_sp      PMOD_EXPORT struct svalue auto_bignum_program = SVALUE_INIT_FREE;      PMOD_EXPORT struct program *get_auto_bignum_program(void)   {    return program_from_function(&auto_bignum_program);   }      PMOD_EXPORT struct program *get_auto_bignum_program_or_zero(void)
pike.git/src/bignum.c:118: Inside #if defined(INT64)
     PMOD_EXPORT void (*push_int64) (INT64) = bootstrap_push_int64;   PMOD_EXPORT int (*int64_from_bignum) (INT64 *, struct object *) = NULL;   PMOD_EXPORT void (*reduce_stack_top_bignum) (void) = NULL;   #endif      PMOD_EXPORT void (*push_ulongest) (unsigned LONGEST) = NULL;   PMOD_EXPORT int (*ulongest_from_bignum) (unsigned LONGEST *,    struct object *) = NULL;    + PMOD_EXPORT MP_INT *(*mpz_from_bignum)(struct object *, int) = NULL; + PMOD_EXPORT void (*push_bignum)(MP_INT *) = NULL; +    PMOD_EXPORT void hook_in_gmp_funcs (   #ifdef INT64    void (*push_int64_val)(INT64),    int (*int64_from_bignum_val) (INT64 *, struct object *),    void (*reduce_stack_top_bignum_val) (void),   #endif    void (*push_ulongest_val) (unsigned LONGEST), -  int (*ulongest_from_bignum_val) (unsigned LONGEST *, struct object *)) +  int (*ulongest_from_bignum_val) (unsigned LONGEST *, struct object *), +  MP_INT *(*mpz_from_bignum_val)(struct object *, int), +  void (*push_bignum_val)(MP_INT *))   {    /* Assigning the pointers above directly from the Gmp module doesn't    * work in some cases, e.g. NT. */   #ifdef INT64    push_int64 = push_int64_val ? push_int64_val : bootstrap_push_int64;    int64_from_bignum = int64_from_bignum_val;    reduce_stack_top_bignum = reduce_stack_top_bignum_val;   #endif    push_ulongest = push_ulongest_val;    ulongest_from_bignum = ulongest_from_bignum_val; -  +  mpz_from_bignum = mpz_from_bignum_val; +  push_bignum = push_bignum_val;   }