1 2007-12-17 Richard B. Kreckel <kreckel@ginac.de>
3 Silly workaround for silly bug in gmp.h:
4 * m4/gmp.m4 (CL_GMP_SET_UINTD): Swap #include <gmp.h> and <stdio.h>.
6 2007-12-17 Richard B. Kreckel <kreckel@ginac.de>
8 * src/polynomial/elem/cl_UP_GF2.h (gf2_mul_table): define for sparc64.
10 2007-12-04 Richard B. Kreckel <kreckel@ginac.de>
12 * include/cln/types.h ([su]intE): 64-bit exponents for MIPS and RS6000.
14 2007-12-03 Richard B. Kreckel <kreckel@ginac.de>
16 * src/float/lfloat/cl_LF.h (cl_heap_lfloat): Change len type to uintC.
18 2007-11-28 Richard B. Kreckel <kreckel@ginac.de>
20 * include/cln/object.h: Don't redefine cl_word_alignment on sparc64.
21 * src/base/digitseq/cl_asm_sparc64_.cc: Declare use of global
22 register %g2 as scratch register within this file.
23 Reported by Paul Irofti <bulibuta@gmail.com> and Sven Verdoolaege
26 2007-11-03 Richard B. Kreckel <kreckel@ginac.de>
28 * src/base/digitseq/cl_asm_i386_.cc (compare_loop_up,
29 compare_loop_down): Fix empty ranges.
31 2007-10-12 Richard B. Kreckel <kreckel@ginac.de>
33 Fix compilation on CYGWIN:
34 * src/float/transcendental/cl_LF_zeta_int.cc: Avoid leading underscores
36 * src/float/transcendental/cl_LF_eulerconst.cc: Likewise.
37 Reported by Chris Bouchard <cbouchrd@uiuc.edu>.
39 2007-10-10 Richard B. Kreckel <kreckel@ginac.de>
41 * src/base/cl_low.h: Add missing linefeeds in SPARC 64 inline assembler.
42 * src/base/low/cl_low_div.cc (divu_6464_6464_): Fix a copy-paste typo.
43 Reported by Sven Verdoolaege <skimo@kotnet.org>.
45 2007-10-02 Richard B. Kreckel <kreckel@ginac.de>
47 On popular demand (Debian bug #286266, Ubuntu bug #128851):
48 * examples/pi.cc: Output no more than requested number of digits.
50 2007-10-01 Richard B. Kreckel <kreckel@ginac.de>
52 * autoconf/config.guess, autoconf/config.sub: updated from automake-1.9.
54 2007-09-19 Richard B. Kreckel <kreckel@ginac.de>
56 * doc/cln.tex: Put entire document in @dircategory Mathematics.
57 * doc/Makefile.in: texi2html -split_chapter suddenly uses subdirectory.
58 * Makefile.in: Don't install non-existing cln-config* and cln.m4.
60 2007-09-18 Richard B. Kreckel <kreckel@ginac.de>
62 * include/cln/modules.h (CL_JUMP_TO): Use a pc relative jump on m68k.
63 See <http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=388000>.
65 2007-09-16 Richard B. Kreckel <kreckel@ginac.de>
67 * */*: Convert encoding from ISO 8859-1 to UTF-8.
69 2007-09-13 Richard B. Kreckel <kreckel@ginac.de>
71 Truncated binary splitting for even more memory efficiency:
72 * src/float/transcendental/cl_LF_tran.h: Added new overloads. See below.
73 * src/float/transcendental/cl_LF_ratseries_stream_pq.cc: Removed and
74 moved everything to...
75 * src/float/transcendental/cl_LF_ratseries_pq.cc: ...here. Added an
76 overload for truncated expansion.
77 * src/float/transcendental/cl_LF_ratseries_stream_pqa.cc: Removed and
78 moved everything to...
79 * src/float/transcendental/cl_LF_ratseries_pqa.cc: ...here. Added an
80 overload for truncated expansion.
81 * src/float/transcendental/cl_LF_ratseries_stream_pqb.cc: Removed and
82 moved everything to...
83 * src/float/transcendental/cl_LF_ratseries_pqb.cc: ...here. Added an
84 overload for truncated expansion.
85 * src/float/transcendental/cl_LF_ratseries_stream_pqab.cc: Removed and
86 moved everything to...
87 * src/float/transcendental/cl_LF_ratseries_pqab.cc: ...here. Added an
88 overload for truncated expansion.
89 * src/float/transcendental/cl_LF_ratsumseries_pqcd_aux.cc: Added
90 overloads for streamed and truncated expansion.
91 * src/float/transcendental/cl_LF_ratsumseries_pqcd.cc: Likewise.
92 * src/float/transcendental/cl_LF_ratsumseries_stream_pqd_aux.cc: Removed
93 and moved everything to...
94 * src/float/transcendental/cl_LF_ratsumseries_pqd_aux.cc: ...here. Added
95 an overload for truncated expansion.
96 * src/float/transcendental/cl_LF_ratsumseries_stream_pqd.cc: Removed
97 and moved everything to...
98 * src/float/transcendental/cl_LF_ratsumseries_pqd.cc: ...here. Added an
99 overload for truncated expansion.
100 * src/float/transcendental/cl_LF_pi.cc: Use truncated series.
101 * src/float/transcendental/cl_LF_catalanconst.cc: Likewise.
102 * src/float/transcendental/cl_LF_eulerconst.cc: Likewise.
103 * src/float/transcendental/cl_LF_zeta_int.cc: Likewise.
104 * src/float/transcendental/cl_LF_zeta3.cc: Likewise.
106 2007-09-07 Richard B. Kreckel <kreckel@ginac.de>
108 More memory efficient Euler-Mascheroni constant:
109 * src/float/transcendental/cl_LF_tran.h (cl_pqd_series_stream): New.
110 * src/float/transcendental/cl_LF_ratsumseries_stream_pqd.cc: New file.
111 * src/float/transcendental/cl_LF_ratsumseries_stream_pqd_aux.cc: New
113 * src/float/transcendental/cl_LF_eulerconst.cc: Compute series
114 coefficients on demand, using a series stream object.
116 2007-08-02 Richard B. Kreckel <kreckel@ginac.de>
118 * src/base/digitseq/cl_DS_div.cc (cl_recip_suitable): uintC arguments.
120 2007-08-01 Richard B. Kreckel <kreckel@ginac.de>
122 * */*: Remove cl_boolean, cl_true, and cl_false in favor of built-in
123 C++ bool, true, and false.
125 2007-07-28 Richard B. Kreckel <kreckel@ginac.de>
127 Remove exception hooks in favor of real C++ exceptions:
128 * include/cln/exception.h: New file...
129 * include/cln/cln.h: ...included here...
130 * include/cln/rational.h: ...and here.
131 * include/cln/abort.h: Removed.
132 * include/cln/integer.h (ash_exception, exquo_exception): Add exception
134 * include/cln/float.h (floating_point_exception,
135 floating_point_nan_exception, floating_point_overflow_exception,
136 floating_point_underflow_exception): Likewise.
137 * include/cln/number_io.h (read_number_exception,
138 read_number_bad_syntax_exception, read_number_junk_exception,
139 read_number_eof_exception): Likewise.
140 * include/cln/object.h (CL_DEFINE_CONVERTER): Replace dynamic assertion
141 with a compile-time assertion.
142 * include/cln/GV.h: Replace nonreturning functions with exceptions.
143 * include/cln/modinteger.h: Likewise.
144 * include/cln/SV.h: Likewise.
145 * include/cln/ring.h: Likewise.
146 * include/cln/string.h: Likewise.
147 * include/cln/univpoly.h: Likewise.
148 * src/base/cl_abort.cc: Removed.
149 * src/base/cl_N_err_d0.cc: Removed.
150 * src/base/cl_d0_exception.cc: New file.
151 * src/base/cl_as_err.cc: Removed.
152 * src/base/cl_as_exception.cc: New file.
153 * src/base/cl_notreached.cc: Removed.
154 * src/base/cl_notreached_exception.cc: New file.
155 * src/base/input/cl_read_err_bad.cc: Removed.
156 * src/base/input/cl_read_bad_syntax_exception.cc: New file.
157 * src/base/input/cl_read_err_junk.cc: Removed.
158 * src/base/input/cl_read_junk_exception.cc: New file.
159 * src/base/input/cl_read_err_eof.cc: Removed.
160 * src/base/input/cl_read_eof_exception.cc: New file.
161 * src/base/cl_N.h (cl_as_error): Removed (see cln/exception.h).
162 * src/base/macros.h (NOTREACHED): Throw.
163 * src/base/cl_malloc.cc (xmalloc): Throw.
164 * src/base/digitseq/cl_2DS_div.cc: Throw.
165 * src/base/digitseq/cl_DS_div.cc: Throw.
166 * src/base/digitseq/cl_DS_mul.cc: Throw.
167 * src/base/digitseq/cl_DS_mul_fftc.h: Throw.
168 * src/base/digitseq/cl_DS_mul_fftcs.h: Throw.
169 * src/base/digitseq/cl_DS_mul_fftm.h: Throw.
170 * src/base/digitseq/cl_DS_mul_fftp.h: Throw.
171 * src/base/digitseq/cl_DS_mul_fftp3.h: Throw.
172 * src/base/digitseq/cl_DS_mul_fftp3m.h: Throw.
173 * src/base/digitseq/cl_DS_mul_fftr.h: Throw.
174 * src/base/digitseq/cl_DS_mul_nuss.h: Throw.
175 * src/base/digitseq/cl_DS_recipsqrt.cc: Throw.
176 * src/base/digitseq/cl_DS_sqrt.cc: Throw.
177 * src/base/hash/cl_hash.h: Throw.
178 * src/base/hash/cl_hash1.h: Throw.
179 * src/base/hash/cl_hash1weak.h: Throw.
180 * src/base/hash/cl_hash2.h: Throw.
181 * src/base/hash/cl_hash2weak.h: Throw.
182 * src/base/hash/cl_hashset.h: Throw.
183 * src/base/hash/cl_hashuniq.h: Throw.
184 * src/base/hash/cl_hashuniqweak.h: Throw.
185 * src/base/proplist/cl_pl_add.cc: Throw.
186 * src/base/ring/cl_no_ring.cc: Throw.
187 * src/base/string/cl_spushstring.h: Throw.
188 * src/base/symbol/cl_symbol.cc: Throw.
189 * src/integer/bitwise/cl_I_ash.h: Removed (see cln/integer.h.)
190 * src/integer/bitwise/cl_I_asherr.cc: Removed.
191 * src/integer/bitwise/cl_I_ash_exception.cc: New file.
192 * src/integer/division/cl_I_exquoerr.cc: Removed.
193 * src/integer/division/cl_I_exquo_exception.cc: New file.
194 * src/integer/cl_I.h: Throw.
195 * src/integer/division/cl_I_exquopos.cc: Throw.
196 * src/integer/bitwise/cl_I_logbitp_I.cc: Throw.
197 * src/integer/bitwise/cl_I_ash.cc: Throw.
198 * src/integer/bitwise/cl_I_ash_I.cc: Throw.
199 * src/integer/division/cl_I_exquo.cc: Throw.
200 * src/integer/gcd/cl_I_gcd_aux2.cc: Throw.
201 * src/integer/conv/cl_I_to_L.cc: Throw.
202 * src/integer/conv/cl_I_to_Q.cc: Throw.
203 * src/integer/conv/cl_I_to_UL.cc: Throw.
204 * src/integer/conv/cl_I_to_UQ.cc: Throw.
205 * src/integer/conv/cl_I_to_digits.cc: Throw.
206 * src/integer/elem/cl_I_div.cc: Throw.
207 * src/integer/algebraic/cl_I_sqrt.cc: Throw.
208 * src/integer/input/cl_I_read.cc: Throw.
209 * src/integer/input/cl_I_read_stream.cc: Throw.
210 * src/integer/misc/cl_I_as.cc: Throw.
211 * src/rational/elem/cl_RA_from_I_I_div.cc: Throw.
212 * src/rational/elem/cl_RA_recip.cc: Throw.
213 * src/rational/input/cl_RA_read.cc: Throw.
214 * src/rational/input/cl_RA_read_stream.cc: Throw.
215 * src/rational/input/cl_RA_readparsed.cc: Throw.
216 * src/rational/misc/cl_RA_as.cc: Throw.
217 * src/float/base/cl_F_err_nan.cc: Removed.
218 * src/float/base/cl_F_nan_exception.cc: New file.
219 * src/float/base/cl_F_err_un.cc: Removed.
220 * src/float/base/cl_F_underflow_exception.cc: New file.
221 * src/float/base/cl_F_err_ov.cc: Removed.
222 * src/float/base/cl_F_overflow_exception.cc: New file.
223 * src/float/cl_F.h (cl_error_floating_point_nan,
224 cl_error_floating_point_overflow, cl_error_floating_point_underflow):
225 Removed (see cln/float.h.)
226 * src/float/sfloat/cl_SF.h: Throw.
227 * src/float/sfloat/elem/cl_SF_div.cc: Throw.
228 * src/float/sfloat/elem/cl_SF_from_RA.cc: Throw.
229 * src/float/sfloat/elem/cl_SF_scale.cc: Throw.
230 * src/float/sfloat/elem/cl_SF_scale_I.cc: Throw.
231 * src/float/sfloat/misc/cl_SF_as.cc: Throw.
232 * src/float/ffloat/cl_FF.h: Throw.
233 * src/float/ffloat/conv/cl_FF_from_float.cc: Throw.
234 * src/float/ffloat/elem/cl_FF_div.cc: Throw.
235 * src/float/ffloat/elem/cl_FF_from_RA.cc: Throw.
236 * src/float/ffloat/elem/cl_FF_scale.cc: Throw.
237 * src/float/ffloat/elem/cl_FF_scale_I.cc: Throw.
238 * src/float/ffloat/misc/cl_FF_as.cc: Throw.
239 * src/float/dfloat/cl_DF.h: Throw.
240 * src/float/dfloat/conv/cl_DF_from_double.cc: Throw.
241 * src/float/dfloat/elem/cl_DF_div.cc: Throw.
242 * src/float/dfloat/elem/cl_DF_from_RA.cc: Throw.
243 * src/float/dfloat/elem/cl_DF_scale.cc: Throw.
244 * src/float/dfloat/elem/cl_DF_scale_I.cc: Throw.
245 * src/float/dfloat/misc/cl_DF_as.cc: Throw.
246 * src/float/lfloat/algebraic/cl_LF_sqrt.cc: Throw.
247 * src/float/lfloat/elem/cl_LF_1plus.cc: Throw.
248 * src/float/lfloat/elem/cl_LF_I_div.cc: Throw.
249 * src/float/lfloat/elem/cl_LF_I_mul.cc: Throw.
250 * src/float/lfloat/elem/cl_LF_div.cc: Throw.
251 * src/float/lfloat/elem/cl_LF_from_I.cc: Throw.
252 * src/float/lfloat/elem/cl_LF_mul.cc: Throw.
253 * src/float/lfloat/elem/cl_LF_scale.cc: Throw.
254 * src/float/lfloat/elem/cl_LF_scale_I.cc: Throw.
255 * src/float/lfloat/elem/cl_LF_square.cc: Throw.
256 * src/float/lfloat/misc/cl_LF_as.cc: Throw.
257 * src/float/lfloat/misc/cl_LF_shorten.cc: Throw.
258 * src/float/lfloat/misc/cl_LF_shortenrel.cc: Throw.
259 * src/float/lfloat/misc/cl_LF_shortenwith.cc: Throw.
260 * src/float/input/cl_F_read.cc: Throw.
261 * src/float/input/cl_F_read_stream.cc: Throw.
262 * src/float/misc/cl_F_as.cc: Throw.
263 * src/float/misc/cl_F_shortenrel.cc: Throw.
264 * src/float/transcendental/cl_LF_coshsinh_aux.cc: Throw.
265 * src/float/transcendental/cl_LF_cossin_aux.cc: Throw.
266 * src/float/transcendental/cl_LF_exp_aux.cc: Throw.
267 * src/float/transcendental/cl_LF_ratseries_a.cc: Throw.
268 * src/float/transcendental/cl_LF_ratseries_ab.cc: Throw.
269 * src/float/transcendental/cl_LF_ratseries_b.cc: Throw.
270 * src/float/transcendental/cl_LF_ratseries_p.cc: Throw.
271 * src/float/transcendental/cl_LF_ratseries_pa.cc: Throw.
272 * src/float/transcendental/cl_LF_ratseries_pab.cc: Throw.
273 * src/float/transcendental/cl_LF_ratseries_pb.cc: Throw.
274 * src/float/transcendental/cl_LF_ratseries_pq.cc: Throw.
275 * src/float/transcendental/cl_LF_ratseries_pqa.cc: Throw.
276 * src/float/transcendental/cl_LF_ratseries_pqab.cc: Throw.
277 * src/float/transcendental/cl_LF_ratseries_pqb.cc: Throw.
278 * src/float/transcendental/cl_LF_ratseries_q.cc: Throw.
279 * src/float/transcendental/cl_LF_ratseries_qa.cc: Throw.
280 * src/float/transcendental/cl_LF_ratseries_qab.cc: Throw.
281 * src/float/transcendental/cl_LF_ratseries_qb.cc: Throw.
282 * src/float/transcendental/cl_LF_ratseries_stream_pq.cc: Throw.
283 * src/float/transcendental/cl_LF_ratseries_stream_pqa.cc: Throw.
284 * src/float/transcendental/cl_LF_ratseries_stream_pqab.cc: Throw.
285 * src/float/transcendental/cl_LF_ratseries_stream_pqb.cc: Throw.
286 * src/float/transcendental/cl_LF_ratsumseries_pqcd_aux.cc: Throw.
287 * src/float/transcendental/cl_LF_ratsumseries_pqd.cc: Throw.
288 * src/float/transcendental/cl_LF_ratsumseries_pqd_aux.cc: Throw.
289 * src/float/transcendental/cl_LF_zeta_int.cc: Throw.
290 * src/real/elem/cl_R_div.cc: Throw.
291 * src/real/format-output/cl_fmt_cardinal.cc: Throw.
292 * src/real/format-output/cl_fmt_newroman.cc: Throw.
293 * src/real/format-output/cl_fmt_oldroman.cc: Throw.
294 * src/real/input/cl_R_read.cc: Throw.
295 * src/real/input/cl_R_read_stream.cc: Throw.
296 * src/real/misc/cl_R_as.cc: Throw.
297 * src/real/random/cl_R_random.cc: Throw.
298 * src/real/transcendental/cl_R_atan2.cc: Throw.
299 * src/real/transcendental/cl_R_log.cc: Throw.
300 * src/complex/input/cl_N_read.cc: Throw.
301 * src/complex/input/cl_N_read_stream.cc: Throw.
302 * src/complex/misc/cl_N_as.cc: Throw.
303 * src/complex/transcendental/cl_C_atanh_aux.cc: Throw.
304 * src/complex/transcendental/cl_C_expt_C.cc: Throw.
305 * src/complex/transcendental/cl_C_log.cc: Throw.
306 * src/complex/transcendental/cl_C_log2.cc: Throw.
307 * src/numtheory/cl_nt_cornacchia1.cc: Throw.
308 * src/numtheory/cl_nt_cornacchia4.cc: Throw.
309 * src/numtheory/cl_nt_isprobprime.cc: Throw.
310 * src/numtheory/cl_nt_jacobi.cc: Throw.
311 * src/numtheory/cl_nt_jacobi_low.cc: Throw.
312 * src/numtheory/cl_nt_sqrtmodp.cc: Throw.
313 * src/modinteger/cl_MI.cc: Throw.
314 * src/modinteger/cl_MI_int.h: Throw.
315 * src/modinteger/cl_MI_montgom.h: Throw.
316 * src/modinteger/cl_MI_pow2.h: Throw.
317 * src/modinteger/cl_MI_rshift.cc: Throw.
318 * src/modinteger/cl_MI_std.h: Throw.
319 * src/polynomial/elem/cl_UP_GF2.h: Throw.
320 * src/polynomial/elem/cl_UP_MI.h: Throw.
321 * src/polynomial/elem/cl_UP_gen.h: Throw.
322 * src/polynomial/elem/cl_UP_named.cc: Throw.
323 * src/polynomial/elem/cl_UP_no_ring.cc (uninitialized_error,
324 uninitialized_ring): Removed (see cln/ring.h.)
325 * src/polynomial/elem/cl_UP_number.h: Throw.
326 * src/polynomial/elem/cl_UP_unnamed.cc: Throw.
327 * src/vector/cl_GV_I.cc: Throw.
328 * src/vector/cl_GV_number.cc: Throw.
329 * tests/timediv2adic-compare.cc: Use default abort(), not cl_abort().
330 * tests/timeprint-compare.cc: Likewise.
331 * tests/timerecip2adic-compare.cc: Likewise.
332 * doc/cln.tex: Document the exception classes.
333 * examples/contfrac.cc: Use try/catch instead of setjmp/longjmp.
334 * INSTALL: undocument -fno-exceptions.
335 * README: Add exceptions to list of used C++ features.
337 2007-06-20 Richard B. Kreckel <kreckel@ginac.de>
339 * cln.spec.in (Source0): Package is bzip2-compressed.
340 Reported by Markus Grabner <grabner@icg.tugraz.at>.
342 2007-05-31 Richard B. Kreckel <kreckel@ginac.de>
344 * include/cln/integer.h (cl_I_to_E, cl_I_to_UE): New functions.
345 * src/float/transcendental/cl_LF_exp_aux.cc: Make lq argument an uintE.
346 * src/float/transcendental/cl_LF_cossin_aux.cc: Likewise.
347 * src/float/transcendental/cl_LF_coshsinh_aux.cc: Likewise.
348 * src/float/transcendental/cl_F_tran.h: Change declaration of lq.
349 * src/float/transcendental/cl_F_lnx.cc: Fix some exponent types.
350 * src/float/transcendental/cl_F_expx.cc: Likewise.
351 * src/float/transcendental/cl_F_sinh.cc: Likewise.
352 * src/float/transcendental/cl_F_atanx.cc: Likewise.
353 * src/float/transcendental/cl_F_coshsinh.cc: Likewise.
354 * src/float/transcendental/cl_LF_cossin.cc: Likewise.
355 * src/float/transcendental/cl_LF_coshsinh.cc: Likewise.
357 2007-04-09 Richard B. Kreckel <kreckel@ginac.de>
359 More memory efficient constants:
360 * src/float/transcendental/cl_LF_pi.cc (compute_pi_ramanujan_163_fast):
361 Compute series coefficients on demand, using a series stream object.
362 * src/float/transcendental/cl_LF_zeta3.cc (zeta3): Likewise.
363 * src/float/transcendental/cl_LF_catalanconst.cc
364 (compute_catalanconst_ramanujan_fast): Likewise.
365 (compute_catalanconst_lupas): New function.
366 (compute_catalanconst): Simplify, based on new benchmark.
368 2007-04-02 Alexei Sheplyakov <varg@theor.jinr.ru>
371 * cln.pc.in: list -lgmp in Libs.private instead of in Libs.
372 * doc/cln.tex: Undocument cln-config, properly document pkg-config.
373 * cln-config.1.in: Remove.
374 * cln-config.in: Remove.
376 * configure.ac: Don't output cln-config and cln-config.1.
378 2006-12-24 Bruno Haible <bruno@clisp.org>
380 Make autoconfiguration work with gcc-4.3 snapshots.
381 * autoconf/intparam.c (main1): Rename get_integer_bitsize to
382 get_unsigned_integer_bitsize. New macro get_signed_integer_bitsize.
384 2006-12-19 Bruno Haible <bruno@clisp.org>
386 * autoconf/intparam.c (main): Use 'return', not exit().
387 * autoconf/floatparam.c (main): Likewise.
388 Reported by Ralf Wildenhues <Ralf.Wildenhues@gmx.de>.
390 2006-12-11 Richard B. Kreckel <kreckel@ginac.de>
392 Extend the exponent range from 32 bits to 64 bits on selected platforms.
393 * include/cln/number.h: Add signatures for operations with long long.
394 * include/cln/complex_class.h: Likewise.
395 * include/cln/real_class.h: Likewise.
396 * include/cln/real.h: Likewise.
397 * include/cln/rational_class.h: Likewise.
398 * include/cln/rational.h: Likewise.
399 * include/cln/integer_class.h: Likewise.
400 * include/cln/integer.h: Likewise.
401 * include/cln/float.h: Likewise.
402 * include/cln/lfloat.h: Likewise.
403 * include/cln/types.h (sintE and uintE): New types for exponents.
404 * include/cln/*float.h: Use the new types for exponents.
405 * include/cln/floatformat.h (float_format_t): Make underlying type
406 compatible with sintE.
407 * doc/cln.tex: Document changed float_exponent return value.
408 * src/float/cl_F.h: Likewise.
409 * src/float/ffloat/misc/cl_FF_exponent.cc: Likewise.
410 * src/float/input/cl_F_read.cc: Likewise.
411 * src/float/lfloat/cl_LF.h: Likewise.
412 * src/float/lfloat/cl_LF_impl.h: Likewise.
413 * src/float/lfloat/algebraic/cl_LF_sqrt.cc: Likewise.
414 * src/float/lfloat/elem/cl_LF_1plus.cc: Likewise.
415 * src/float/lfloat/elem/cl_LF_I_div.cc: Likewise.
416 * src/float/lfloat/elem/cl_LF_I_mul.cc: Likewise.
417 * src/float/lfloat/elem/cl_LF_compare.cc: Likewise.
418 * src/float/lfloat/elem/cl_LF_div.cc: Likewise.
419 * src/float/lfloat/elem/cl_LF_from_I.cc: Likewise.
420 * src/float/lfloat/elem/cl_LF_fround.cc: Likewise.
421 * src/float/lfloat/elem/cl_LF_ftrunc.cc: Likewise.
422 * src/float/lfloat/elem/cl_LF_futrunc.cc: Likewise.
423 * src/float/lfloat/elem/cl_LF_mul.cc: Likewise.
424 * src/float/lfloat/elem/cl_LF_scale.cc: Likewise.
425 * src/float/lfloat/elem/cl_LF_scale_I.cc: Likewise.
426 * src/float/lfloat/elem/cl_LF_square.cc: Likewise.
427 * src/float/lfloat/elem/cl_LF_to_I.cc: Likewise.
428 * src/float/lfloat/misc/cl_LF_decode.cc: Likewise.
429 * src/float/lfloat/misc/cl_LF_exponent.cc: Likewise.
430 * src/float/lfloat/misc/cl_LF_idecode.cc: Likewise.
431 * src/float/lfloat/misc/cl_LF_shortenrel.cc: Likewise.
432 * src/float/lfloat/misc/cl_LF_shortenwith.cc: Likewise.
433 * src/float/misc/cl_F_decode.cc: Likewise.
434 * src/float/misc/cl_F_exponent.cc: Likewise.
435 * src/float/misc/cl_F_shortenrel.cc: Likewise.
436 * src/float/misc/cl_float_format.cc: Likewise.
437 * src/float/output/cl_F_dprint.cc: Likewise.
438 * src/float/sfloat/misc/cl_SF_exponent.cc: Likewise.
439 * src/float/transcendental/cl_F_atanhx.cc: Likewise.
440 * src/float/transcendental/cl_F_atanx.cc: Likewise.
441 * src/float/transcendental/cl_F_cosh.cc: Likewise.
442 * src/float/transcendental/cl_F_expx.cc: Likewise.
443 * src/float/transcendental/cl_F_lnx.cc: Likewise.
444 * src/float/transcendental/cl_F_sinhx.cc: Likewise.
445 * src/float/transcendental/cl_F_sinx.cc: Likewise.
446 * src/float/transcendental/cl_LF_pi.cc: Likewise.
447 * src/integer/cl_I.h: Likewise.
448 * src/complex/algebraic/cl_LF_hypot.cc: Likewise.
449 * src/complex/elem/division/cl_C_LF_recip.cc: Likewise.
450 * src/float/dfloat/misc/cl_DF_exponent.cc: Likewise.
451 * src/integer/conv/cl_I_from_Q2.cc: Added.
452 * src/base/cl_low.h (isqrtC): New function, for 64 bit falls back to...
453 * src/base/low/cl_low_isqrt.cc (isqrt): ...this new implementation.
454 * src/base/cl_macros.h (bitc): Make sure 64 bit is used if required by
456 * examples/pi.cc: Support more than 646456614 decimal digits.
458 2006-11-02 Richard B. Kreckel <kreckel@ginac.de>
460 * src/base/digitseq/cl_DS.h: #undef DS, needed for i386-Solaris.
462 2006-10-11 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
464 * tests/Makefile.in (VPATH): Fix syntax error.
466 2006-09-14 Richard B. Kreckel <kreckel@ginac.de>
468 * examples/perfnum.cc: update to presumed 44th Mersenne prime.
470 2006-08-15 Richard B. Kreckel <kreckel@ginac.de>
472 * tests/Makefile.in: MinGW support for make check
473 (Patch by Sheplyakov Alexei <varg@theor.jinr.ru> to add ${EXEEXT}).
474 * Makefile.in: Convert from $(VAR) to ${VAR} syntax.
475 * benchmarks/Makefile.in: Likewise.
476 * doc/Makefile.in: Likewise.
477 * examples/Makefile.in: Likewise.
478 * src/Makefile.in: Likewise.
479 * tests/Makefile.in: Likewise.
481 2006-08-06 Richard B. Kreckel <kreckel@ginac.de>
483 * configure.ac: Re-enable shared lib on non-MinGW platforms, sigh.
485 2006-08-04 Sheplyakov Alexei <varg@theor.jinr.ru>
487 * configure.ac: Disable shared lib on MinGW.
489 2006-08-03 Sheplyakov Alexei <varg@theor.jinr.ru>
491 * m4/param.m4: Add support for MinGW.
492 * src/base/random/cl_random_from.cc: Fix for last patch.
494 2006-07-23 Sheplyakov Alexei <varg@theor.jinr.ru>
496 * src/base/random/cl_random_from.cc: Add support for MinGW.
498 2006-06-13 Richard B. Kreckel <kreckel@ginac.de>
500 * m4/general.m4 (CL_CANONICAL_HOST_CPU): Force host_cpu=i386 for x86_64
501 if userland is 32 bit.
502 * include/cln/config.h.in: Simplify __x86_64__ selection.
503 * src/base/digitseq/cl_asm_x86_64_.cc: Remove.
505 2006-06-09 Richard B. Kreckel <kreckel@ginac.de>
507 * src/base/digitseq/cl_DS.h (struct DS): Change len type to uintC.
509 2006-05-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
511 * m4/gettimeofday.m4 (CL_GETTIMEOFDAY): Fix M4 quoting.
513 2006-05-20 Bruno Haible <bruno@clisp.org>
515 * src/base/random/cl_random_from.cc: Treat FreeBSD, NetBSD like other
518 2006-05-07 Richard B. Kreckel <kreckel@ginac.de>
520 * include/cln/modules.h (CL_JUMP_TO): Fix for Intel Mac.
522 2006-04-25 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
524 Prepare for autoconf-2.60.
525 * Makefile.in (datarootdir): New variable.
526 * src/Makefile.in (datarootdir): New variable.
527 * doc/Makefile.in (datarootdir): New variable.
529 2006-04-25 Bruno Haible <bruno@clisp.org>
530 Richard B. Kreckel <kreckel@ginac.de>
532 Make it theoretically possible to use bignums and long-floats with
533 more than 2^32 significant digits or bits.
534 * doc/cln.tex (logcount): Change return type to uintC.
535 (struct cl_byte): Change elements to uintC.
536 (integer_length, ord2, power2p): Change return type to uintC.
537 (scale_float): Change argument type to sintC.
538 (float_digits, float_precision): Change return type to uintC.
539 * examples/atan_recip.cc: Use uintC instead of uintL where appropriate.
540 * examples/atanh_recip.cc: Likewise.
541 * include/cln/GV.h: Likewise.
542 * include/cln/GV_complex.h: Likewise.
543 * include/cln/GV_integer.h: Likewise.
544 * include/cln/GV_modinteger.h: Likewise.
545 * include/cln/GV_number.h: Likewise.
546 * include/cln/GV_rational.h: Likewise.
547 * include/cln/GV_real.h: Likewise.
548 * include/cln/SV.h: Likewise.
549 * include/cln/SV_complex.h: Likewise.
550 * include/cln/SV_integer.h: Likewise.
551 * include/cln/SV_number.h: Likewise.
552 * include/cln/SV_rational.h: Likewise.
553 * include/cln/SV_real.h: Likewise.
554 * include/cln/SV_ringelt.h: Likewise.
555 * include/cln/dfloat.h: Likewise.
556 * include/cln/ffloat.h: Likewise.
557 * include/cln/float.h: Likewise.
558 * include/cln/integer.h: Likewise.
559 * include/cln/lfloat.h: Likewise.
560 * include/cln/modinteger.h: Likewise.
561 * include/cln/sfloat.h: Likewise.
562 * src/base/cl_low.h (integerlengthC): New macro.
563 * src/base/digitseq/cl_2DS_div.cc: Use uintC instead of uintL where
565 * src/base/digitseq/cl_2DS_recip.cc: Likewise.
566 * src/base/digitseq/cl_DS.h: Likewise.
567 * src/base/digitseq/cl_DS_mul.c: Likewise.
568 * src/base/digitseq/cl_DS_mul_fftc.h: Likewise.
569 * src/base/digitseq/cl_DS_mul_fftcs.h: Likewise.
570 * src/base/digitseq/cl_DS_mul_fftm.h: Likewise.
571 * src/base/digitseq/cl_DS_mul_fftp.h: Likewise.
572 * src/base/digitseq/cl_DS_mul_fftp3.h: Likewise.
573 * src/base/digitseq/cl_DS_mul_fftp3m.h: Likewise.
574 * src/base/digitseq/cl_DS_mul_fftr.h: Likewise.
575 * src/base/digitseq/cl_DS_mul_kara.h: Likewise.
576 * src/base/digitseq/cl_DS_mul_nuss.h: Likewise.
577 * src/base/digitseq/cl_DS_recip.cc: Likewise.
578 * src/base/digitseq/cl_DS_recipsqrt.cc: Likewise.
579 * src/base/digitseq/cl_DS_sqrt.cc: Likewise.
580 * src/base/digitseq/cl_DS_trandom.cc: Likewise.
581 * src/complex/input/cl_N_read.cc: Likewise.
582 * src/complex/transcendental/cl_C_asinh_aux.cc: Likewise.
583 * src/complex/transcendental/cl_C_expt_C.cc: Likewise.
584 * src/float/cl_F.h: Likewise.
585 * src/float/conv/cl_F_from_F_f.cc: Likewise.
586 * src/float/conv/cl_F_from_I_f.cc: Likewise.
587 * src/float/conv/cl_F_from_RA_f.cc: Likewise.
588 * src/float/dfloat/conv/cl_I_to_double.cc: Likewise.
589 * src/float/dfloat/conv/cl_RA_to_double.cc: Likewise.
590 * src/float/dfloat/elem/cl_DF_from_I.cc: Likewise.
591 * src/float/dfloat/elem/cl_DF_from_RA.cc: Likewise.
592 * src/float/dfloat/elem/cl_DF_scale.cc: Likewise.
593 * src/float/dfloat/misc/cl_DF_digits.cc: Likewise.
594 * src/float/dfloat/misc/cl_DF_precision.cc: Likewise.
595 * src/float/elem/cl_F_scale.cc: Likewise.
596 * src/float/ffloat/conv/cl_I_to_float.cc: Likewise.
597 * src/float/ffloat/conv/cl_RA_to_float.cc: Likewise.
598 * src/float/ffloat/elem/cl_FF_from_I.cc: Likewise.
599 * src/float/ffloat/elem/cl_FF_from_RA.cc: Likewise.
600 * src/float/ffloat/elem/cl_FF_scale.cc: Likewise.
601 * src/float/ffloat/misc/cl_FF_digits.cc: Likewise.
602 * src/float/ffloat/misc/cl_FF_precision.cc: Likewise.
603 * src/float/input/cl_F_read.cc: Likewise.
604 * src/float/lfloat/algebraic/cl_LF_sqrt.cc: Likewise.
605 * src/float/lfloat/elem/cl_LF_1plus.cc: Likewise.
606 * src/float/lfloat/elem/cl_LF_I_div.cc: Likewise.
607 * src/float/lfloat/elem/cl_LF_I_mul.cc: Likewise.
608 * src/float/lfloat/elem/cl_LF_div.cc: Likewise.
609 * src/float/lfloat/elem/cl_LF_from_I.cc: Likewise.
610 * src/float/lfloat/elem/cl_LF_from_RA.cc: Likewise.
611 * src/float/lfloat/elem/cl_LF_fround.cc: Likewise.
612 * src/float/lfloat/elem/cl_LF_ftrunc.cc: Likewise.
613 * src/float/lfloat/elem/cl_LF_futrunc.cc: Likewise.
614 * src/float/lfloat/elem/cl_LF_scale.cc: Likewise.
615 * src/float/lfloat/elem/cl_LF_to_I.cc: Likewise.
616 * src/float/lfloat/misc/cl_LF_digits.cc: Likewise.
617 * src/float/lfloat/misc/cl_LF_idecode.cc: Likewise.
618 * src/float/lfloat/misc/cl_LF_leninc.cc: Likewise.
619 * src/float/lfloat/misc/cl_LF_lenincx.cc: Likewise.
620 * src/float/lfloat/misc/cl_LF_precision.cc: Likewise.
621 * src/float/lfloat/misc/cl_LF_shortenrel.cc: Likewise.
622 * src/float/lfloat/misc/cl_LF_shortenwith.cc: Likewise.
623 * src/float/misc/cl_F_digits.cc: Likewise.
624 * src/float/misc/cl_F_epsneg.cc: Likewise.
625 * src/float/misc/cl_F_epspos.cc: Likewise.
626 * src/float/misc/cl_F_leastneg.cc: Likewise.
627 * src/float/misc/cl_F_leastpos.cc: Likewise.
628 * src/float/misc/cl_F_mostneg.cc: Likewise.
629 * src/float/misc/cl_F_mostpos.cc: Likewise.
630 * src/float/misc/cl_F_precision.cc: Likewise.
631 * src/float/misc/cl_F_rational.cc: Likewise.
632 * src/float/misc/cl_F_shortenrel.cc: Likewise.
633 * src/float/output/cl_F_dprint.cc: Likewise.
634 * src/float/random/cl_F_random.cc: Likewise.
635 * src/float/sfloat/elem/cl_SF_from_I.cc: Likewise.
636 * src/float/sfloat/elem/cl_SF_from_RA.cc: Likewise.
637 * src/float/sfloat/elem/cl_SF_scale.cc: Likewise.
638 * src/float/sfloat/misc/cl_SF_digits.cc: Likewise.
639 * src/float/sfloat/misc/cl_SF_precision.cc: Likewise.
640 * src/float/transcendental/cl_F_atanhx.cc: Likewise.
641 * src/float/transcendental/cl_F_atanx.cc: Likewise.
642 * src/float/transcendental/cl_F_catalanconst_f.cc: Likewise.
643 * src/float/transcendental/cl_F_cos.cc: Likewise.
644 * src/float/transcendental/cl_F_cosh.cc: Likewise.
645 * src/float/transcendental/cl_F_coshsinh.cc: Likewise.
646 * src/float/transcendental/cl_F_cossin.cc: Likewise.
647 * src/float/transcendental/cl_F_eulerconst_f.cc: Likewise.
648 * src/float/transcendental/cl_F_exp1_f.cc: Likewise.
649 * src/float/transcendental/cl_F_expx.cc: Likewise.
650 * src/float/transcendental/cl_F_ln10_f.cc: Likewise.
651 * src/float/transcendental/cl_F_ln2_f.cc: Likewise.
652 * src/float/transcendental/cl_F_lnx.cc: Likewise.
653 * src/float/transcendental/cl_F_pi_f.cc: Likewise.
654 * src/float/transcendental/cl_F_sin.cc: Likewise.
655 * src/float/transcendental/cl_F_sinh.cc: Likewise.
656 * src/float/transcendental/cl_F_sinhx.cc: Likewise.
657 * src/float/transcendental/cl_F_sinx.cc: Likewise.
658 * src/float/transcendental/cl_F_tran.h: Likewise.
659 * src/float/transcendental/cl_F_zeta_int_f.cc: Likewise.
660 * src/float/transcendental/cl_LF_atan_recip.cc: Likewise.
661 * src/float/transcendental/cl_LF_atanh_recip.cc: Likewise.
662 * src/float/transcendental/cl_LF_catalanconst.cc: Likewise.
663 * src/float/transcendental/cl_LF_coshsinh_aux.cc: Likewise.
664 * src/float/transcendental/cl_LF_cossin_aux.cc: Likewise.
665 * src/float/transcendental/cl_LF_eulerconst.cc: Likewise.
666 * src/float/transcendental/cl_LF_exp1.cc: Likewise.
667 * src/float/transcendental/cl_LF_exp_aux.cc: Likewise.
668 * src/float/transcendental/cl_LF_pi.cc: Likewise.
669 * src/float/transcendental/cl_LF_ratseries.cc: Likewise.
670 * src/float/transcendental/cl_LF_ratseries_.cc: Likewise.
671 * src/float/transcendental/cl_LF_ratseries_a.cc: Likewise.
672 * src/float/transcendental/cl_LF_ratseries_ab.cc: Likewise.
673 * src/float/transcendental/cl_LF_ratseries_b.cc: Likewise.
674 * src/float/transcendental/cl_LF_ratseries_p.cc: Likewise.
675 * src/float/transcendental/cl_LF_ratseries_pa.cc: Likewise.
676 * src/float/transcendental/cl_LF_ratseries_pab.cc: Likewise.
677 * src/float/transcendental/cl_LF_ratseries_pb.cc: Likewise.
678 * src/float/transcendental/cl_LF_ratseries_pq.cc: Likewise.
679 * src/float/transcendental/cl_LF_ratseries_pqa.cc: Likewise.
680 * src/float/transcendental/cl_LF_ratseries_pqab.cc: Likewise.
681 * src/float/transcendental/cl_LF_ratseries_pqb.cc: Likewise.
682 * src/float/transcendental/cl_LF_ratseries_q.cc: Likewise.
683 * src/float/transcendental/cl_LF_ratseries_qa.cc: Likewise.
684 * src/float/transcendental/cl_LF_ratseries_qab.cc: Likewise.
685 * src/float/transcendental/cl_LF_ratseries_qb.cc: Likewise.
686 * src/float/transcendental/cl_LF_ratseries_stream_pq.cc: Likewise.
687 * src/float/transcendental/cl_LF_ratseries_stream_pqa.cc: Likewise.
688 * src/float/transcendental/cl_LF_ratseries_stream_pqab.cc: Likewise.
689 * src/float/transcendental/cl_LF_ratseries_stream_pqb.cc: Likewise.
690 * src/float/transcendental/cl_LF_ratsumseries_pqcd.cc: Likewise.
691 * src/float/transcendental/cl_LF_ratsumseries_pqcd_aux.cc: Likewise.
692 * src/float/transcendental/cl_LF_ratsumseries_pqd.cc: Likewise.
693 * src/float/transcendental/cl_LF_ratsumseries_pqd_aux.cc: Likewise.
694 * src/float/transcendental/cl_LF_tran.h: Likewise.
695 * src/float/transcendental/cl_LF_zeta3.cc: Likewise.
696 * src/float/transcendental/cl_LF_zeta_int.cc: Likewise.
697 * src/integer/algebraic/cl_I_rootp_I.cc: Likewise.
698 * src/integer/algebraic/cl_I_rootp_aux.cc: Likewise.
699 * src/integer/bitwise/cl_I_ash.cc: Likewise.
700 * src/integer/bitwise/cl_I_ash_I.cc: Likewise.
701 * src/integer/bitwise/cl_I_byte.h: Likewise.
702 * src/integer/bitwise/cl_I_fullbyte.cc: Likewise.
703 * src/integer/bitwise/cl_I_ilength.cc: Likewise.
704 * src/integer/bitwise/cl_I_ldb.cc: Likewise.
705 * src/integer/bitwise/cl_I_ldbtest.cc: Likewise.
706 * src/integer/bitwise/cl_I_ldbx.cc: Likewise.
707 * src/integer/bitwise/cl_I_ldbxtest.cc: Likewise.
708 * src/integer/bitwise/cl_I_logbitp.cc: Likewise.
709 * src/integer/bitwise/cl_I_logbitp_I.cc: Likewise.
710 * src/integer/bitwise/cl_I_logcount.cc: Likewise.
711 * src/integer/bitwise/cl_I_mkf.cc: Likewise.
712 * src/integer/bitwise/cl_I_mkfx.cc: Likewise.
713 * src/integer/cl_I.h: Likewise.
714 * src/integer/conv/cl_I_to_digits.cc: Likewise.
715 * src/integer/conv/cl_I_digits_need.cc: Likewise.
716 * src/integer/conv/cl_I_from_digits.cc: Likewise.
717 * src/integer/gcd/cl_I_gcd.cc: Likewise.
718 * src/integer/gcd/cl_I_xgcd.cc: Likewise.
719 * src/integer/misc/cl_I_eqhashcode.cc: Likewise.
720 * src/integer/misc/cl_I_ord2.cc: Likewise.
721 * src/integer/misc/cl_I_power2p.cc: Likewise.
722 * src/integer/output/cl_I_cached_power.h (cached_power_table): allow
724 * src/integer/output/cl_I_decstring.cc: Use uintC instead of uintL
726 * src/integer/output/cl_I_print.cc: Likewise.
727 * src/integer/output/cl_I_print_string.cc: Likewise.
728 * src/modinteger/cl_MI.cc: Likewise.
729 * src/modinteger/cl_MI_lshift.cc: Likewise.
730 * src/modinteger/cl_MI_montgom.h: Likewise.
731 * src/modinteger/cl_MI_pow2.h: Likewise.
732 * src/modinteger/cl_MI_pow2m1.h: Likewise.
733 * src/modinteger/cl_MI_pow2p1.h: Likewise.
734 * src/modinteger/cl_MI_rshift.cc: Likewise.
735 * src/modinteger/cl_MI_std.h: Likewise.
736 * src/numtheory/cl_IF_millerrabin.cc: Likewise.
737 * src/numtheory/cl_nt_isprobprime.cc: Likewise.
738 * src/numtheory/cl_nt_sqrtmodp.cc: Likewise.
739 * src/polynomial/elem/cl_UP_GF2.h: Likewise.
740 * src/real/conv/cl_F_from_R_f.cc: Likewise.
741 * src/real/format-output/cl_fmt_floatstring.cc: Likewise.
742 * src/real/input/cl_R_read.cc: Likewise.
743 * src/vector/cl_GV_I.cc: Likewise.
744 * src/vector/cl_GV_I_copy.cc: Likewise.
745 * src/vector/cl_GV_number.cc: Likewise.
746 * src/vector/cl_GV_number_copy.cc: Likewise.
747 * src/vector/cl_SV_copy.cc: Likewise.
748 * src/vector/cl_SV_number.cc: Likewise.
749 * src/vector/cl_SV_ringelt.cc: Likewise.
750 * tests/main.cc: Likewise.
751 * tests/test_I_ilength.cc: Likewise.
752 * tests/test_I_ord2.cc: Likewise.
754 2006-04-19 Bruno Haible <bruno@clisp.org>
756 Prepare for autoconf-2.60.
757 * general.m4 (CL_CC_WORKS): Include <stdlib.h>, for exit() declaration.
758 * longdouble.m4 (CL_LONGDOUBLE): Likewise.
759 * longlong.m4 (CL_LONGLONG): Likewise.
760 * times.m4 (CL_TIMES_CLOCK): Likewise.
761 Reported by Ralf Wildenhues <Ralf.Wildenhues@gmx.de>.
763 2005-12-04 Bruno Haible <bruno@clisp.org>
765 * src/integer/conv/cl_I_to_digits.cc (I_to_digits_noshrink): Set
768 2005-12-04 Bruno Haible <bruno@clisp.org>
770 Extend the fixnum range from 32 bits to 61 bits on 64-bit platforms.
771 * doc/cln.tex (gcd, jacobi): Take 'long' instead of 'int32' arguments.
772 * include/cln/object.h (cl_value_shift): Define as 3, not 32, in the
774 * include/cln/types.h (intVsize): New macro.
775 (sintV, uintV): New types.
776 * include/cln/integer.h (gcd): Take uintV arguments.
777 * include/cln/numtheory.h (jacobi): Take sintV arguments.
778 * src/complex/input/cl_N_read.cc (read_complex): Call FN_to_UV instead
780 * src/complex/transcendental/cl_C_expt_C.cc: Likewise.
781 * src/float/dfloat/elem/cl_DF_scale_I.cc: Use uintV instead of uintL
782 * src/float/dfloat/elem/cl_DF_from_RA.cc: Don't assume values >= 2^53
783 and < 2^55 are always bignums.
785 * src/float/ffloat/conv/cl_RA_to_float.cc: Call FN_to_UV instead of
787 * src/float/ffloat/elem/cl_FF_from_RA.cc: Likewise.
788 * src/float/ffloat/elem/cl_FF_scale_I.cc: Call FN_to_V instead of
790 * src/float/lfloat/elem/cl_LF_scale_I.cc: Likewise.
791 * src/float/output/cl_F_dprint.cc: Likewise.
792 * src/float/sfloat/elem/cl_SF_from_RA.cc: Call FN_to_UV instead of
794 * src/float/sfloat/elem/cl_SF_scale_I.cc: Call FN_to_V instead of
796 * src/integer/cl_I.h (FN_to_UV): Renamed from FN_to_UL, change return
798 (FN_to_V): Renamed from FN_to_L, change return type.
799 (FN_V_zerop): Renamed from FN_L_zerop.
800 (FN_V_minusp): Renamed from FN_L_minusp.
801 (cl_I_constructor_from_L2, cl_I_constructor_from_UL2): Define as an
802 inline function on 64-bit platforms.
803 (V_to_I, UV_to_I): New macros.
804 (pFN_maxlength_digits_at): Return an uintV instead of an uint32.
805 (set_pFN_maxlength_digits_at): Take an uintV instead of an uint32.
806 * src/integer/algebraic/cl_I_sqrtp.cc: Call FN_to_UV instead of
808 * src/integer/bitwise/cl_I_ash_I.cc: Call FN_to_V instead of FN_to_L.
809 * src/integer/bitwise/cl_I_ilength.cc: Likewise.
810 * src/integer/bitwise/cl_I_log_aux.cc: Likewise.
811 * src/integer/bitwise/cl_I_logbitp_I.cc: Likewise.
812 * src/integer/bitwise/cl_I_logcount.cc: Likewise.
813 * src/integer/bitwise/cl_I_logtest.cc: Likewise.
814 * src/integer/conv/cl_I_from_L2.cc: Don't produce code on 64-bit
816 * src/integer/conv/cl_I_from_UL2.cc: Likewise.
817 * src/integer/conv/cl_I_from_NDS.cc: Update.
818 * src/integer/conv/cl_I_from_Q.cc: Remove cast to sint32.
819 * src/integer/conv/cl_I_from_UQ.cc: Remove cast to uint32.
820 * src/integer/conv/cl_I_to_L.cc: Check again fixnum that needs more
822 * src/integer/conv/cl_I_to_Q.cc: Call FN_to_V instead of FN_to_L.
823 * src/integer/conv/cl_I_to_UL.cc: Likewise.
824 * src/integer/conv/cl_I_to_UQ.cc: Likewise.
825 * src/integer/elem/cl_I_div.cc: Treat fixnums that need more than 32
827 * src/integer/elem/cl_I_minus.cc: Call FN_to_V instead of FN_to_L.
828 * src/integer/elem/cl_I_mul.cc: Likewise.
829 * src/integer/elem/cl_I_plus.cc: Likewise.
830 * src/integer/elem/cl_I_square.cc: Likewise.
831 * src/integer/elem/cl_I_uminus.cc: Likewise.
832 * src/integer/gcd/cl_I_gcd.cc: Likewise.
833 * src/integer/gcd/cl_low_gcd.cc (gcd): Take uintV arguments.
834 * src/integer/hash/cl_I_hashcode.cc: Call FN_to_V instead of FN_to_L.
835 * src/integer/input/cl_I_read.cc (read_integer): Call FN_to_UV instead
837 * src/integer/misc/cl_I_ord2.cc (ord2): Call ord2_64 on 64-bit
839 * src/integer/misc/cl_I_power2p.cc: Call FN_to_UV instead of FN_to_UL.
840 * src/integer/misc/combin/cl_I_doublefactorial.cc (doublefakul_table):
841 Extend table for larger fixnums.
842 (doublefactorial): Update.
843 * src/integer/misc/combin/cl_I_factorial.cc (fakul_table): Extend table
846 * src/modinteger/cl_MI_fix16.h: Call FN_to_UV instead of FN_to_UL.
847 * src/modinteger/cl_MI_fix29.h: Likewise.
848 * src/modinteger/cl_MI_fix32.h: Likewise.
849 * src/modinteger/cl_MI_std.h: Likewise.
850 * src/numtheory/cl_nt_cornacchia4.cc: Call FN_to_V instead of FN_to_L.
851 * src/numtheory/cl_nt_jacobi.cc: Likewise.
852 * src/numtheory/cl_nt_jacobi_low.cc (jacobi_aux): Take uintV arguments
853 instead of uint32 arguments.
854 (jacobi): Take sintV argument instead of a sint32 argument.
855 * src/rational/input/cl_RA_read.cc: Call FN_to_UV instead of FN_to_UL.
856 * src/real/input/cl_R_read.cc: Likewise.
857 * src/vector/cl_GV_I.cc: Likewise.
858 * tests/timefact.cc: Call FN_to_V instead of FN_to_L.
860 2005-12-04 Bruno Haible <bruno@clisp.org>
862 More complete 64-bit division macros.
863 * src/base/cl_low.h (divu_6432_3232_w): Choose a different macro
865 (divu_6432_6432): New macro.
866 (divu_6464_6464): Choose a different macro expansion for all CPUs
867 except sparc64 and x86_64.
868 (divu_12864_6464): Define NEED_VAR_divu_64_rest here.
869 * src/base/low/cl_low_div.cc (divu_64_rest): Avoid defining it twice.
870 (divu_6464_6464_): New function.
872 2005-12-04 Bruno Haible <bruno@clisp.org>
874 * src/base/cl_low.h (ord2_64): New macro.
876 2005-12-02 Bruno Haible <bruno@clisp.org>
878 * src/base/cl_low.h (mulu64) [x86_64]: Change asm restriction, since
879 mulq doesn't accept immediate arguments.
881 2005-11-26 Bruno Haible <bruno@clisp.org>
883 * src/base/cl_low.h (GENERIC_INTEGERLENGTH32): New macro.
884 (integerlength64): Define using integerlength32 if integerlength32
885 is not defined generically.
887 2005-11-26 Bruno Haible <bruno@clisp.org>
889 * src/base/cl_low.h (mulu32) [SPARC64]: Remove rd instruction, since
890 umul returns the complete 64-bit product in a register.
891 (mulu32_w) [SPARC64]: Prefer umul over mulx instruction.
892 (divu_6432_3232_w) [SPARC64]: Prefer umul/udiv over mulx/udivx
895 2005-11-26 Bruno Haible <bruno@clisp.org>
897 * src/base/cl_low.h (divu_3216_1616): Prepend underscore to local
900 2005-11-26 Bruno Haible <bruno@clisp.org>
902 * src/base/cl_low.h (ord2_32): Parenthesize macro argument.
904 2005-12-17 Richard B. Kreckel <kreckel@ginac.de>
906 * Created branch cln_1-1 for maintenance patches.
907 This is the main branch, which will eventually become CLN 1.2.0.
909 2005-12-15 Dmitry V. Kustov <kustov@telex221.ru>
911 * src/base/random/cl_random_from.cc: Add support for OpenBSD.
913 2005-11-23 Richard B. Kreckel <kreckel@ginac.de>
915 * Version 1.1.11 released.
917 2005-11-20 Richard B. Kreckel <kreckel@ginac.de>
919 * src/integer/conv/cl_I_cached_power.h: New file.
920 * src/integer/conv/cl_I_cached_power.cc: New file.
921 Contains power_table and cached_power_table previously...
922 * src/integer/conv/cl_I_to_digits.cc: ...here.
923 * src/integer/conv/cl_I_from_digits.cc: Use cached powers.
925 2005-11-02 Richard B. Kreckel <kreckel@ginac.de>
927 * src/integer/conv/cl_I_from_digits.cc: Made input of all numbers in
928 non-power-of-two base much faster.
929 * tests/test_I_io.cc: New file...
930 * tests/Makefile.in, tests/test_I.cc: ...used here.
932 2005-10-22 Richard B. Kreckel <kreckel@ginac.de>
934 * Version 1.1.10 released.
936 2005-10-22 Richard B. Kreckel <kreckel@ginac.de>
938 * src/Makefile.in: Accept CPPFLAGS from environment.
939 * examples/Makefile.in: Likewise.
940 * benchmarks/Makefile.in: Likewise.
941 * tests/Makefile.in: Likewise.
943 2005-08-30 Richard B. Kreckel <kreckel@ginac.de>
945 * include/cln/modules.h (CL_OUTPUT_LABEL): Work around redundant
946 duplication of basic blocks on m68k.
948 2005-08-30 Richard B. Kreckel <kreckel@ginac.de>
950 * include/cln/modules.h (CL_JUMP_TO): Fix mips* brokenness.
952 2005-08-27 Bruno Haible <bruno@clisp.org>
954 Split aclocal.m4 into individual files.
955 * m4/alloca.m4, m4/as-underscore.m4, m4/c++-constructors.m4:
956 * m4/fpu_control.m4, m4/general.m4, m4/gettimeofday.m4:
957 * m4/longdouble.m4, m4/longlong.m4, m4/param.m4, m4/perror.m4:
958 * m4/proto.m4, m4/rusage.m4, m4/times.m4:
959 New files, extracted from autoconf/aclocal.m4.
960 * autoconf/aclocal.m4: m4_include them.
961 * Makefile.devel (AUTOCONF_MACROS): New variable.
962 (configure): Depend on it.
963 (CLISP_M4DIR): Remove variable.
964 (autoconf/aclocal.m4): Remove rule.
966 2005-08-27 Bruno Haible <bruno@clisp.org>
968 * src/integer/bitwise/cl_I_ash_I.cc (ash): Avoid shifting a 32-bit
969 zero value by more than 31 bits.
971 2005-08-27 Bruno Haible <bruno@clisp.org>
973 Make the long-float overflow check work on 64-bit platforms.
974 * src/float/lfloat/cl_LF.h (LF_exp_mid, LF_exp_high): Define as
975 'unsigned int', not 'unsigned long'.
977 2005-08-27 Bruno Haible <bruno@clisp.org>
979 * include/cln/modules.h (CL_OUTPUT_LABEL): Work around redundant
980 duplication of basic blocks by g++ 4.0.
981 See <http://gcc.gnu.org/bugzilla/show_bug.cgi?id=23345>.
983 2005-08-27 Bruno Haible <bruno@clisp.org>
985 Make it possible to cross-compile CLN.
986 * m4/intparam.m4: New file.
987 * m4/floatparam.m4: New file.
988 * autoconf/aclocal.m4: Include both.
989 (CL_MACHINE): Add an additional CROSS_MACRO parameter.
990 * configure.ac (CL_MACHINE): When cross-compiling, use
991 CL_INTPARAM_CROSS and CL_FLOATPARAM_CROSS.
993 2005-08-27 Bruno Haible <bruno@clisp.org>
995 Define HAVE_LONGLONG and HAVE_LONGDOUBLE when cross-compiling.
996 * autoconf/aclocal.m4 (CL_LONGLONG, CL_LONGDOUBLE): When cross-
997 compiling, use the test code from gnulib.
999 2005-08-27 Bruno Haible <bruno@clisp.org>
1001 * autoconf/aclocal.m4 (CL_RUSAGE): Fix error when cross-compiling.
1003 2005-08-16 Richard B. Kreckel <kreckel@ginac.de>
1005 The patch of 2005-05-01 made it impossible to test the type of a cl_UP
1006 by comparing with &cl_class_univpoly_ring. We need an alternative:
1007 * include/cln/object.h (cl_class_flags_modint_ring): New #define...
1008 * src/polynomial/elem/cl_UP.cc (cl_class_univpoly_ring): ...used here.
1009 * src/polynomial/elem/cl_UP_GF2.h: Likewise.
1010 * src/polynomial/elem/cl_UP_MI.h: Likewise.
1011 * src/polynomial/elem/cl_UP_gen.h: Likewise.
1012 * src/polynomial/elem/cl_UP_number.h: Likewise.
1014 2005-08-15 Richard B. Kreckel <kreckel@ginac.de>
1016 * m4/cc.m4 (CL_AS_NOEXECSTACK): New macro...
1017 * configure.ac: ...used here for setting ASMFLAGS...
1018 * src/Makefile.in: ...which are used here.
1020 2005-08-02 Andreas Jochens <aj@andaco.de>
1022 * include/cln/config.h.in: Add support for PowerPC 64 CPU.
1023 * include/cln/modules.h: Likewise.
1024 * include/cln/object.h: Likewise.
1025 * include/cln/types.h: Likewise.
1027 2005-07-24 Richard B. Kreckel <kreckel@ginac.de>
1029 Make out of the box build on x86_64 system with complete 32 bit
1031 * include/cln/config.h.in: Don't #define __x86_64__ when
1032 __i386__ is defined.
1033 * src/base/digitseq/cl_asm_x86_64_.cc: New file.
1034 * doc/cln.tex: Revert workaround description introduced 2005-05-02.
1036 2005-06-10 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1038 * Makefile.in: Don't enter nonexisting directories.
1040 2005-05-17 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1042 Speed up the linking step
1043 * src/Makefile.in: Use -objectlist for linking libcln.la.
1045 2005-05-15 Richard B. Kreckel <kreckel@ginac.de>
1047 * autoconf/ltmain.sh: Upgrade to libtool-1.5.16.
1048 * m4/libtool.m4: Upgrade to libtool-1.5.16 (without Comeau patch).
1050 2005-05-02 Richard B. Kreckel <kreckel@ginac.de>
1052 * doc/cln.tex: Document what to do on a x86_64 machine with 32-bit
1055 2005-05-01 Richard B. Kreckel <kreckel@ginac.de>
1057 Fix crashes in find_univpoly_ring and related functions
1058 * include/cln/modinteger.h: Remove vptr from cl_heap_modint_ring;
1059 remove declaration of cl_class cl_class_modint_ring.
1060 * include/cln/univpoly.h: Remove vptr from cl_heap_univpoly_ring;
1061 remove declaration of cl_class_univpoly_ring.
1062 * include/cln/object.h: cl_class_flags_modint_ring: New #define...
1063 * src/modinteger/cl_MI.cc: ...used in cl_class_modint_ring.
1064 * src/modinteger/cl_MI_fix16.h: No vptr, but static dtor and type flag.
1065 * src/modinteger/cl_MI_fix29.h: Likewise.
1066 * src/modinteger/cl_MI_fix32.h: Likewise.
1067 * src/modinteger/cl_MI_int32.h: Likewise.
1068 * src/modinteger/cl_MI_montgom.h: Likewise.
1069 * src/modinteger/cl_MI_pow2: Likewise.
1070 * src/modinteger/cl_MI_pow2m1.h: Likewise.
1071 * src/modinteger/cl_MI_pow2p1.h: Likewise.
1072 * src/modinteger/cl_MI_std.h: Likewise.
1073 * src/polynomial/elem/cl_UP.cc (cl_make_univpoly_ring): Compare with
1074 cl_class_flags_modint_ring, not with cl_class_modint_ring.
1075 * src/polynomial/elem/cl_UP_GF2.h (cl_class_num_univpoly_ring): New.
1076 * src/polynomial/elem/cl_UP_MI.h (cl_class_modint_univpoly_ring): New.
1077 * src/polynomial/elem/cl_UP_gen.h (cl_class_gen_univpoly_ring): New.
1078 * src/polynomial/elem/cl_UP_number.h (cl_class_num_univpoly_ring): New.
1079 Reported by Ralf Goertz <R_Goertz@web.de>.
1081 2005-04-29 Richard B. Kreckel <kreckel@ginac.de>
1082 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1084 * m4/cc.m4: Emit a warning if g++ is used and optimization turned off.
1086 2005-04-24 Richard B. Kreckel <kreckel@ginac.de>
1088 Make GCC compiler flags default to -O
1089 * m4/cc.m4: New file...
1090 * configure.ac: ...used here.
1091 * autoconf/aclocal.m4: Regenerate.
1093 2005-04-18 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1095 * include/cln/string.h: Declare cl_string.
1097 2005-03-17 Richard B. Kreckel <kreckel@ginac.de>
1099 * autoconf/ltmain.sh: Upgrade to libtool-1.5.14.
1100 * m4/libtool.m4: Upgrade to libtool-1.5.14 with Comeau patch.
1101 * autoconf/aclocal.m4: Regenerate.
1103 2005-03-15 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1105 * src/Makefile.in: Use $CXX instead of $CC when linking.
1107 2005-02-27 Richard B. Kreckel <kreckel@ginac.de>
1109 * examples/perfnum.cc: update to presumed 42st Mersenne prime.
1111 2004-11-28 Richard B. Kreckel <kreckel@ginac.de>
1113 Disambiguate binary operators of CLN types with float/double
1114 * include/cln/dfloat.h: Add binary operator overloads for arguments of
1116 * include/cln/ffloat.h: Likewise, for arguments of type float.
1117 * include/cln/float.h: Likewise, both for arguments of types double and
1119 * include/cln/real.h: Likewise.
1120 Reported by Isidro Cachadiña Gutiérrez <icacha@unex.es>.
1122 2004-11-03 Richard B. Kreckel <kreckel@ginac.de>
1124 * Version 1.1.9 released.
1126 2004-10-28 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1128 * src/Makefile.in: Let config.status set LDFLAGS.
1130 2004-10-27 Peter Breitenlohner <peb@mppmu.mpg.de>
1132 * cln.pc.in: Fix typo.
1133 * Makefile.in (INSTALL_SCRIPT): Added, to be used for scripts like
1134 cln-config. Allows us to do special things to binaries, like
1135 installing them with install -s.
1136 * doc/Makefile.in: add/remove the cln.info from the installed
1137 $(infodir)/dir unless this is debian install-info (code copied from
1138 what GNU automake would produce).
1140 2004-10-26 Richard B. Kreckel <kreckel@ginac.de>
1142 * src/integer/input/cl_I_read_stream.cc (read_integer): Fix a bug
1143 that caused radix specifiers to not work when reading from a stream.
1144 * src/rational/input/cl_RA_read_stream.cc (read_rational): Likewise.
1145 * src/real/input/cl_R_read_stream.cc (read_real): Likewise.
1146 * src/float/input/cl_F_read_stream.cc (read_float): Likewise.
1147 * src/complex/input/cl_N_read_stream.cc (read_complex): Likewise.
1149 2004-10-25 Richard B. Kreckel <kreckel@ginac.de>
1151 * src/base/cl_low.h: Add mulu64 assembler macro for ia64.
1153 2004-10-24 Richard B. Kreckel <kreckel@ginac.de>
1155 * src/base/cl_low.h: Add mul and div macros for x86_64.
1157 2004-10-23 Richard B. Kreckel <kreckel@ginac.de>
1159 * src/integer/conv/cl_I_from_digits.cc (digits_to_I): Fix thinko in
1160 new code for base power of two.
1162 2004-10-22 Richard B. Kreckel <kreckel@ginac.de>
1164 * src/integer/conv/cl_I_to_digits (I_to_digits): Fix an elusive stack
1165 overwriting problem. That was the real cause for Debian bug#246319.
1166 * src/integer/output/cl_I_print.cc (print_integer): Revert workaround
1167 for the bug fixed above.
1169 2004-10-20 Richard B. Kreckel <kreckel@ginac.de>
1171 * include/cln/types.h: Use 64 bit digits on x86_64 CPU.
1173 2004-10-12 Richard B. Kreckel <kreckel@ginac.de>
1175 * src/integer/conv/cl_I_from_digits.cc (digits_to_I): Speedup when
1176 the base is a power of two.
1178 2004-10-05 Richard B. Kreckel <kreckel@ginac.de>
1180 * src/integer/conv/cl_I_to_digits.cc (I_to_digits): Fix bug in base 32.
1182 2004-09-27 Richard B. Kreckel <kreckel@ginac.de>
1184 Support for little-endian Mips, second shot
1185 * src/base/digitseq/cl_asm_mipsel_.cc: New file...
1186 * src/base/digitseq/cl_asm_cc: ...used here.
1187 * src/base/digitseq/cl_asm.h: Include cl_asm_mips.h for any endianness.
1188 * include/cln/object.h: Set alignment for mipsel explicitly.
1190 2004-09-05 Richard B. Kreckel <kreckel@ginac.de>
1192 Support for little-endian Mips
1193 * include/cln/config.h.in: Add __mipsel__.
1194 * include/cln/modules.h: For Mips, this is endianness-agnostic.
1195 * src/base/digitseq/cl_asm_.cc, src/base/digitseq/cl_asm.h:
1196 Mask out assembler for little-endian Mips.
1198 2004-08-30 Bruno Haible <bruno@clisp.org>
1200 * benchmarks/timebench2.sh: Multiply all repeat counts by 100.
1201 * benchmarks/timebench2.results: Add recent PowerPC G4 results.
1203 2004-08-26 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1205 * examples/e.cc: remove extra semicolon.
1207 2004-08-25 Bruno Haible <bruno@clisp.org>
1209 * autoconf/ltmain.sh: Upgrade to libtool-1.5.6.
1210 * m4/libtool.m4: New file, from libtool-1.5.6 with modifications:
1211 2004-08-22 Bruno Haible <bruno@clisp.org>
1212 * m4/libtool.m4: Add support for Comeau C++ on Linux.
1213 Reported by Prof. Roberto Bagnara <bagnara@cs.unipr.it>.
1214 * autoconf/aclocal.m4: Regenerate.
1216 2004-08-19 Bruno Haible <bruno@clisp.org>
1218 * include/cln/modules.h (CL_GLOBALIZE_JUMP_LABEL, CL_JUMP_TO): When
1219 converting a label to a string, use ASM_UNDERSCORE_PREFIX. Needed on
1221 Reported by Darren Bane <darren.bane@ul.ie>.
1223 2004-07-01 Richard B. Kreckel <kreckel@ginac.de>
1225 * Version 1.1.8 released.
1227 2004-06-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1229 * src/base/cl_macros.h: alloca(3) has size_t argument type.
1231 2004-06-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1233 * include/cln/floatformat.h: Do define a type here.
1235 2004-06-27 Richard B. Kreckel <kreckel@ginac.de>
1237 * include/cln/modules.h (CL_JUMP_TO): Fix AMD64 brokenness.
1239 2004-06-23 Bruno Haible <bruno@clisp.org>
1241 * configure.ac: Pretend ftime() is not available. Needed by
1244 2004-06-21 Ralf Stephan <ralf@ark.in-berlin.de>
1246 * doc/cln.tex: Document jacobi, isprobprime and nextprobprime.
1248 2004-06-18 Richard B. Kreckel <kreckel@ginac.de>
1250 * rational/transcendental/cl_RA_logp.cc: fix bug where base is
1251 reciprocal of an integer.
1252 Reported by Niklas Knutsson <nq@altern.org>.
1254 2004-06-18 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1256 * src/complex/ring/cl_C_ring.cc, src/integer/ring/cl_I_ring.cc,
1257 src/rational/ring/cl_RA_ring.cc, src/real/ring/cl_R_ring.cc:
1258 Make template specializations explicit.
1260 2004-06-17 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1262 * src/complex/input/cl_N_read.cc, src/float/input/cl_F_read.cc,
1263 src/integer/input/cl_I_read.cc, src/rational/input/cl_RA_read.cc,
1264 src/real/input/cl_R_read.cc: Remove unused labels.
1266 2004-06-17 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1268 * benchmarks/timebench1.cc, benchmarks/timebench2a.LiDIA.cc,
1269 benchmarks/timebench2a.cc, benchmarks/timebench2ap.cc,
1270 benchmarks/timebench2b.LiDIA.cc, benchmarks/timebench2b.cc,
1271 examples/atan_recip.cc, examples/atanh_recip.cc,
1272 examples/contfrac.cc, examples/e.cc, examples/legendre.cc,
1273 examples/lucaslehmer.cc, examples/pi.cc, include/cln/GV.h,
1274 include/cln/SV.h, include/cln/malloc.h, include/cln/modules.h,
1275 include/cln/object.h, include/cln/string.h, src/base/cl_abort.cc,
1276 src/base/cl_alloca.h, src/base/cl_malloc.cc,
1277 src/base/random/cl_random_from.cc,
1278 src/base/string/cl_spushstring_append.cc,
1279 src/base/string/cl_spushstring_push.cc,
1280 src/base/string/cl_st_debug.cc,
1281 src/base/string/input/cl_st_gettoken.cc,
1282 src/complex/input/cl_N_read.cc, src/float/input/cl_F_read.cc,
1283 src/float/output/cl_F_dprint.cc, src/integer/input/cl_I_read.cc,
1284 src/rational/input/cl_RA_read.cc,
1285 src/real/format-output/cl_fmt_integer.cc,
1286 src/real/format-output/cl_fmt_paddedstring.cc,
1287 src/real/input/cl_R_read.cc, src/timing/cl_t_current.cc,
1288 src/timing/cl_t_current2.cc, tests/exam.cc, tests/tests.cc,
1289 tests/timeLFRAmul.cc, tests/timeLFatan-compare.cc,
1290 tests/timeLFatan.cc, tests/timeLFatanh-compare.cc,
1291 tests/timeLFatanh.cc, tests/timeLFcos-compare.cc, tests/timeLFcos.cc,
1292 tests/timeLFcosh.cc, tests/timeLFexp-compare.cc, tests/timeLFexp.cc,
1293 tests/timeLFln-compare.cc, tests/timeLFln.cc,
1294 tests/timeLFsin-compare.cc, tests/timeLFsin.cc, tests/timeLFsinh.cc,
1295 tests/timeLFsqrt.cc, tests/timeMImisc5.cc, tests/timeMIpow2div.cc,
1296 tests/timeMIpow2recip.cc, tests/timeRALFdiv.cc, tests/timeRAtoLF.cc,
1297 tests/timeUPMImul.cc, tests/timecatalan.cc, tests/timediv.cc,
1298 tests/timediv2adic-compare.cc, tests/timediv2adic.cc,
1299 tests/timeeuler.cc, tests/timeexp1.cc, tests/timefact.cc,
1300 tests/timegcd.cc, tests/timemul-compare.cc, tests/timemul.cc,
1301 tests/timepi.cc, tests/timeprint-compare.cc, tests/timeprint.cc,
1302 tests/timerecip2adic-compare.cc, tests/timerecip2adic.cc,
1303 tests/timesqrt.cc, tests/timesqrtmodp.cc, tests/timesquare.cc,
1304 tests/timezeta3.cc: Change all C include headers to ISO style
1307 2004-06-10 Richard B. Kreckel <kreckel@ginac.de>
1309 * examples/perfnum.cc: update to presumed 41st Mersenne prime.
1311 2004-05-02 Richard B. Kreckel <kreckel@ginac.de>
1313 * Version 1.1.7 released.
1315 2004-05-02 Richard B. Kreckel <kreckel@ginac.de>
1317 * examples/pi.cc and examples/pi.1: New files.
1318 * examples/Makefile.in: Build the pi executable.
1320 2004-05-01 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1322 * src/Makefile.in: Fix for parallel build: wait for subdir objects to
1323 be finished before creating the library.
1325 2004-04-30 Richard B. Kreckel <kreckel@ginac.de>
1327 * src/integer/output/cl_I_print.cc (print_integer): workaround
1328 GCC compiler bug (cf. Debian bug#246319).
1330 2004-03-20 Ralf Wildenhues <Ralf.Wildenhues@gmx.de>
1332 * m4/gmp.m4 (CL_GMP_CHECK): Do not lose LIBS setting with config.cache
1335 2004-03-08 Bruno Haible <bruno@clisp.org>
1337 * src/float/lfloat/elem/cl_LF_mul.cc (operator*): Fix the second
1338 underflow condition.
1339 * src/float/lfloat/algebraic/cl_LF_sqrt.cc (sqrt): Fix a bug with large
1340 uexp whereby SQRT of MOST-POSITIVE-LONG-FLOAT was less than 1.
1342 2004-03-04 Richard B. Kreckel <kreckel@ginac.de>
1344 * Makefile.in (install): Add ${srcdir} for cln.m4.
1345 * m4/gmp.m4: quote macro names.
1346 Reported by Ralf Wildenhues <Ralf.Wildenhues@gmx.de>.
1348 2004-01-01 Richard B. Kreckel <kreckel@ginac.de>
1350 * Version 1.1.6 released.
1352 2004-01-01 Richard B. Kreckel <kreckel@ginac.de>
1354 * include/cln/univpoly.h, include/cln/univpoly_complex.h,
1355 include/cln//univpoly_integer.h, include/cln/univpoly_modint.h,
1356 include/cln/univpoly_rational.h, include/cln/univpoly_real.h,
1357 src/polynomial/elem/cl_UP_GF2.h, src/polynomial/elem/cl_UP_MI.h,
1358 src/polynomial/elem/cl_UP_gen.h, src/polynomial/elem/cl_UP_no_ring.cc,
1359 src/polynomial/elem/cl_UP_number.h (ldegree): New function.
1360 * doc/cln.tex: Document `ldegree'.
1362 2003-12-29 Richard B. Kreckel <kreckel@ginac.de>
1364 Rework of autoconfiscation infrastructure
1365 * autoconf/config.{guess,sub}: Update to GNU version 2003-10-07.
1366 * autoconf/ltmain.sh: Update to GNU version 1.4.3.
1367 * autoconf/autoconf: Remove (from now on we assume autoconf is
1368 installed properly on the sytem).
1369 * autoconf/autoconf.m4: Likewise.
1370 * autoconf/autoconf.m4f: Likewise.
1371 * autoconf/acgeneral.m4: Likewise.
1372 * autoconf/acspecific.m4: Likewise.
1373 * autoconf/aclocal.m4: Regenerate.
1374 * autoconf/acinclude.m4: Remove (while moving the macros...)
1375 * m4/gmp.m4: New file (...to here).
1376 * Makefile.devel: Update to new scheme.
1377 * configure.ac: Likewise.
1378 * include/cln/GV_integer.h: Assume template specializations work.
1379 * include/cln/GV_modinteger.h: Likewise.
1380 * include/cln/config.h.in: Likewise, and drop HAVE_BOOL.
1381 * src/base/cl_base_config.h.in: Drop support for obsolete ftime(3).
1382 * src/base/random/cl_random_from.cc: Likewise.
1383 * src/timing/cl_base_config.h.in: Likewise.
1384 * src/timing/cl_t_current.cc: Likewise.
1386 2003-12-27 Richard B. Kreckel <kreckel@ginac.de>
1388 * src/polynomial/cl_UP_gen.h (gen_minus): Fix case where first
1390 * src/polynomial/cl_UP_MI.h (modint_minus): Likewise.
1391 * src/polynomial/cl_UP_number.h (num_minus): Likewise.
1392 Reported by Munagala Ramanath <amberarrow@yahoo.com>.
1394 2003-12-02 Richard B. Kreckel <kreckel@ginac.de>
1396 * examples/perfnum.cc: update to presumed 40th Mersenne prime.
1398 2003-11-20 Christian Bauer <cbauer@ginac.de>
1400 Added pkg-config support
1401 * cln.pc.in: New file.
1402 * Makefile.in: Take care of cln.pc.
1403 * configure.ac: Likewise.
1405 2003-08-06 Richard B. Kreckel <kreckel@ginac.de>
1407 * src/numtheory/cl_nt_sqrtmodp.cc: #undef _R.
1408 Reported by Andrew Rechnitzer <A.Rechnitzer@ms.unimelb.edu.au>.
1410 2003-08-01 Richard Kreckel <kreckel@ginac.de>
1412 More dependent base resolution issues
1413 * src/base/hash/cl_hash.h (cl_heap_hashtable<T>::iterator()):
1414 portable syntactic simplification.
1415 * src/base/hash/cl_hashset.h: Preceed inherited members with this->.
1416 * src/base/hash/cl_hash1.h: Likewise for member functions.
1417 * src/base/hash/cl_hash2.h: Likewise.
1418 * src/base/hash/cl_hashuniq.h: Likewise.
1419 * src/base/hash/cl_hashuniqweak.h: Likewise.
1420 * src/base/hash/cl_hash.h: Revert explicit static member function
1421 lookup since that was GCC's fault.
1422 * src/base/hash/cl_hash2weak.h: Likewise.
1423 * src/base/hash/cl_hashuniqweak.h: Likewise.
1425 2003-06-29 Richard Kreckel <kreckel@ginac.de>
1427 Dependent base resolution needed for GCC-3.4
1428 * include/cln/GV.h: Preceed inherited members with this->.
1429 * include/cln/SV.h: Likewise.
1430 * include/cln/object.h: Likewise.
1431 * src/base/hash/cl_hash1.h: Likewise.
1432 * src/base/hash/cl_hash1weak.h: Likewise.
1433 * src/base/hash/cl_hash2.h: Likewise.
1434 * src/base/hash/cl_hashuniq.h: Likewise.
1435 * src/base/hash/cl_hash.h: Make lookup of static member function
1437 * src/base/hash/cl_hash2weak.h: Likewise.
1438 * src/base/hash/cl_hashuniqweak.h: Likewise.
1439 * src/modinteger/cl_MI.cc: Make shell-comment a C-comment. Geez.
1441 2003-02-24 Bruno Haible <bruno@clisp.org>
1443 * src/base/random/cl_random_from.cc (random_state::random_state): Add
1444 support for MacOS X.
1445 * src/modinteger/cl_MI.cc: #undef _R.
1446 Reported by Erann Gat <gat@jpl.nasa.gov>.
1448 2002-08-03 Joerg Arndt <jj@suse.de>
1450 * include/cln/config.h.in: Add support for x86_64 CPU.
1451 * include/cln/modules.h: Likewise.
1452 * include/cln/types.h: Likewise.
1453 * include/cln/object.h: Likewise.
1455 2002-06-08 Richard Kreckel <kreckel@ginac.de>
1457 * src/base/digitseq/cl_asm.h: ensure intCsize==16 when including
1458 m68k Assembler routines.
1459 * src/base/digitseq/cl_asm_.cc: Likewise.
1461 2002-05-28 Richard Kreckel <kreckel@ginac.de>
1463 * Version 1.1.5 released.
1465 2002-05-27 Richard Kreckel <kreckel@ginac.de>
1467 * include/cln/modules.h (CL_CONCATENATE): New macro.
1469 2002-05-10 Richard Kreckel <kreckel@ginac.de>
1471 * doc/cln.tex (Building the library): Update recommendations for
1472 compiling on Tru64 using g++ 3.0 and 3.1.
1473 * README: Update homepage.
1475 2002-05-05 Bruno Haible <bruno@clisp.org>
1477 * doc/cln.tex (Building the library): Give some recommendations for
1480 Force link-time references despite optimizations done by g++ 2.95
1482 * include/cln/modules.h (CL_FORCE_LINK): New macro.
1483 * Use CL_FORCE_LINK.
1484 * include/cln/GV_integer.h (cl_GV_I_debug_dummy): Likewise.
1485 * include/cln/GV_number.h (cl_GV_number_debug_dummy): Likewise.
1486 * include/cln/SV_number.h (cl_SV_number_debug_dummy): Likewise.
1487 * include/cln/SV_ringelt.h (cl_SV_ringelt_debug_dummy): Likewise.
1488 * include/cln/dfloat.h (cl_DF_debug_dummy): Likewise.
1489 * include/cln/ffloat.h (cl_FF_classes_dummy, cl_FF_debug_dummy):
1491 * include/cln/integer.h (cl_I_classes_dummy, cl_I_debug_dummy):
1493 * include/cln/lfloat.h (cl_LF_debug_dummy): Likewise.
1494 * include/cln/modinteger.h (cl_MI_debug_dummy): Likewise.
1495 * include/cln/rational.h (cl_RA_debug_dummy): Likewise.
1496 * include/cln/real.h (cl_R_debug_dummy): Likewise.
1497 * include/cln/ring.h (cl_ring_debug_dummy): Likewise.
1498 * include/cln/sfloat.h (cl_SF_classes_dummy, cl_SF_classes_dummy):
1500 * include/cln/string.h (cl_string_debug_dummy): Likewise.
1501 * include/cln/univpoly.h (cl_UP_debug_dummy): Likewise.
1502 * src/float/base/cl_ieee.h (cl_ieee_dummy_NNN): Likewise.
1504 Avoid g++ 3.1 warnings.
1505 * src/base/cl_offsetof.h (offsetof): Redefine each time.
1506 * src/base/digitseq/cl_DS.h: Include "cl_offsetof.h" after <gmp.h>.
1508 Avoid g++ 3.1 warnings.
1509 * src/base/hash/cl_hash.h (struct cl_heap_hashtable): Use typename
1511 * src/base/hash/cl_hash1.h (struct cl_heap_hashtable_1): typedef
1512 htxentry as a shortcut.
1513 * src/base/hash/cl_hash2.h (struct cl_heap_hashtable_2): Likewise.
1514 * src/base/hash/cl_hashset.h (struct cl_heap_hashtable_set): Likewise.
1515 * src/base/hash/cl_hashuniq.h (struct cl_heap_hashtable_uniq):
1518 2002-03-15 Bruno Haible <bruno@clisp.org>
1520 * cln.tex: Document problem with GNU make 3.77.
1521 Reported by Michael Somos <somos@grail.cba.csuohio.edu>.
1523 2002-02-16 Richard Kreckel <kreckel@ginac.de>
1525 * cln.m4: quote macro name.
1526 Pointed out by Roberto Bagnara.
1528 2002-01-20 Richard Kreckel <kreckel@ginac.de>
1530 * autoconf/config.{guess,sub}: Update to GNU version 2002-01-02.
1531 (the old one was broken on Linux/Mips.)
1533 2002-01-04 Richard Kreckel <kreckel@ginac.de>
1535 * autoconf/autoconf.m4f: get brutal in order to adhere to FHS.
1536 * Version 1.1.4 released.
1538 2002-01-03 Richard Kreckel <kreckel@ginac.de>
1540 * autoconf/acinclude.m4: revamp MPN-matcher.
1541 * autoconf/aclocal.m4: upgrade to autoconf-2.52 infrastructure,
1542 sync with CLisp from CVS.
1543 * autoconf/autoconf: Likewise.
1544 * autoconf/autoconf.m4f: Likewise (new file).
1545 * configure.ac: Likewise (new file, replaces configure.in).
1546 * configure.in: Likewise (deleted, replaced by configure.ac).
1547 * autoconf/config.{guess,sub}: Update to GNU version 2001-12-13.
1548 * src/Makefile.in: made VPATH safe for autoconf-2.52.
1549 * include/cln/config.h.in: Add __s390__.
1551 2001-12-31 Richard Kreckel <kreckel@ginac.de>
1553 * src/base/digitseq/cl_DS.h: <gmp.h> is not included extern "C"
1554 any more since GMP4 has some C++ support in it.
1556 2001-12-14 Richard Kreckel <kreckel@ginac.de>
1558 * include/cln/modules.h, include/cln/object.h: add support for
1560 * src/numtheory/cl_nt_sqrtmodp.cc: workaround for GCC2.x compiler-bug
1561 on s390, provided by Gerhard Tonn.
1563 2001-11-05 Richard Kreckel <kreckel@ginac.de>
1565 * autoconf/ltmain.sh: Upgrade to libtool-1.4.2.
1566 * autoconf/config.{guess,sub}: Update to GNU version 2001-09-07.
1567 * Version 1.1.3 released.
1569 2001-11-04 Bruno Haible <haible@clisp.cons.org>
1571 Interoperability with gcc-3.0 -fuse-cxa-atexit.
1572 * autoconf/aclocal.m4 (CL_GLOBAL_CONSTRUCTORS): Add test whether
1573 global destructors actually exist.
1574 * include/cln/modules.h (CL_PROVIDE, CL_PROVIDE_END, CL_PROVIDE_END):
1575 Don't hack the global destructors if there is no global destructors
1578 2001-11-03 Richard Kreckel <kreckel@ginac.de>
1580 * src/float/transcendental/cl_F_sinx.cc (sinx_naive): For small
1581 values of x, return square(x) instead of x.
1582 * src/float/transcendental/cl_F_sinhx.cc (sinhx_naive): Likewise.
1584 2001-07-25 Richard Kreckel <kreckel@ginac.de>
1586 * Version 1.1.2 released.
1588 2001-07-24 Richard Kreckel <kreckel@ginac.de>
1590 * src/base/hash/cl_hash.h: declare _cl_hashtable_iterator<htentry> a
1591 friend of cl_heap_hashtable<htentry>.
1593 2001-07-22 Richard Kreckel <kreckel@ginac.de>
1595 * src/float/base/cl_ieee.cc: try to do magic to the FPU only if
1596 _FPU_IEEE is really defined.
1597 * include/cln/modules.h: change assembler labels from `label' to
1598 `label:' on hppa, needed by Linux (see comment).
1599 * autoconf/acinclude.m4: new file (for storing CLN-specific macros).
1600 * Makefile.devel: adjusted.
1601 * autoconf/aclocal.m4: regenerate.
1602 * src/base/low/cl_low_mul.cc: moved POD variables that are declared
1603 extern "C" elsewhere out of the namespace.
1604 * src/base/low/cl_low_div.cc: Likewise.
1606 2001-06-08 Bruno Haible <haible@clisp.cons.org>
1608 * autoconf/config.{guess,sub}: Update to GNU version 2001-05-11.
1609 * autoconf/aclocal.m4: Upgrade to libtool-1.4.
1610 * autoconf/ltmain.sh: Likewise.
1611 * autoconf/ltconfig: Remove file.
1612 * autoconf/install-sh: New file.
1613 * configure.in: Add AC_CONFIG_AUX_DIR call.
1615 2001-06-05 Richard Kreckel <kreckel@ginac.de>
1617 * tests/tests.cc: resolve namespace ambiguity about strcmp().
1619 2001-05-31 Richard Kreckel <kreckel@ginac.de>
1621 * Version 1.1.1 released.
1623 2001-05-28 Richard Kreckel <kreckel@ginac.de>
1625 * cln/cln.tex: documented problems with shared library on Sparc
1626 using gcc older than 2.95.3.
1627 * configure.in: Fixed typos in versioning docu.
1629 2001-05-25 Bruno Haible <haible@clisp.cons.org>
1631 * src/base/digitseq/cl_asm_arm_.cc: Use #0x instead of #& to designate
1632 hexadecimal constants.
1634 2001-05-25 Richard Kreckel <kreckel@ginac.de>
1636 * autoconf/floatparam.c (double_wordorder_bigendian_p): new symbol.
1637 * src/float/dfloat/cl_DF.h: Check for double_wordorder_bigendian_p.
1638 * Removed LiDIA interface since that is now outdated (namespace cln)
1639 and maintained elsewhere.
1640 * Adjusted dates and final touches for 1.1.1.
1642 2001-05-19 Richard Kreckel <kreckel@ginac.de>
1644 * INSTALL: Update toolchain info: no egcs, some more platforms.
1645 * doc/cln.tex: Likewise.
1647 2001-05-18 Richard Kreckel <kreckel@ginac.de>
1649 * src/base/cl_low.h: prepended variables declared inside macros
1650 with underscore. Fixes equal_hashcode() on various platforms.
1652 2001-04-25 Richard Kreckel <kreckel@ginac.de>
1654 * src/base/cl_low.h: Added several checks if NO_ASM is defined, so
1655 this definition becomes actually useful. This is needed for
1656 compilation on Arm until somebody fixes the assembler files for Arm.
1657 * src/base/digitseq/cl_asm.h: Likewise.
1658 * src/base/digitseq/cl_asm_.cc: Likewise.
1659 * */Makefile.in: Added `override' in front of `CPPFLAGS +=' so
1660 one can say `make CPPFLAGS=-DFOOBAR'.
1662 2001-03-26 Arvid Norberg <c99ang@cs.umu.se>
1664 * src/base/random/cl_random_from.cc: ported to beos.
1666 2001-03-05 Richard Kreckel <kreckel@ginac.de>
1668 * include/cln/modules.h (CL_JUMP_TO): Fix IA64 brokenness.
1670 2001-01-28 Richard Kreckel <kreckel@ginac.de>
1672 * include/cln/number.h (cl_as_N): Remove bogus comment.
1674 2001-01-22 Richard Kreckel <kreckel@ginac.de>
1676 * configure.in: Make build in separate builddir possible (again).
1678 2001-01-22 Richard Kreckel <kreckel@ginac.de>
1680 * include/cln/*.h: Change signatures of all classes' methods
1681 cln::cl_foo::operator new(size_t, cl_foo*) to
1682 cln::cl_foo::operator new(size_t, void*) so one can declare
1683 std::vector<cln::cl_foo>, std::list<cln::cl_foo> etc. for
1684 certain STL implementations (like libstdc++-v3).
1686 2000-12-14 Richard Kreckel <kreckel@ginac.de>
1688 * Version 1.1 released.
1690 2000-12-13 Richard Kreckel <kreckel@ginac.de>
1692 * */*: cl_istream -> std::istream, cl_ostream -> std::ostream.
1694 2000-12-05 Richard Kreckel <kreckel@ginac.de>
1696 * Makefile.in, src/Makefile.in, doc/Makefile.in: Use mkdir -p.
1697 * include/cln/version.h.in, src/base/verion.cc: New files.
1698 * configure.in: Generate include/cln/version.h.
1699 * cln.m4: Rewrote it. Check result of cln-config without compiling.
1700 Do cross-check library version and header version information.
1702 2000-12-02 Christian Bauer <cbauer@ginac.de>
1704 * Makefile.in, src/Makefile.in, doc/Makefile.in: Added $DESTDIR.
1705 * cln.m4, cln.spec.in: some minor fixes with respect to RPM package
1708 2000-11-24 Richard Kreckel <kreckel@ginac.de>
1710 * */*: Removed problematic stdin, stdout and stderr definitions.
1711 Use std::cin, std::cout, std::cerr instead (obsoletes 2000-10-29).
1713 2000-11-20 Bruno Haible
1715 * cln-config.1: change title.
1717 2000-11-18 Richard Kreckel <kreckel@ginac.de>
1720 * doc/cln.tex: Document package tools cln-config and cln.m4.
1721 * Makefile.in: Care about cln.m4.
1723 2000-11-17 Richard Kreckel <kreckel@ginac.de>
1725 * cln-config.1: added manpage, as required by a couple of distros.
1726 * Makefile.in, doc/Makefile.in: target install depends on installdirs.
1728 2000-11-16 Richard Kreckel <kreckel@ginac.de>
1730 * autoconf/aclocal.m4 (CL_GMP_SET_UINTD): New macro...
1731 * configure.in: ...used here.
1732 * include/cln/config.h.in: Put in macros defined by CL_GMP_SET_UINTD...
1733 * include/cln/types.h: ...used here.
1734 * autoconf/acgeneral.m4, autoconf/aclocal.m4: Adhere to FHS.
1736 2000-11-13 Richard Kreckel <kreckel@ginac.de>
1738 * src/base/digitseq/cl_asm.h: Test if (intDsize==32) for MIPS and HPPA,
1739 in order to guard against an accidented configuration.
1740 * src/integer/conv/cl_I_to_digits.cc (table): member b_hoch_k of
1741 struct power_table_entry initialized as ULL instead of as UL, if
1742 intDsize==64 (caused misprinting on MIPS w/ GMP).
1743 * src/base/cl_macros.h (minus_bitm, bitc): implemented ULL, if
1745 * src/integer/bitwise/cl_I_mkfx.cc (mkf_extract): Likewise.
1746 * src/integer/conv/cl_I_from_L.cc (cl_I_from_L): Added trival
1747 generation of Bignum for intDsize==64 and a notreached-check at end.
1748 * autoconf/config.guess, autoconf/config.sub: updated from FSF.
1749 * include/cln/config.h.in: Prepared support for IA64.
1750 * include/cln/types.h: Likewise.
1751 * include/cln/object.h: Likewise.
1752 * include/cln/modules.h: Likewise.
1753 * src/base/cl_macros.h (nonreturning_function): Likewise (NUE's
1754 compiler claims __GNUC_MINOR__==9).
1756 2000-11-03 Richard Kreckel <kreckel@ginac.de>
1758 * src/base/cl_macros.h (bit, minus_bit): changed criterion for ULL from
1759 HAVE_DD to HAVE_FAST_LONGLONG.
1760 * src/base/cl_macros.h (bitm): implemented ULL, if HAVE_FAST_LONGLONG.
1761 * src/base/cl_low.h: actually no need to include "cln/types.h" here.
1762 * src/base/cl_low.h (logcount_64): always ULL, independent of HAVE_DD.
1763 * src/base/random/cl_UL_random.cc (random32): a is always ULL.
1765 2000-11-01 Richard Kreckel <kreckel@ginac.de>
1767 * include/cln/object.h (cl_combine): define additional signatures, if
1768 HAVE_LONGLONG is defined, in order to keep the compiler happy.
1769 * src/base/cl_macros.h: include "cln/types.h", since we need HAVE_DD...
1770 * src/base/cl_macros.h (bit): ...for this macro...
1771 * src/base/cl_macros.h (minus_bit): ...and this one.
1772 * src/base/cl_low.h: include "cln/types.h", since we need HAVE_DD...
1773 * src/base/cl_low.h (logcount_64): ...for this macro.
1774 * src/base/random/cl_UL_random.cc (random32): if HAVE_DD a is an ULL.
1775 * src/integer/gcd/cl_I_gcd_aux2.cc (floorDD): fixed algorithmic bug.
1776 that turned up when intDsize==32 and cl_word_size==64.
1777 * src/float/dfloat/elem/cl_DF_div.cc (operator/): fixed a missing cast
1778 to uint64 that turned up when intDsize==32 and cl_word_size==64.
1780 2000-10-29 Richard Kreckel <kreckel@ginac.de>
1782 * src/real/input/cl_R_read.cc, src/complex/input/cl_N_read.cc:
1783 #undef stderr, if it's defined so cln::stderr isn't confused.
1784 * src/base/input/cl_read_globals.cc: stdin should not be extern.
1786 2000-09-05 Richard Kreckel <kreckel@ginac.de>
1788 * include/cln/number.h (As): Fix it in namespace by suffixing `_As'
1789 to the appropiate method instead of prefixing `as_'.
1790 * src/complex/misc/cl_N_as.cc (cl_N_As): Likewise.
1791 * src/real/misc/cl_R_as.cc (cl_R_As): Likewise.
1792 * src/rational/misc/cl_RA_as.cc (cl_RA_As): Likewise.
1793 * src/integer/misc/cl_I_as.cc (cl_I_As): Likewise.
1794 * src/float/misc/cl_F_as.cc (cl_F_As): Likewise.
1795 * src/float/sfloat/misc/cl_SF_as.cc (cl_SF_As): Likewise.
1796 * src/float/lfloat/misc/cl_LF_as.cc (cl_LF_As): Likewise.
1797 * src/float/ffloat/misc/cl_FF_as.cc (cl_FF_As): Likewise.
1798 * src/float/dfloat/misc/cl_DF_as.cc (cl_DF_As): Likewise.
1800 2000-09-05 Richard Kreckel <kreckel@ginac.de>
1802 * src/complex/transcendental/cl_C_expt_C.cc (expt): fix logic for
1805 2000-08-30 Richard Kreckel <kreckel@ginac.de>
1807 * include/cln/number.h, cl_number::_as_cl_private_thing(): removed.
1808 Rearranged for a clearer distinction between macros and remaining
1809 identifiers, so Cint can parse it smoothly.
1811 2000-08-29 Richard Kreckel <kreckel@ginac.de>
1813 * include/cln/number.h, the(const cl_number& x): New template
1816 2000-08-29 Richard Kreckel <kreckel@ginac.de>
1818 * */*: Pushed CLN into a namespace `cln'. While doing so, the
1819 following identifiers got their poor-man's namespace (i.e. the
1820 prefix `cl_') stripped off:
1821 cl_catalanconst() -> catalanconst()
1822 cl_compare() -> compare()
1823 cl_cos_sin() -> cos_sin()
1824 cl_cos_sin_t -> cos_sin_t
1825 cl_cosh_sinh() -> cosh_sinh()
1826 cl_cosh_sinh_t -> cosh_sinh_t
1827 cl_decoded_dfloat -> decoded_dfloat
1828 cl_decoded_ffloat -> decoded_ffloat
1829 cl_decoded_float -> decoded_float
1830 cl_decoded_lfloat -> decoded_lfloat
1831 cl_decoded_sfloat -> decoded_sfloat
1832 cl_default_float_format -> default_float_format
1833 cl_default_print_flags -> default_print_flags
1834 cl_default_random_state -> default_random_state
1835 cl_double_approx() -> double_approx()
1836 cl_equal() -> equal()
1837 cl_equal_hashcode() -> equal_hashcode()
1838 cl_eulerconst() -> eulerconst()
1839 cl_find_modint_ring() -> find_modint_ring()
1840 cl_find_univpoly_ring() -> find_univ_poly_ring()
1841 cl_float_approx() -> float_approx
1842 cl_float_format() -> float_format()
1843 cl_float_format_t -> float_format_t
1844 cl_free_hook() -> free_hook()
1845 cl_hermite() -> hermite()
1846 cl_laguerre() -> laguerre()
1847 cl_legendre() -> legandre()
1848 cl_malloc_hook() -> malloc_hook()
1850 cl_tschebychev() -> tschebychev()
1852 NB: For functions these changes includes all signatures.
1853 * include/*: moved to include/cln/*, stripped `cl_' off filenames.
1854 * cln-config.in: new file.
1856 2000-08-26 Bruno Haible <haible@clisp.cons.org>
1858 * autoconf/acgeneral.m4 (AC_OUTPUT): Use braces in exec_prefix default
1861 2000-08-18 Bruno Haible <haible@clisp.cons.org>
1863 * include/cl_univpoly_modint.h: Fix typo.
1865 2000-07-13 Bruno Haible <haible@clisp.cons.org>
1867 * src/float/input/cl_F_read_stream.cc (number_char_p): Accept '_',
1868 used as precision marker for floats.
1869 Reported by Keith Briggs (in 1998) and Thomas Roessler.
1870 * src/integer/input/cl_I_read_stream.cc (number_char_p): Likewise.
1871 * src/rational/input/cl_RA_read_stream.cc (number_char_p): Likewise.
1872 * src/real/input/cl_R_read_stream.cc (number_char_p): Likewise.
1873 * src/complex/input/cl_N_read_stream.cc (number_char_p): Likewise.
1875 2000-06-22 Bruno Haible <haible@clisp.cons.org>
1877 * include/cl_object.h: Rename cl_word_size to cl_pointer_size.
1878 * include/cl_types.h (HAVE_FAST_LONGLONG): Also define on Irix6
1880 (cl_word_size): New macro.
1881 * src/float/sfloat/cl_SF.h: Use cl_pointer_size instead of
1884 2000-05-31 Bruno Haible <haible@clisp.cons.org>
1886 * tests/exam_I_floor.cc (integer_floor_tests): Add one more entry.
1887 From a sample that fails with gcc-2.95.2 on Sparc.
1888 * tests/exam_I_gcd.cc (integer_gcd_tests): Likewise.
1890 2000-05-30 Richard Kreckel <kreckel@ginac.de>
1892 * configure.in, autoconf/aclocal.m4 (CL_GMP_H_VERSION, CL_GMP_CHECK):
1894 * configure.in, include/cl_config.h.in (CL_VERSION, CL_VERSION_MINOR,
1895 CL_VERSION_PATCHLEVEL): New definitions.
1896 * autoconf/config.guess, autoconf/config.sub, autoconf/ltconfig,
1897 autoconf/ltmain.sh: updated from FSF (libtool 1.3.5, etc).
1898 * src/Makefile.in, configure.in: release-variables renamed from
1900 * configure.in: default to build both shared and static library
1901 (i.e. default to the most common behaviour).
1903 2000-05-29 Richard Kreckel <kreckel@ginac.de>
1905 * autoconf/aclocal.m4 (CL_CANONICAL_HOST): Added missing changequote
1906 environment around the patch of 2000-05-23.
1908 2000-05-29 Bruno Haible <haible@clisp.cons.org>
1910 * autoconf/aclocal.m4 (CL_PROG_INSTALL): Fix typo.
1911 Reported by Thomas Klausner <wiz@danbala.ifoer.tuwien.ac.at>.
1913 2000-05-27 Richard Kreckel <kreckel@ginac.de>
1915 * src/float/lfloat/algebraic/cl_LF_sqrt.cc,
1916 src/base/digitseq/cl_DS_sqrt.cc: Readjusted break-even points.
1918 2000-05-24 Richard Kreckel <kreckel@ginac.de>
1920 * autoconf/config.*: Updated to new version from FSF
1921 (the new libtool wants this).
1922 * src/Makefile.in: added $(LDFLAGS) to link step.
1923 * src/base/digitseq/cl_2DS_div.cc, cl_2DS_recip.cc: Readjusted
1926 2000-05-23 Bruno Haible <haible@clisp.cons.org>
1928 * autoconf/aclocal.m4 (CL_CANONICAL_HOST): Determine host_cpu,
1929 host_vendor, host_os correctly if $host has more than two hyphens.
1931 2000-05-19 Richard Kreckel <kreckel@ginac.de>
1933 * src/base/digitseq/cl_DS_mul.cc: Rearranged break-even points to
1934 better match present-day CPUs whenever GMP3 is used.
1935 * src/base/digitseq/cl_DS_div.cc: dto.
1936 * src/TUNING: Added comment about order of tuning.
1937 * configure, configure.in: Safer GMP3-detection.
1938 * INSTALL.generic: Clarified behaviour of --with-gmp.
1939 * autoconf/config.guess: updated from Clisp-2000-03-06 sources.
1941 2000-05-04 Richard Kreckel <kreckel@ginac.de>
1943 * gmp/: removed completely. From now on we are going to link
1944 externally against libgmp3.0 or above!
1945 * configure, configure.in, Makefile.in, */Makeflags: removed support
1946 of internal gmp 2.0.2, like $GMP_INCLUDES, which should be done by
1947 setting $CPPFLAGS instead.
1948 * Makefile.in: Added libtool inter-library dependency for -lgmp and
1949 conforming interface versioning (-version-info).
1950 * autoconf/ltconfig, autoconf/ltmain.sh: Updated to newer versions
1953 2000-02-22 Bruno Haible <haible@clisp.cons.org>
1955 * src/base/digitseq/cl_asm_mips_.cc: Starting at argument 5 the
1956 parameter passing was changed for the MIPS n32 ABI.
1958 2000-01-24 Richard Kreckel <kreckel@ginac.de>
1960 * gmp/*: Replaced the complete mpn sources with the ones from
1961 Debian since they are maintained while the ones from FSF
1962 aren't and there were problems on some architectures, PowerPC
1963 in particular. See the file gmp/README.CLN. This way the
1964 hard links in this directory have vanished, they were causing
1965 trouble for people working in AFS. This became necessary for
1966 Debian, because there it woudn't compile on PPC.
1968 2000-01-13 Richard Kreckel <kreckel@ginac.de>
1970 * Version 1.0.3 released.
1972 2000-01-13 Richard Kreckel <kreckel@ginac.de>
1974 * src/base/cl_macros.h (nonreturning_function): For egcs and newer
1975 use __attribute__ ((__noreturn__)) instead of the __volatile__
1977 (nonreturning): Remove macro.
1978 * include/*: Minor fixes to stop -ansi -pedantic from complaining.
1979 * include/cl_integer.h: (doublefactorial): New declaration.
1980 * src/integer/misc/combin/cl_I_doublefactorial.cc: New file.
1982 1999-12-18 Bruno Haible <haible@clisp.cons.org>
1984 * autoconf/acgeneral.m4 (AC_ARG_PROGRAM): Create conftestsed using
1986 * autoconf/ltconfig: Improve support for recent FreeBSD 3.
1987 * include/cl_GV.h (cl_GV_vectorops): Change return type from 'T' to
1988 'const T', to match definition in src/vector/cl_GV_number.cc.
1989 Reported by Duncan Simpson <dps@io.stargate.co.uk>.
1990 * gmp/mpn/Makefile.in (.S.lo): Use 'if', not '&&', because '&&' may
1991 yield return code 1.
1993 1999-09-07 Bruno Haible <haible@clisp.cons.org>
1995 * Version 1.0.2 released.
1997 1999-09-06 Bruno Haible <haible@clisp.cons.org>
1999 * src/rational/cl_RA.h (integerp, ratiop): Instead of returning a
2000 boolean expression, write alternatives ending with either
2001 "return cl_true;" or "return cl_false;". This way, g++ does a
2002 better job inlining it.
2003 * src/float/cl_F.h (longfloatp): Likewise.
2004 * src/real/cl_R.h (rationalp, integerp, floatp): Likewise.
2005 * src/complex/cl_C.h (realp, complexp): Likewise.
2007 1999-09-05 Bruno Haible <haible@clisp.cons.org>
2009 * include/cl_integer.h (cl_equal_hashcode): New declaration.
2010 * include/cl_rational.h (cl_equal_hashcode): New declaration.
2011 * include/cl_sfloat.h (cl_equal_hashcode): New declaration.
2012 * include/cl_ffloat.h (cl_equal_hashcode): New declaration.
2013 * include/cl_dfloat.h (cl_equal_hashcode): New declaration.
2014 * include/cl_lfloat.h (cl_equal_hashcode): New declaration.
2015 * include/cl_float.h (cl_equal_hashcode): New declaration.
2016 * include/cl_real.h (cl_equal_hashcode): New declaration.
2017 * include/cl_complex.h (cl_equal_hashcode): New declaration.
2018 * src/base/cl_N.h (equal_hashcode_low, equal_hashcode_one): New macros.
2019 * src/integer/misc/cl_I_eqhashcode.cc: New file.
2020 * src/rational/misc/cl_RA_eqhashcode.cc: New file.
2021 * src/float/sfloat/misc/cl_SF_eqhashcode.cc: New file.
2022 * src/float/ffloat/misc/cl_FF_eqhashcode.cc: New file.
2023 * src/float/dfloat/misc/cl_DF_eqhashcode.cc: New file.
2024 * src/float/lfloat/misc/cl_LF_eqhashcode.cc: New file.
2025 * src/float/misc/cl_F_eqhashcode.cc: New file.
2026 * src/real/misc/cl_R_eqhashcode.cc: New file.
2027 * src/complex/misc/cl_C_eqhashcode.cc: New file.
2028 * doc/cln.tex: Document `cl_equal_hashcode'.
2030 1999-09-05 Bruno Haible <haible@clisp.cons.org>
2032 * include/cl_ring.h (cl_number_ring_ops): Add `contains' member.
2033 (cl_number_ring): New class.
2034 (cl_specialized_number_ring<T>): Inherit from cl_number_ring.
2035 (instanceof): New function.
2036 * src/integer/ring/cl_I_ring.cc (cl_I_p): New function.
2037 * src/integer/misc/cl_I_as.cc (cl_I_p): Add comment.
2038 * src/rational/ring/cl_RA_ring.cc (cl_RA_p): New function.
2039 * src/rational/misc/cl_RA_as.cc (cl_RA_p): Add comment.
2040 * src/real/ring/cl_R_ring.cc (cl_R_p): New function.
2041 * src/real/misc/cl_R_as.cc (cl_R_p): Add comment.
2042 * src/complex/ring/cl_C_ring.cc (cl_N_p): New function.
2043 * src/complex/misc/cl_N_as.cc (cl_N_p): Add comment.
2044 * doc/cln.tex: Document `instanceof'.
2046 1999-09-05 Bruno Haible <haible@clisp.cons.org>
2048 * include/cl_rational.h (numerator, denominator): New declarations.
2049 * src/rational/elem/cl_RA_numerator.cc: New file.
2050 * src/rational/elem/cl_RA_denominator.cc: New file.
2051 * include/cl_integer.h (numerator, denominator): New inline functions.
2052 * doc/cln.tex: Document `numerator' and `denominator'.
2054 1999-09-05 Bruno Haible <haible@clisp.cons.org>
2056 * src/rational/algebraic/cl_RA_rootp.cc (rootp): Fix endless loop
2057 in the integer case.
2058 * src/rational/algebraic/cl_RA_rootp_I.cc (rootp): Likewise.
2060 1999-09-05 Bruno Haible <haible@clisp.cons.org>
2062 * include/cl_config.h.in: Support for sparc64 CPU.
2063 * include/cl_modules.h: Likewise.
2064 * include/cl_types.h: Likewise.
2065 * include/cl_object.h: Likewise.
2066 * include/cl_GV.h: Likewise.
2067 * src/Makefile.in: Likewise.
2068 * src/base/cl_alloca.h: Likewise.
2069 * src/base/cl_macros.h: Likewise.
2070 * src/base/cl_sysdep.h: Likewise.
2071 * src/base/cl_low.h: Likewise.
2072 * src/base/digitseq/cl_asm.h: Likewise.
2073 * src/base/digitseq/cl_asm_.cc: Likewise.
2074 * src/base/digitseq/cl_asm_sparc64.h: New file.
2075 * src/base/digitseq/cl_asm_sparc64_.cc: New file.
2076 * src/modinteger/cl_MI_int.h: Support for sparc64 CPU.
2077 * src/polynomial/elem/cl_UP_no_ring.cc: Likewise.
2078 * src/polynomial/elem/cl_UP_GF2.h: Likewise.
2079 * src/polynomial/elem/cl_asm_GF2.cc: Likewise.
2081 1999-09-04 Bruno Haible <haible@clisp.cons.org>
2083 * src/base/digitseq/cl_asm_sparc_.cc (orc2_loop_up, orc2_loop_down):
2084 Use the `orn' instruction.
2086 1999-08-14 Bruno Haible <haible@clisp.cons.org>
2088 Assume all platforms have <stdlib.h> and clock_t.
2089 * configure.in: Don't call CL_STDLIB_H and CL_CLOCK_T.
2090 * src/base/cl_base_config.h.in (CLOCK_T): Remove definition.
2091 * src/base/random/cl_random_from.cc: Use clock_t instead of CLOCK_T.
2092 * src/timing/cl_t_config.h.in (CLOCK_T): Remove definition.
2093 * src/timing/cl_t_current2.cc: Use clock_t instead of CLOCK_T.
2095 1999-07-18 Bruno Haible <haible@clisp.cons.org>
2097 * gmp/config.guess: Link to autoconf/config.guess.
2098 gmp/config.sub: Link to autoconf/config.sub.
2099 Needed for Win32 platforms.
2101 1999-07-17 Bruno Haible <haible@clisp.cons.org>
2103 * autoconf/aclocal.m4 (CL_CANONICAL_HOST_CPU): Distinguish "sparc" and
2104 "sparc64" according to the C compiler, not the uname result.
2106 1999-06-17 Bruno Haible <haible@clisp.cons.org>
2108 * src/base/digitseq/cl_asm_sparc_.cc (compare_loop_up): Fix
2109 COUNTER_LOOPS version, fortunately not used yet.
2111 * include/cl_modules.h: Prepare for gcc version 3.
2113 1999-06-12 Bruno Haible <haible@clisp.cons.org>
2115 * src/rational/elem/cl_RA_plus.cc, src/rational/elem/cl_RA_minus.cc:
2116 Change the last call from I_I_to_RT to I_I_to_RA.
2118 1999-06-09 Bruno Haible <haible@clisp.cons.org>
2120 * Version 1.0.1 released.
2122 1999-06-09 Bruno Haible <haible@clisp.cons.org>
2124 * src/integer/cl_I.h (pFN_maxlength_digits_at): Define also when
2127 1999-06-08 Bruno Haible <haible@clisp.cons.org>
2129 * autoconf/intparam.c (printf_underscored): Change argument type to
2131 * include/cl_modules.h (CL_OUTPUT_LABEL, CL_JUMP_TO): New macros.
2132 (CL_PROVIDE, CL_PROVIDE_END): Use them.
2133 * include/cl_string.h (cl_heap_string::operator new): Return 1, not 0.
2134 * include/cl_GV.h (cl_GV_inner<T>::operator new): Likewise.
2135 * src/base/ring/cl_no_ring.cc (dummy_canonhom, dummy_expt_pos): Don't
2136 cast a cl_I to void here. Works around a bug in g++-2.95.
2137 * src/complex/misc/cl_C_class.cc: Include "cl_C.h".
2138 * src/polynomial/elem/cl_UP_no_ring.cc (dummy_canonhom,
2139 dummy_expt_pos): Don't cast a cl_I to void here. Works around a bug
2141 * src/polynomial/elem/cl_asm_sparc_GF2.cc (DECLARE_FUNCTION): New
2143 * src/rational/misc/cl_RA_class.cc: Include "cl_RA.h".
2144 * src/vector/cl_GV_I.cc (cl_heap_GV_I_general::operator new,
2145 DEFINE_cl_heap_GV_I_bits): Return 1, not 0.
2146 * src/vector/cl_GV_number.cc (cl_heap_GV_number_general::operator new):
2149 1999-06-01 Bruno Haible <haible@clisp.cons.org>
2151 * autoconf/aclocal.m4 (CL_CANONICAL_HOST_CPU): Canonicalize alpha
2154 1999-05-29 Bruno Haible <haible@clisp.cons.org>
2156 * src/base/digitseq/cl_asm_i386_.cc (DECLARE_FUNCTION): Treat
2157 OpenBSD like NetBSD.
2158 * src/base/digitseq/cl_asm_sparc_.cc (DECLARE_FUNCTION): Likewise.
2159 * src/base/digitseq/cl_asm_m68k_.cc (DECLARE_FUNCTION): Treat
2160 OpenBSD like NetBSD, and Linux/ELF like SVR4.
2162 1999-05-16 Bruno Haible <haible@clisp.cons.org>
2164 * src/base/cl_low.h (integerlength32) [__rs6000__]: Use old assembler
2165 syntax on AIX systems and new assembler syntax on non-AIX systems.
2167 1999-05-01 Bruno Haible <haible@clisp.cons.org>
2169 * autoconf/config.guess, autoconf/config.sub: Upgrade to newest
2170 version from GNU CVS.
2172 1999-04-24 Bruno Haible <haible@clisp.cons.org>
2174 * src/integer/bitwise/cl_I_logand.cc (logand): Optimize the case when
2175 either operand is a positive fixnum, O(1) instead of O(N).
2176 * src/integer/bitwise/cl_I_lognand.cc (lognand): Likewise.
2177 * src/integer/bitwise/cl_I_logandc2.cc (logandc2): Likewise for the
2180 1999-04-14 Bruno Haible <haible@clisp.cons.org>
2182 * autoconf/aclocal.m4 (CL_GLOBAL_CONSTRUCTORS): Add check whether
2183 ctor/dtor needs to be exported.
2184 * include/cl_config.h.in (CL_NEED_GLOBALIZE_CTORDTOR): New macro.
2185 * include/cl_modules.h (CL_GLOBALIZE_JUMP_LABEL): Renamed from
2187 (CL_GLOBALIZE_LABEL): New macro.
2188 (CL_GLOBALIZE_CTORDTOR_LABEL): Renamed from CL_GLOBALIZE_ASM_LABEL.
2189 (CL_PROVIDE): Update.
2191 1999-04-12 Bruno Haible <haible@clisp.cons.org>
2193 * src/Makefile.in ($(ASMFILES_S)): On HPPA, ignore preprocessing
2194 errors ("unterminated string or character constant").
2195 ($(ASMFILES_LO)): On HPPA, try with various settings of
2196 COMPILER_PATH, in order to try /usr/ccs/bin/as and /bin/as.
2198 1999-04-11 Bruno Haible <haible@clisp.cons.org>
2200 * INSTALL: Mention gmp problems on MIPS.
2201 * doc/cln.tex: Likewise.
2203 1999-03-24 Mumit Khan <khan@xraylith.wisc.edu>
2205 * src/Makefile.in (SUBDIRS): Filter out CVS and RCS directories from
2207 * include/cl_modules.h (CL_GLOBALIZE_LABEL): Define for Win32.
2208 (CL_GLOBALIZE_ASM_LABEL): New macro.
2209 (CL_PROVIDE): Use it.
2210 * src/base/random/cl_random_from.cc: Handle WIN32.
2211 * src/timing/cl_t_current.cc: Likewise.
2213 1999-03-15 Bruno Haible <haible@clisp.cons.org>
2215 * autoconf/intparam.c (main7): Use %lX instead of %X for a `long'.
2216 (main8): Adapt for C++.
2218 1999-03-09 Bruno Haible <haible@clisp.cons.org>
2220 * INSTALL: Mention egcs-1.1 problems on Sparc.
2221 * doc/cln.tex: Likewise.
2223 1999-03-08 Bruno Haible <haible@clisp.cons.org>
2225 * autoconf/aclocal.m4 (CL_FPU_CONTROL): Fix the "checking for"
2228 1999-02-25 Bruno Haible <haible@clisp.cons.org>
2230 * autoconf/aclocal.m4: In test programs, declare `int main()', not
2233 * lidia-interface/src/interfaces/integers/cln/bigint.c
2234 (bigint_to_string): Fix for negative arguments.
2236 * src/base/cl_low.h: Check for `__sparc__', not `SPARC'.
2237 * src/base/cl_alloca.h: Likewise.
2239 * src/base/cl_low.h: Eliminate CLISP style "# " comments.
2240 * src/base/digitseq/cl_asm_arm_.cc,
2241 src/base/digitseq/cl_asm_mips_.cc,
2242 src/float/dfloat/elem/cl_DF_mul.cc: Likewise.
2244 * src/modinteger/cl_MI_pow2.h,
2245 src/modinteger/cl_MI_pow2m1.h,
2246 src/modinteger/cl_MI_pow2p1.h: Workaround g++-2.7.2 inlining bug.
2248 1999-01-18 Bruno Haible <haible@clisp.cons.org>
2250 * autoconf/acgeneral.m4,
2251 autoconf/acspecific.m4: Upgrade to autoconf-2.13.
2252 * autoconf/config.guess, autoconf/config.sub: Likewise.
2253 * autoconf/aclocal.m4 (CL_ALLOCA): Test for _MSC_VER and alloca being
2254 a macro. Use ${ac_objext}.
2255 * src/base/cl_macros.h (alloca): Put _MSC_VER test before the others,
2256 conforming with CL_ALLOCA.
2258 1999-01-12 Bruno Haible <haible@clisp.cons.org>
2260 * Version 1.0 released.