1 /* init.c: bcmath library file. */
2 /*
3 Copyright (C) 1991, 1992, 1993, 1994, 1997 Free Software Foundation, Inc.
4 Copyright (C) 2000 Philip A. Nelson
5
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2 of the License, or (at your option) any later version.
10
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details. (COPYING.LIB)
15
16 You should have received a copy of the GNU Lesser General Public
17 License along with this library; if not, write to:
18
19 The Free Software Foundation, Inc.
20 59 Temple Place, Suite 330
21 Boston, MA 02111-1307 USA.
22
23 You may contact the author by:
24 e-mail: philnelson@acm.org
25 us-mail: Philip A. Nelson
26 Computer Science Department, 9062
27 Western Washington University
28 Bellingham, WA 98226-9062
29
30 *************************************************************************/
31
32 #include <config.h>
33 #include <stdio.h>
34 #include <assert.h>
35 #include <stdlib.h>
36 #include <ctype.h>
37 #include <stdarg.h>
38 #include "bcmath.h"
39 #include "private.h"
40
41 /* new_num allocates a number and sets fields to known values. */
42
43 bc_num
_bc_new_num_ex(length,scale,persistent)44 _bc_new_num_ex (length, scale, persistent)
45 int length, scale, persistent;
46 {
47 bc_num temp;
48 /* PHP Change: add length check */
49 if ((size_t)length+(size_t)scale > INT_MAX) {
50 zend_error(E_ERROR, "Result too long, max is %d", INT_MAX);
51 }
52 /* PHP Change: malloc() -> pemalloc(), removed free_list code */
53 temp = (bc_num) safe_pemalloc (1, sizeof(bc_struct)+length, scale, persistent);
54 #if 0
55 if (_bc_Free_list != NULL) {
56 temp = _bc_Free_list;
57 _bc_Free_list = temp->n_next;
58 } else {
59 temp = (bc_num) pemalloc (sizeof(bc_struct), persistent);
60 }
61 #endif
62 temp->n_sign = PLUS;
63 temp->n_len = length;
64 temp->n_scale = scale;
65 temp->n_refs = 1;
66 /* PHP Change: malloc() -> pemalloc() */
67 temp->n_ptr = (char *) safe_pemalloc (1, length, scale, persistent);
68 temp->n_value = temp->n_ptr;
69 memset (temp->n_ptr, 0, length+scale);
70 return temp;
71 }
72
73
74 /* "Frees" a bc_num NUM. Actually decreases reference count and only
75 frees the storage if reference count is zero. */
76
77 void
_bc_free_num_ex(num,persistent)78 _bc_free_num_ex (num, persistent)
79 bc_num *num;
80 int persistent;
81 {
82 if (*num == NULL) return;
83 (*num)->n_refs--;
84 if ((*num)->n_refs == 0) {
85 if ((*num)->n_ptr)
86 /* PHP Change: free() -> pefree(), removed free_list code */
87 pefree ((*num)->n_ptr, persistent);
88 pefree(*num, persistent);
89 #if 0
90 (*num)->n_next = _bc_Free_list;
91 _bc_Free_list = *num;
92 #endif
93 }
94 *num = NULL;
95 }
96
97
98 /* Intitialize the number package! */
99
100 void
bc_init_numbers(void)101 bc_init_numbers (void)
102 {
103 BCG(_zero_) = _bc_new_num_ex (1,0,1);
104 BCG(_one_) = _bc_new_num_ex (1,0,1);
105 BCG(_one_)->n_value[0] = 1;
106 BCG(_two_) = _bc_new_num_ex (1,0,1);
107 BCG(_two_)->n_value[0] = 2;
108 }
109
110
111 /* Make a copy of a number! Just increments the reference count! */
112
113 bc_num
bc_copy_num(bc_num num)114 bc_copy_num (bc_num num)
115 {
116 num->n_refs++;
117 return num;
118 }
119
120
121 /* Initialize a number NUM by making it a copy of zero. */
122
123 void
bc_init_num(bc_num * num)124 bc_init_num (bc_num *num)
125 {
126 *num = bc_copy_num (BCG(_zero_));
127 }
128