1
  
2
  
3
  
4
  
5
  
6
  
7
  
8
  
9
  
10
  
11
  
12
  
13
  
14
  
15
  
16
  
17
  
18
  
19
  
20
  
21
  
22
  
23
  
24
  
25
  
26
  
27
  
28
  
29
  
30
  
31
  
32
  
33
  
34
  
35
  
36
  
37
  
38
  
39
  
40
  
41
  
42
  
43
  
44
  
45
  
46
  
47
  
48
  
49
  
50
  
51
  
52
  
53
  
54
  
55
  
56
  
57
  
58
  
59
  
60
  
61
  
62
  
63
  
64
  
65
  
66
  
67
  
68
  
69
  
70
  
71
  
72
  
73
  
74
  
75
  
76
  
77
  
78
  
79
  
80
  
81
  
82
  
83
  
84
  
85
  
86
  
87
  
88
  
89
  
90
  
91
  
92
  
93
  
94
  
95
  
96
  
97
  
98
  
#include "global.h" 
 
#ifdef AUTO_BIGNUM 
 
#include "interpret.h" 
#include "program.h" 
#include "object.h" 
#include "svalue.h" 
#include "error.h" 
 
struct svalue auto_bignum_program = { T_INT }; 
 
static void resolve_auto_bignum_program(void) 
{ 
  if(auto_bignum_program.type == T_INT) 
  { 
    push_text("Gmp.mpz"); 
    SAFE_APPLY_MASTER("resolv", 1); 
     
    if(sp[-1].type != T_FUNCTION) 
      error("Failed to resolv Gmp.mpz!\n"); 
     
    auto_bignum_program=sp[-1]; 
    sp--; 
  } 
} 
 
void exit_auto_bignum(void) 
{ 
  free_svalue(&auto_bignum_program); 
  auto_bignum_program.type=T_INT; 
} 
 
void convert_stack_top_to_bignum(void) 
{ 
  resolve_auto_bignum_program(); 
  apply_svalue(&auto_bignum_program, 1); 
 
  if(sp[-1].type != T_OBJECT) 
    error("Gmp.mpz conversion failed.\n"); 
} 
 
void convert_stack_top_with_base_to_bignum(void) 
{ 
  resolve_auto_bignum_program(); 
  apply_svalue(&auto_bignum_program, 2); 
 
  if(sp[-1].type != T_OBJECT) 
    error("Gmp.mpz conversion failed.\n"); 
} 
 
int is_bignum_object(struct object *o) 
{ 
  resolve_auto_bignum_program(); 
  return o->prog == program_from_function(&auto_bignum_program); 
} 
 
int is_bignum_object_in_svalue(struct svalue *sv) 
{ 
  return sv->type == T_OBJECT && is_bignum_object(sv->u.object); 
} 
 
struct object *make_bignum_object(void) 
{ 
  convert_stack_top_to_bignum(); 
  return (--sp)->u.object; 
} 
 
struct object *bignum_from_svalue(struct svalue *s) 
{ 
  push_svalue(s); 
  convert_stack_top_to_bignum(); 
  return (--sp)->u.object; 
} 
 
struct pike_string *string_from_bignum(struct object *o, int base) 
{ 
  push_int(base); 
  safe_apply(o, "digits", 1); 
   
  if(sp[-1].type != T_STRING) 
    error("Gmp.mpz string conversion failed.\n"); 
   
  return (--sp)->u.string; 
} 
 
void convert_svalue_to_bignum(struct svalue *s) 
{ 
  push_svalue(s); 
  convert_stack_top_to_bignum(); 
  free_svalue(s); 
  *s=sp[-1]; 
  sp--; 
} 
 
#endif /* AUTO_BIGNUM */