mirror of
https://github.com/lcn2/calc.git
synced 2025-08-22 01:23:28 +03:00
Compare commits
13 Commits
2.11.0t9.4
...
2.11.0t10.
Author | SHA1 | Date | |
---|---|---|---|
|
2c9b160dc5 | ||
|
fbd3a79eba | ||
|
025b5e58d6 | ||
|
160f4102ab | ||
|
306e031f03 | ||
|
6cfe9696ce | ||
|
97ed812cb9 | ||
|
6254c4a14c | ||
|
c7c0de97f2 | ||
|
96c34adee3 | ||
|
86c8e6dcf1 | ||
|
58d32c68f9 | ||
|
7d0b761de3 |
50
BUGS
50
BUGS
@@ -31,23 +31,19 @@ The calc web site is located at:
|
|||||||
If you have tried all of the above and things still are not right,
|
If you have tried all of the above and things still are not right,
|
||||||
then it may be time to send in a bug report. You can send bug reports to:
|
then it may be time to send in a bug report. You can send bug reports to:
|
||||||
|
|
||||||
calc-tester@postofc.corp.sgi.com
|
calc-bugs at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
When you send your report, please include the following information:
|
When you send your report, please include the following information:
|
||||||
|
|
||||||
* a description of the problem
|
* a description of the problem
|
||||||
|
|
||||||
* the version of calc you are using (if you cannot get calc
|
* the version of calc you are using (if you cannot get calc
|
||||||
it to run, then send us the 4 #define lines from version.c)
|
it to run, then send us the 4 #define lines from version.c)
|
||||||
|
|
||||||
* if you modified calc from an official patch, send me the mods you made
|
* if you modified calc from an official patch, send me the mods you made
|
||||||
|
|
||||||
* the type of system you were using
|
* the type of system you were using
|
||||||
|
|
||||||
* the type of compiler you were using
|
* the type of compiler you were using
|
||||||
|
|
||||||
* any compiler warnings or errors that you saw
|
* any compiler warnings or errors that you saw
|
||||||
|
|
||||||
* cd to the calc source directory, and type:
|
* cd to the calc source directory, and type:
|
||||||
|
|
||||||
make debug > debug.out 2>&1 (sh, ksh, bash users)
|
make debug > debug.out 2>&1 (sh, ksh, bash users)
|
||||||
@@ -62,13 +58,18 @@ Stack traces from core dumps are useful to send as well.
|
|||||||
Send any comments, compiler warning messages, suggestions and most
|
Send any comments, compiler warning messages, suggestions and most
|
||||||
importantly, fixes (in the form of a context diff patch) to:
|
importantly, fixes (in the form of a context diff patch) to:
|
||||||
|
|
||||||
calc-tester@postofc.corp.sgi.com
|
calc-tester at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
|
You should use the above calc-bugs address for bug reports, if you are
|
||||||
|
not currently a member of the calc-tester mailing list.
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
Known bugs:
|
Known bugs:
|
||||||
|
|
||||||
* Calc does not support the #! exec method. For example of the
|
* Calc does not support the #! exec method. For example of the
|
||||||
following is placed in an executable file (assume the path to
|
following is placed in an executable file (assume the path to
|
||||||
calc is correct) called /tmp/xyzzy:
|
calc is correct) called /tmp/xyzzy:
|
||||||
|
|
||||||
@@ -105,12 +106,30 @@ Known bugs:
|
|||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
Other items of note:
|
Problems with known work-a-rounds:
|
||||||
|
|
||||||
* There is a bug in gcc-2.95 that causes calc, when compiled with -O2,
|
* There is a bug in gcc-2.95 that causes calc, when compiled with -O2,
|
||||||
to fail the regression test. The work-a-round is to compile with -O
|
to fail the regression test. The work-a-round is to compile with -O
|
||||||
or to use gcc-2.96 or later.
|
or to use gcc-2.96 or later.
|
||||||
|
|
||||||
|
* Solaris cc somtimes barfs while compiling zrand.c. In particular, calc
|
||||||
|
barfs on on the SVAL macro. The work-a-round is to use the Solaric cc
|
||||||
|
Makefile set sets -DFORCE_STDC. I.e,:
|
||||||
|
|
||||||
|
CCWARN=
|
||||||
|
CCOPT= ${DEBUG} ${NO_SHARED}
|
||||||
|
CCMISC= -DFORCE_STDC
|
||||||
|
#
|
||||||
|
CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
|
ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
|
#
|
||||||
|
LCFLAGS=
|
||||||
|
LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
|
ILDFLAGS=
|
||||||
|
#
|
||||||
|
LCC= cc
|
||||||
|
CC= ${PURIFY} ${LCC}
|
||||||
|
|
||||||
* There is a bug in some versions of the Dec/Compaq cc for the Alpha
|
* There is a bug in some versions of the Dec/Compaq cc for the Alpha
|
||||||
where the following:
|
where the following:
|
||||||
|
|
||||||
@@ -120,7 +139,7 @@ Other items of note:
|
|||||||
|
|
||||||
fails because it puts a space inside the concatenated hex. Calc
|
fails because it puts a space inside the concatenated hex. Calc
|
||||||
has code that is affected by this bug. This bug has been reported
|
has code that is affected by this bug. This bug has been reported
|
||||||
to Compaq and may be fixed in the future. A work-a-round is to
|
to Compaq and may be fixed in the future. A work-a-round is to
|
||||||
compile with cc -std0 or to use a later version of their compiler.
|
compile with cc -std0 or to use a later version of their compiler.
|
||||||
|
|
||||||
* On a Digital UNIX V4.0F (Rev. 1229) on a 500 Mhz 21264, make check
|
* On a Digital UNIX V4.0F (Rev. 1229) on a 500 Mhz 21264, make check
|
||||||
@@ -141,11 +160,12 @@ Other items of note:
|
|||||||
it finally hangs at test 2000.
|
it finally hangs at test 2000.
|
||||||
|
|
||||||
The work-a-round is to compile calc without the optimizer. If this
|
The work-a-round is to compile calc without the optimizer. If this
|
||||||
happens to you, try compiling without -O and without -O2. I.e., in
|
happens to you, try compiling without -O and without -O2. I.e., in
|
||||||
the Makefile, set:
|
the Makefile, set:
|
||||||
|
|
||||||
DEBUG= -g
|
DEBUG= -g
|
||||||
|
|
||||||
or set:
|
* The sparcv9 support for 64 bit Solaris under gcc-2.96 is able
|
||||||
|
to compile calc, but calc dumps core very early on in startup.
|
||||||
DEBUG=
|
It is said that sparcv9 support in gcc-2.96 is very unofficial.
|
||||||
|
There is no work-a-round for this compiler problem.
|
||||||
|
@@ -19,11 +19,6 @@ Installing calc in 4 easy steps:
|
|||||||
As shipped the Makefile assumes 'more'. On your system
|
As shipped the Makefile assumes 'more'. On your system
|
||||||
you may find 'less' to be a better pager.
|
you may find 'less' to be a better pager.
|
||||||
|
|
||||||
The CALCBINDINGS is matter of personal taste. As shipped
|
|
||||||
the Makefile assumes a default quasi-emacs-like command
|
|
||||||
line editor. Changing CALCBINDINGS= altbind will cause ^D
|
|
||||||
to end calc in a fashion similar to that of the bc(1) command.
|
|
||||||
|
|
||||||
Set TOPDIR to be the place under which help files, calc,
|
Set TOPDIR to be the place under which help files, calc,
|
||||||
include files and calc libs are to be installed. As shipped
|
include files and calc libs are to be installed. As shipped
|
||||||
the Makefile assumes a TOPDIR of /usr/local/lib.
|
the Makefile assumes a TOPDIR of /usr/local/lib.
|
||||||
|
34
LIBRARY
34
LIBRARY
@@ -43,7 +43,7 @@ to use more than one type of arithmetic, since qmath.h automatically includes
|
|||||||
zmath.h, and cmath.h automatically includes qmath.h.
|
zmath.h, and cmath.h automatically includes qmath.h.
|
||||||
|
|
||||||
The prototypes for the available routines are listed in the above include
|
The prototypes for the available routines are listed in the above include
|
||||||
files. Some of these routines are meant for internal use, and so aren't
|
files. Some of these routines are meant for internal use, and so aren't
|
||||||
convenient for outside use. So you should read the source for a routine
|
convenient for outside use. So you should read the source for a routine
|
||||||
to see if it really does what you think it does. I won't guarantee that
|
to see if it really does what you think it does. I won't guarantee that
|
||||||
obscure internal routines won't change or disappear in future releases!
|
obscure internal routines won't change or disappear in future releases!
|
||||||
@@ -60,7 +60,7 @@ External programs may want to compile with:
|
|||||||
ERROR HANDLING
|
ERROR HANDLING
|
||||||
--------------
|
--------------
|
||||||
|
|
||||||
Your program MUST provide a function called math_error. This is called by
|
Your program MUST provide a function called math_error. This is called by
|
||||||
the math routines on an error condition, such as malloc failures or a
|
the math routines on an error condition, such as malloc failures or a
|
||||||
division by zero. The routine is called in the manner of printf, with a
|
division by zero. The routine is called in the manner of printf, with a
|
||||||
format string and optional arguments. (However, none of the low level math
|
format string and optional arguments. (However, none of the low level math
|
||||||
@@ -142,7 +142,7 @@ output strings with space filling, output formatted strings like printf, and
|
|||||||
flush the output. Output from these routines is diverted as described above.
|
flush the output. Output from these routines is diverted as described above.
|
||||||
|
|
||||||
You can change the default output mode by calling math_setmode, and you can
|
You can change the default output mode by calling math_setmode, and you can
|
||||||
change the default number of digits printed by calling math_setdigits. These
|
change the default number of digits printed by calling math_setdigits. These
|
||||||
routines return the previous values. The possible modes are described in
|
routines return the previous values. The possible modes are described in
|
||||||
zmath.h.
|
zmath.h.
|
||||||
|
|
||||||
@@ -154,7 +154,7 @@ The arbitrary precision integer routines define a structure called a ZVALUE.
|
|||||||
This is defined in zmath.h. A ZVALUE contains a pointer to an array of
|
This is defined in zmath.h. A ZVALUE contains a pointer to an array of
|
||||||
integers, the length of the array, and a sign flag. The array is allocated
|
integers, the length of the array, and a sign flag. The array is allocated
|
||||||
using malloc, so you need to free this array when you are done with a
|
using malloc, so you need to free this array when you are done with a
|
||||||
ZVALUE. To do this, you should call zfree with the ZVALUE as an argument
|
ZVALUE. To do this, you should call zfree with the ZVALUE as an argument
|
||||||
(or call freeh with the pointer as an argument) and never try to free the
|
(or call freeh with the pointer as an argument) and never try to free the
|
||||||
array yourself using free. The reason for this is that sometimes the pointer
|
array yourself using free. The reason for this is that sometimes the pointer
|
||||||
points to one of two statically allocated arrays which should NOT be freed.
|
points to one of two statically allocated arrays which should NOT be freed.
|
||||||
@@ -248,7 +248,7 @@ If the value is too large for ztofull(), ztoulong() or ztolong(), only
|
|||||||
the low order bits converted.
|
the low order bits converted.
|
||||||
|
|
||||||
There are two types of comparisons you can make on ZVALUEs. This is whether
|
There are two types of comparisons you can make on ZVALUEs. This is whether
|
||||||
or not they are equal, or the ordering on size of the numbers. The zcmp
|
or not they are equal, or the ordering on size of the numbers. The zcmp
|
||||||
function tests whether two ZVALUEs are equal, returning TRUE if they differ.
|
function tests whether two ZVALUEs are equal, returning TRUE if they differ.
|
||||||
The zrel function tests the relative sizes of two ZVALUEs, returning -1 if
|
The zrel function tests the relative sizes of two ZVALUEs, returning -1 if
|
||||||
the first one is smaller, 0 if they are the same, and 1 if the first one
|
the first one is smaller, 0 if they are the same, and 1 if the first one
|
||||||
@@ -267,7 +267,7 @@ is always positive. If the NUMBER is an integer, the denominator has the
|
|||||||
value 1.
|
value 1.
|
||||||
|
|
||||||
Unlike ZVALUEs, NUMBERs are passed using pointers, and pointers to them are
|
Unlike ZVALUEs, NUMBERs are passed using pointers, and pointers to them are
|
||||||
returned by functions. So the basic type for using fractions is not really
|
returned by functions. So the basic type for using fractions is not really
|
||||||
(NUMBER), but is (NUMBER *). NUMBERs are allocated using the qalloc routine.
|
(NUMBER), but is (NUMBER *). NUMBERs are allocated using the qalloc routine.
|
||||||
This returns a pointer to a number which has the value 1. Because of the
|
This returns a pointer to a number which has the value 1. Because of the
|
||||||
special property of a ZVALUE of 1, the numerator and denominator of this
|
special property of a ZVALUE of 1, the numerator and denominator of this
|
||||||
@@ -283,7 +283,7 @@ A better way to create NUMBERs with particular values is to use the itoq,
|
|||||||
iitoq, or atoq functions. Using itoq makes a long value into a NUMBER,
|
iitoq, or atoq functions. Using itoq makes a long value into a NUMBER,
|
||||||
using iitoq makes a pair of longs into the numerator and denominator of a
|
using iitoq makes a pair of longs into the numerator and denominator of a
|
||||||
NUMBER (reducing them first if needed), and atoq converts a string representing
|
NUMBER (reducing them first if needed), and atoq converts a string representing
|
||||||
a number into the corresponding NUMBER. The atoq function accepts input in
|
a number into the corresponding NUMBER. The atoq function accepts input in
|
||||||
integral, fractional, real, or exponential formats. Examples of allocating
|
integral, fractional, real, or exponential formats. Examples of allocating
|
||||||
numbers are:
|
numbers are:
|
||||||
|
|
||||||
@@ -294,7 +294,7 @@ numbers are:
|
|||||||
q3 = atoq("456.78");
|
q3 = atoq("456.78");
|
||||||
|
|
||||||
Also unlike ZVALUEs, NUMBERs are quickly copied. This is because they contain
|
Also unlike ZVALUEs, NUMBERs are quickly copied. This is because they contain
|
||||||
a link count, which is the number of pointers there are to the NUMBER. The
|
a link count, which is the number of pointers there are to the NUMBER. The
|
||||||
qlink macro is used to copy a pointer to a NUMBER, and simply increments
|
qlink macro is used to copy a pointer to a NUMBER, and simply increments
|
||||||
the link count and returns the same pointer. Since it is a macro, the
|
the link count and returns the same pointer. Since it is a macro, the
|
||||||
argument should not be a function call, but a real pointer variable. The
|
argument should not be a function call, but a real pointer variable. The
|
||||||
@@ -329,11 +329,11 @@ denominator, qint to return the integer part of, qfrac to return the
|
|||||||
fractional part of, and qinv to invert a fraction.
|
fractional part of, and qinv to invert a fraction.
|
||||||
|
|
||||||
There are some transcendental functions in the library, such as sin and cos.
|
There are some transcendental functions in the library, such as sin and cos.
|
||||||
These cannot be evaluated exactly as fractions. Therefore, they accept
|
These cannot be evaluated exactly as fractions. Therefore, they accept
|
||||||
another argument which tells how accurate you want the result. This is an
|
another argument which tells how accurate you want the result. This is an
|
||||||
"epsilon" value, and the returned value will be within that quantity of
|
"epsilon" value, and the returned value will be within that quantity of
|
||||||
the correct value. This is usually an absolute difference, but for some
|
the correct value. This is usually an absolute difference, but for some
|
||||||
functions (such as exp), this is a relative difference. For example, to
|
functions (such as exp), this is a relative difference. For example, to
|
||||||
calculate sin(0.5) to 100 decimal places, you could do:
|
calculate sin(0.5) to 100 decimal places, you could do:
|
||||||
|
|
||||||
NUMBER *q, *ans, *epsilon;
|
NUMBER *q, *ans, *epsilon;
|
||||||
@@ -363,7 +363,7 @@ macros are:
|
|||||||
The comparisons for NUMBERs are similar to the ones for ZVALUEs. You use the
|
The comparisons for NUMBERs are similar to the ones for ZVALUEs. You use the
|
||||||
qcmp and qrel functions.
|
qcmp and qrel functions.
|
||||||
|
|
||||||
There are four predefined values for fractions. You should qlink them when
|
There are four predefined values for fractions. You should qlink them when
|
||||||
you want to use them. These are _qzero_, _qone_, _qnegone_, and _qonehalf_.
|
you want to use them. These are _qzero_, _qone_, _qnegone_, and _qonehalf_.
|
||||||
These have the values 0, 1, -1, and 1/2. An example of using them is:
|
These have the values 0, 1, -1, and 1/2. An example of using them is:
|
||||||
|
|
||||||
@@ -377,7 +377,7 @@ USING COMPLEX NUMBERS
|
|||||||
---------------------
|
---------------------
|
||||||
|
|
||||||
The arbitrary precision complex arithmetic routines define a structure
|
The arbitrary precision complex arithmetic routines define a structure
|
||||||
called COMPLEX. This is defined in cmath.h. This contains two NUMBERs
|
called COMPLEX. This is defined in cmath.h. This contains two NUMBERs
|
||||||
for the real and imaginary parts of a complex number, and a count of the
|
for the real and imaginary parts of a complex number, and a count of the
|
||||||
number of links there are to this COMPLEX number.
|
number of links there are to this COMPLEX number.
|
||||||
|
|
||||||
@@ -410,7 +410,7 @@ There is no direct routine to convert a string value into a COMPLEX value.
|
|||||||
But you can do this yourself by converting two strings into two NUMBERS,
|
But you can do this yourself by converting two strings into two NUMBERS,
|
||||||
and then using the qqtoc routine.
|
and then using the qqtoc routine.
|
||||||
|
|
||||||
COMPLEX values are always returned from these routines. To split out the
|
COMPLEX values are always returned from these routines. To split out the
|
||||||
real and imaginary parts into normal NUMBERs, you can simply qlink the
|
real and imaginary parts into normal NUMBERs, you can simply qlink the
|
||||||
two components, as shown in the following example:
|
two components, as shown in the following example:
|
||||||
|
|
||||||
@@ -423,7 +423,7 @@ two components, as shown in the following example:
|
|||||||
|
|
||||||
There are many macros for checking quick things about complex numbers,
|
There are many macros for checking quick things about complex numbers,
|
||||||
similar to the ZVALUE and NUMBER macros. In addition, there are some
|
similar to the ZVALUE and NUMBER macros. In addition, there are some
|
||||||
only used for complex numbers. Examples of macros are:
|
only used for complex numbers. Examples of macros are:
|
||||||
|
|
||||||
cisreal(c) (number is real)
|
cisreal(c) (number is real)
|
||||||
cisimag(c) (number is pure imaginary)
|
cisimag(c) (number is pure imaginary)
|
||||||
@@ -441,8 +441,8 @@ only used for complex numbers. Examples of macros are:
|
|||||||
There is only one comparison you can make for COMPLEX values, and that is
|
There is only one comparison you can make for COMPLEX values, and that is
|
||||||
for equality. The ccmp function returns TRUE if two complex numbers differ.
|
for equality. The ccmp function returns TRUE if two complex numbers differ.
|
||||||
|
|
||||||
There are three predefined values for complex numbers. You should clink
|
There are three predefined values for complex numbers. You should clink
|
||||||
them when you want to use them. They are _czero_, _cone_, and _conei_.
|
them when you want to use them. They are _czero_, _cone_, and _conei_.
|
||||||
These have the values 0, 1, and i.
|
These have the values 0, 1, and i.
|
||||||
|
|
||||||
----------------
|
----------------
|
||||||
|
292
Makefile
292
Makefile
@@ -17,12 +17,12 @@
|
|||||||
|
|
||||||
# Determine the type of terminal controls that you want to use
|
# Determine the type of terminal controls that you want to use
|
||||||
#
|
#
|
||||||
# value meaning
|
# value meaning
|
||||||
# -------- -------
|
# -------- -------
|
||||||
# (nothing) let the makefile guess at what you need
|
# (nothing) let the makefile guess at what you need
|
||||||
# -DUSE_TERMIOS use struct termios from <termios.h>
|
# -DUSE_TERMIOS use struct termios from <termios.h>
|
||||||
# -DUSE_TERMIO use struct termios from <termio.h>
|
# -DUSE_TERMIO use struct termios from <termio.h>
|
||||||
# -DUSE_SGTTY use struct sgttyb from <sys/ioctl.h>
|
# -DUSE_SGTTY use struct sgttyb from <sys/ioctl.h>
|
||||||
#
|
#
|
||||||
# If in doubt, leave TERMCONTROL empty.
|
# If in doubt, leave TERMCONTROL empty.
|
||||||
#
|
#
|
||||||
@@ -41,7 +41,7 @@ TERMCONTROL=
|
|||||||
# for the best.
|
# for the best.
|
||||||
#
|
#
|
||||||
# If HAVE_VSPRINTF is empty, this makefile will run the have_stdvs.c and/or
|
# If HAVE_VSPRINTF is empty, this makefile will run the have_stdvs.c and/or
|
||||||
# have_varvs.c program to determine if vsprintf() is supported. If
|
# have_varvs.c program to determine if vsprintf() is supported. If
|
||||||
# HAVE_VSPRINTF is set to -DDONT_HAVE_VSPRINTF then calc will hope that
|
# HAVE_VSPRINTF is set to -DDONT_HAVE_VSPRINTF then calc will hope that
|
||||||
# sprintf() will work.
|
# sprintf() will work.
|
||||||
#
|
#
|
||||||
@@ -55,12 +55,12 @@ HAVE_VSPRINTF=
|
|||||||
# Big Endian: Amdahl, 68k, Pyramid, Mips, Sparc, ...
|
# Big Endian: Amdahl, 68k, Pyramid, Mips, Sparc, ...
|
||||||
# Little Endian: Vax, 32k, Spim (Dec Mips), i386, i486, ...
|
# Little Endian: Vax, 32k, Spim (Dec Mips), i386, i486, ...
|
||||||
#
|
#
|
||||||
# If in doubt, leave BYTE_ORDER empty. This makefile will attempt to
|
# If in doubt, leave BYTE_ORDER empty. This makefile will attempt to
|
||||||
# use BYTE_ORDER in <machine/endian.h> or it will attempt to run
|
# use BYTE_ORDER in <machine/endian.h> or it will attempt to run
|
||||||
# the endian program. If you get syntax errors when you compile,
|
# the endian program. If you get syntax errors when you compile,
|
||||||
# try forcing the value to be BIG_ENDIAN and run the calc regression
|
# try forcing the value to be BIG_ENDIAN and run the calc regression
|
||||||
# tests. (see the README file) If the calc regression tests fail, do
|
# tests. (see the README file) If the calc regression tests fail, do
|
||||||
# a make clobber and try LITTLE_ENDIAN. If that fails, ask a wizard
|
# a make clobber and try LITTLE_ENDIAN. If that fails, ask a wizard
|
||||||
# for help.
|
# for help.
|
||||||
#
|
#
|
||||||
BYTE_ORDER=
|
BYTE_ORDER=
|
||||||
@@ -112,7 +112,7 @@ HAVE_FPOS=
|
|||||||
#HAVE_FPOS= -DHAVE_NO_FPOS
|
#HAVE_FPOS= -DHAVE_NO_FPOS
|
||||||
|
|
||||||
# Determine if we have an off_t which one can perform arithmetic operations,
|
# Determine if we have an off_t which one can perform arithmetic operations,
|
||||||
# assignments and comparisons. On some systems off_t is some sort of union
|
# assignments and comparisons. On some systems off_t is some sort of union
|
||||||
# or struct.
|
# or struct.
|
||||||
#
|
#
|
||||||
# If HAVE_OFFSCL is empty, this makefile will run the have_offscl program
|
# If HAVE_OFFSCL is empty, this makefile will run the have_offscl program
|
||||||
@@ -126,7 +126,7 @@ HAVE_OFFSCL=
|
|||||||
#HAVE_OFFSCL= -DOFF_T_NON_SCALAR
|
#HAVE_OFFSCL= -DOFF_T_NON_SCALAR
|
||||||
|
|
||||||
# Determine if we have an fpos_t which one can perform arithmetic operations,
|
# Determine if we have an fpos_t which one can perform arithmetic operations,
|
||||||
# assignments and comparisons. On some systems fpos_t is some sort of union
|
# assignments and comparisons. On some systems fpos_t is some sort of union
|
||||||
# or struct. Some systems do not have an fpos_t and long is as a file
|
# or struct. Some systems do not have an fpos_t and long is as a file
|
||||||
# offset instead.
|
# offset instead.
|
||||||
#
|
#
|
||||||
@@ -192,7 +192,7 @@ HAVE_MEMMOVE=
|
|||||||
# Determine if we have ustat()
|
# Determine if we have ustat()
|
||||||
#
|
#
|
||||||
# If HAVE_USTAT is empty, this makefile will run the have_memmv program
|
# If HAVE_USTAT is empty, this makefile will run the have_memmv program
|
||||||
# to determine if ustat() is supported. If HAVE_USTAT is set to
|
# to determine if ustat() is supported. If HAVE_USTAT is set to
|
||||||
# -DHAVE_NO_USTAT, then calc will use internal functions to simulate
|
# -DHAVE_NO_USTAT, then calc will use internal functions to simulate
|
||||||
# the memory move function that does correct overlapping memory modes.
|
# the memory move function that does correct overlapping memory modes.
|
||||||
#
|
#
|
||||||
@@ -228,7 +228,7 @@ HAVE_GETPGID=
|
|||||||
# Determine if we have clock_gettime()
|
# Determine if we have clock_gettime()
|
||||||
#
|
#
|
||||||
# If HAVE_GETTIME is empty, this makefile will run the have_memmv program
|
# If HAVE_GETTIME is empty, this makefile will run the have_memmv program
|
||||||
# to determine if clock_gettime() is supported. If HAVE_GETTIME is set to
|
# to determine if clock_gettime() is supported. If HAVE_GETTIME is set to
|
||||||
# -DHAVE_NO_GETTIME, then calc will use internal functions to simulate
|
# -DHAVE_NO_GETTIME, then calc will use internal functions to simulate
|
||||||
# the memory move function that does correct overlapping memory modes.
|
# the memory move function that does correct overlapping memory modes.
|
||||||
#
|
#
|
||||||
@@ -289,7 +289,7 @@ HAVE_STRDUP=
|
|||||||
# that are not alligned on a 32 bit boundary.
|
# that are not alligned on a 32 bit boundary.
|
||||||
#
|
#
|
||||||
# The Dec Alpha running OSF/1 will produce alignment error messages when
|
# The Dec Alpha running OSF/1 will produce alignment error messages when
|
||||||
# align32.c tries to figure out if alignment is needed. Use the
|
# align32.c tries to figure out if alignment is needed. Use the
|
||||||
# ALIGN32= -DMUST_ALIGN32 to force alignment and avoid such error messages.
|
# ALIGN32= -DMUST_ALIGN32 to force alignment and avoid such error messages.
|
||||||
#
|
#
|
||||||
# ALIGN32= let align32.c figure out if alignment is needed
|
# ALIGN32= let align32.c figure out if alignment is needed
|
||||||
@@ -302,39 +302,6 @@ HAVE_STRDUP=
|
|||||||
ALIGN32= -DMUST_ALIGN32
|
ALIGN32= -DMUST_ALIGN32
|
||||||
#ALIGN32= -UMUST_ALIGN32
|
#ALIGN32= -UMUST_ALIGN32
|
||||||
|
|
||||||
# On most machines: errno sys_errlist and sys_nerr are declared
|
|
||||||
# by either <stdio.h> and/or <errno.h>. But some systems declare
|
|
||||||
# them somewhere else or do not declare them at all!
|
|
||||||
#
|
|
||||||
# If the system were doing a proper job in headers, this should declare them:
|
|
||||||
#
|
|
||||||
# #include <stdio.h>
|
|
||||||
# #include <errno.h>
|
|
||||||
#
|
|
||||||
# But one some systems one must explicitly declare them as:
|
|
||||||
#
|
|
||||||
# extern int errno;
|
|
||||||
# extern const char *const sys_errlist[];
|
|
||||||
# extern int sys_nerr;
|
|
||||||
#
|
|
||||||
# and on some old systems they must be explicitly and incorrectly declared as:
|
|
||||||
#
|
|
||||||
# extern int errno;
|
|
||||||
# extern char *sys_errlist[];
|
|
||||||
# extern int sys_nerr;
|
|
||||||
#
|
|
||||||
# ERRNO_DECL= let calc_errno.c determine how to declare them
|
|
||||||
# ERRNO_DECL= -DERRNO_NO_DECL headers declare them correctly
|
|
||||||
# ERRNO_DECL= -DERRNO_STD_DECL one must explicitly declare then
|
|
||||||
# ERRNO_DECL= -DERRNO_OLD_DECL one must explicitly & incorrectly declare them
|
|
||||||
#
|
|
||||||
# When in doubt, be safe leave ERRNO_DECL empty.
|
|
||||||
#
|
|
||||||
ERRNO_DECL=
|
|
||||||
#ERRNO_DECL= -DERRNO_NO_DECL
|
|
||||||
#ERRNO_DECL= -DERRNO_STD_DECL
|
|
||||||
#ERRNO_DECL= -DERRNO_OLD_DECL
|
|
||||||
|
|
||||||
# where to install binary files
|
# where to install binary files
|
||||||
#
|
#
|
||||||
BINDIR= /usr/local/bin
|
BINDIR= /usr/local/bin
|
||||||
@@ -435,23 +402,11 @@ CALCPATH= .:./lib:~/lib:${LIBDIR}:${CUSTOMLIBDIR}
|
|||||||
#
|
#
|
||||||
CALCRC= ${LIBDIR}/startup:~/.calcrc
|
CALCRC= ${LIBDIR}/startup:~/.calcrc
|
||||||
|
|
||||||
# If the $CALCBINDINGS environment variable is not defined, then the following
|
|
||||||
# file will be used for the command line and edit history key bindings.
|
|
||||||
# The $CALCPATH will be used to search for this file.
|
|
||||||
#
|
|
||||||
# ${LIBDIR}/bindings uses ^D for editing
|
|
||||||
# ${LIBDIR}/altbind uses ^D for EOF
|
|
||||||
#
|
|
||||||
# NOTE: This facility is disabled if USE_READLINE is set to -DUSE_READLINE.
|
|
||||||
#
|
|
||||||
CALCBINDINGS= bindings
|
|
||||||
#CALCBINDINGS= altbind
|
|
||||||
|
|
||||||
# Determine of the GNU-readline facility will be used instead of the
|
# Determine of the GNU-readline facility will be used instead of the
|
||||||
# built-in CALCBINDINGS above.
|
# built-in calc binding method.
|
||||||
#
|
#
|
||||||
# USE_READLINE= Do not use GNU-readline, use CALCBINDINGS
|
# USE_READLINE= Do not use GNU-readline, use calc bindings
|
||||||
# USE_READLINE= -DUSE_READLINE Use GNU-readline, do not use CALCBINDINGS
|
# USE_READLINE= -DUSE_READLINE Use GNU-readline, do not use calc bindings
|
||||||
#
|
#
|
||||||
# NOTE: If you select the 'USE_READLINE= -DUSE_READLINE' mode, you must set:
|
# NOTE: If you select the 'USE_READLINE= -DUSE_READLINE' mode, you must set:
|
||||||
#
|
#
|
||||||
@@ -459,8 +414,8 @@ CALCBINDINGS= bindings
|
|||||||
# and history libs
|
# and history libs
|
||||||
# READLINE_INCLUDE Where the readline include files reside
|
# READLINE_INCLUDE Where the readline include files reside
|
||||||
#
|
#
|
||||||
# NOTE: The GNU-readline code is not shipped with calc. You must have
|
# NOTE: The GNU-readline code is not shipped with calc. You must have
|
||||||
# the appropriate headers and libs installed on your system in
|
# the appropriate headers and libs installed on your system in
|
||||||
# order to use it.
|
# order to use it.
|
||||||
#
|
#
|
||||||
# If in doubt, set USE_READLINE, READLINE_LIB and READLINE_INCLUDE to nothing.
|
# If in doubt, set USE_READLINE, READLINE_LIB and READLINE_INCLUDE to nothing.
|
||||||
@@ -516,7 +471,7 @@ DEBUG= -O2 -g3
|
|||||||
# BSD NO_SHARED=
|
# BSD NO_SHARED=
|
||||||
# SYSV NO_SHARED= -dn
|
# SYSV NO_SHARED= -dn
|
||||||
# IRIX NO_SHARED= -non_shared
|
# IRIX NO_SHARED= -non_shared
|
||||||
# disable NO_SHARED=
|
# disable NO_SHARED=
|
||||||
#
|
#
|
||||||
# If in doubt, use NO_SHARED=
|
# If in doubt, use NO_SHARED=
|
||||||
#
|
#
|
||||||
@@ -527,11 +482,11 @@ NO_SHARED=
|
|||||||
# On some systems where you are disabling dynamic shared libs, you may
|
# On some systems where you are disabling dynamic shared libs, you may
|
||||||
# need to pass a special flag to ${CC} and ${LCC} during linking stage.
|
# need to pass a special flag to ${CC} and ${LCC} during linking stage.
|
||||||
#
|
#
|
||||||
# System type NO_SHARED recommendation
|
# System type NO_SHARED recommendation
|
||||||
#
|
#
|
||||||
# IRIX with NO_SHARED= -non_shared LD_NO_SHARED= -Wl,-rdata_shared
|
# IRIX with NO_SHARED= -non_shared LD_NO_SHARED= -Wl,-rdata_shared
|
||||||
# IRIX with NO_SHARED= LD_NO_SHARED=
|
# IRIX with NO_SHARED= LD_NO_SHARED=
|
||||||
# others LD_NO_SHARED=
|
# others LD_NO_SHARED=
|
||||||
#
|
#
|
||||||
# If in doubt, use LD_NO_SHARED=
|
# If in doubt, use LD_NO_SHARED=
|
||||||
#
|
#
|
||||||
@@ -553,7 +508,7 @@ RANLIB=ranlib
|
|||||||
#
|
#
|
||||||
# BSD ${LINT} ${LCFLAGS} ${LINTFLAGS} -u -Ccalc
|
# BSD ${LINT} ${LCFLAGS} ${LINTFLAGS} -u -Ccalc
|
||||||
# SYSV ${LINT} ${LCFLAGS} ${LINTFLAGS} -u -o calc
|
# SYSV ${LINT} ${LCFLAGS} ${LINTFLAGS} -u -o calc
|
||||||
# disable :
|
# disable :
|
||||||
#
|
#
|
||||||
# If in doubt and you don't care about lint, use LINTLIB= :
|
# If in doubt and you don't care about lint, use LINTLIB= :
|
||||||
#
|
#
|
||||||
@@ -562,10 +517,10 @@ RANLIB=ranlib
|
|||||||
LINTLIB= :
|
LINTLIB= :
|
||||||
|
|
||||||
# The lint flags vary from system to system. Some systems have the
|
# The lint flags vary from system to system. Some systems have the
|
||||||
# opposite meaning for the flags below. Other systems change flag
|
# opposite meaning for the flags below. Other systems change flag
|
||||||
# meaning altogether.
|
# meaning altogether.
|
||||||
#
|
#
|
||||||
# System LINTFLAGS recommendation
|
# System LINTFLAGS recommendation
|
||||||
#
|
#
|
||||||
# SunOs -a -h -v -z
|
# SunOs -a -h -v -z
|
||||||
#
|
#
|
||||||
@@ -575,7 +530,7 @@ LINTLIB= :
|
|||||||
LINTFLAGS=
|
LINTFLAGS=
|
||||||
|
|
||||||
# Normally certain files depend on the Makefile. If the Makefile is
|
# Normally certain files depend on the Makefile. If the Makefile is
|
||||||
# changed, then certain steps should be redone. If MAKE_FILE is
|
# changed, then certain steps should be redone. If MAKE_FILE is
|
||||||
# set to Makefile, then these files will depend on Makefile. If
|
# set to Makefile, then these files will depend on Makefile. If
|
||||||
# MAKE_FILE is empty, they they wont.
|
# MAKE_FILE is empty, they they wont.
|
||||||
#
|
#
|
||||||
@@ -626,7 +581,7 @@ CALC_ENV= CALCPATH=./lib
|
|||||||
|
|
||||||
# By default, custom builtin functions may only be executed if calc
|
# By default, custom builtin functions may only be executed if calc
|
||||||
# is given the -C option. This is because custom builtin functions
|
# is given the -C option. This is because custom builtin functions
|
||||||
# may invoke non-standard or non-portable code. One may completely
|
# may invoke non-standard or non-portable code. One may completely
|
||||||
# disable custom builtin functions by not compiling any of code
|
# disable custom builtin functions by not compiling any of code
|
||||||
#
|
#
|
||||||
# ALLOW_CUSTOM= -DCUSTOM # allow custom only if -C is given
|
# ALLOW_CUSTOM= -DCUSTOM # allow custom only if -C is given
|
||||||
@@ -942,7 +897,7 @@ BUILD_H_SRC= align32.h args.h calcerr.h conf.h endian_calc.h \
|
|||||||
fposval.h have_const.h have_fpos.h have_malloc.h \
|
fposval.h have_const.h have_fpos.h have_malloc.h \
|
||||||
have_memmv.h have_newstr.h have_offscl.h have_posscl.h \
|
have_memmv.h have_newstr.h have_offscl.h have_posscl.h \
|
||||||
have_stdlib.h have_string.h have_times.h have_uid_t.h \
|
have_stdlib.h have_string.h have_times.h have_uid_t.h \
|
||||||
have_unistd.h longbits.h longlong.h terminal.h calc_errno.h \
|
have_unistd.h longbits.h longlong.h terminal.h \
|
||||||
have_ustat.h have_getsid.h have_getpgid.h \
|
have_ustat.h have_getsid.h have_getpgid.h \
|
||||||
have_gettime.h have_getprid.h have_urandom.h have_rusage.h \
|
have_gettime.h have_getprid.h have_urandom.h have_rusage.h \
|
||||||
have_strdup.h
|
have_strdup.h
|
||||||
@@ -957,7 +912,7 @@ BUILD_C_SRC= calcerr.c
|
|||||||
#
|
#
|
||||||
UTIL_C_SRC= align32.c endian.c longbits.c have_newstr.c have_uid_t.c \
|
UTIL_C_SRC= align32.c endian.c longbits.c have_newstr.c have_uid_t.c \
|
||||||
have_const.c have_stdvs.c have_varvs.c fposval.c have_fpos.c \
|
have_const.c have_stdvs.c have_varvs.c fposval.c have_fpos.c \
|
||||||
longlong.c have_offscl.c have_posscl.c have_memmv.c calc_errno.c \
|
longlong.c have_offscl.c have_posscl.c have_memmv.c \
|
||||||
have_ustat.c have_getsid.c have_getpgid.c \
|
have_ustat.c have_getsid.c have_getpgid.c \
|
||||||
have_gettime.c have_getprid.c have_rusage.c have_strdup.c
|
have_gettime.c have_getprid.c have_rusage.c have_strdup.c
|
||||||
|
|
||||||
@@ -973,32 +928,23 @@ UTIL_MISC_SRC= calcerr_h.sed calcerr_h.awk calcerr_c.sed calcerr_c.awk \
|
|||||||
#
|
#
|
||||||
UTIL_OBJS= endian.o longbits.o have_newstr.o have_uid_t.o \
|
UTIL_OBJS= endian.o longbits.o have_newstr.o have_uid_t.o \
|
||||||
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
||||||
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o calc_errno.o \
|
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o \
|
||||||
have_ustat.o have_getsid.o have_getpgid.o \
|
have_ustat.o have_getsid.o have_getpgid.o \
|
||||||
have_gettime.o have_getprid.o ver_calc.o have_rusage.o have_strdup.o
|
have_gettime.o have_getprid.o ver_calc.o have_rusage.o have_strdup.o
|
||||||
|
|
||||||
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
||||||
#
|
#
|
||||||
UTIL_TMP= ll_tmp fpos_tmp fposv_tmp const_tmp uid_tmp newstr_tmp vs_tmp \
|
UTIL_TMP= ll_tmp fpos_tmp fposv_tmp const_tmp uid_tmp newstr_tmp vs_tmp \
|
||||||
calc_errno_tmp memmv_tmp offscl_tmp posscl_tmp newstr_tmp \
|
memmv_tmp offscl_tmp posscl_tmp newstr_tmp \
|
||||||
getsid_tmp gettime_tmp getprid_tmp rusage_tmp strdup_tmp
|
getsid_tmp gettime_tmp getprid_tmp rusage_tmp strdup_tmp
|
||||||
|
|
||||||
# these utility progs may be used in the process of building BUILD_H_SRC
|
# these utility progs may be used in the process of building BUILD_H_SRC
|
||||||
#
|
#
|
||||||
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
||||||
endian longbits have_newstr have_stdvs have_varvs calc_errno \
|
endian longbits have_newstr have_stdvs have_varvs \
|
||||||
have_ustat have_getsid have_getpgid \
|
have_ustat have_getsid have_getpgid \
|
||||||
have_gettime have_getprid ver_calc have_strdup
|
have_gettime have_getprid ver_calc have_strdup
|
||||||
|
|
||||||
# These files are required by the regress.cal regression test.
|
|
||||||
#
|
|
||||||
REGRESS_CAL= ./lib/lucas_chk.cal ./lib/natnumset.cal ./lib/surd.cal \
|
|
||||||
./lib/test1700.cal ./lib/test2300.cal ./lib/test2600.cal \
|
|
||||||
./lib/test2700.cal ./lib/test3100.cal ./lib/test3300.cal \
|
|
||||||
./lib/test3400.cal ./lib/test3500.cal ./lib/test4000.cal \
|
|
||||||
./lib/test4100.cal ./lib/test4600.cal ./lib/test5100.cal \
|
|
||||||
./lib/test5200.cal
|
|
||||||
|
|
||||||
# The complete list of makefile vars passed down to custom/Makefile.
|
# The complete list of makefile vars passed down to custom/Makefile.
|
||||||
#
|
#
|
||||||
CUSTOM_PASSDOWN= Q="${Q}" \
|
CUSTOM_PASSDOWN= Q="${Q}" \
|
||||||
@@ -1090,7 +1036,12 @@ C_SRC= ${LIBSRC} ${CALCSRC} ${UTIL_C_SRC}
|
|||||||
# These files are found (but not built) in the distribution
|
# These files are found (but not built) in the distribution
|
||||||
#
|
#
|
||||||
DISTLIST= ${C_SRC} ${H_SRC} ${MAKE_FILE} BUGS CHANGES LIBRARY README \
|
DISTLIST= ${C_SRC} ${H_SRC} ${MAKE_FILE} BUGS CHANGES LIBRARY README \
|
||||||
calc.man lint.sed HOWTO.INSTALL ${UTIL_MISC_SRC}
|
calc.man lint.sed HOWTO.INSTALL ${UTIL_MISC_SRC}
|
||||||
|
|
||||||
|
# These files are used to make (but not built) a calc .a library
|
||||||
|
#
|
||||||
|
CALCLIBLIST= ${LIBSRC} ${UTIL_C_SRC} ${LIB_H_SRC} ${MAKE_FILE} \
|
||||||
|
${UTIL_MISC_SRC} BUGS CHANGES LIBRARY
|
||||||
|
|
||||||
# complete list of .o files
|
# complete list of .o files
|
||||||
#
|
#
|
||||||
@@ -1107,12 +1058,12 @@ PROGS= calc ${UTIL_PROGS}
|
|||||||
# complete list of targets
|
# complete list of targets
|
||||||
#
|
#
|
||||||
TARGETS= ${CALC_LIBS} custom/.all calc sample/sample \
|
TARGETS= ${CALC_LIBS} custom/.all calc sample/sample \
|
||||||
lib/.all help/.all help/builtin calc.1
|
lib/.all help/.all help/builtin calc.1
|
||||||
|
|
||||||
|
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
# The reason for this Makefile :-)
|
# The reason for this Makefile :-)
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
|
|
||||||
@@ -1131,8 +1082,7 @@ calc.1: calc.man ${MAKE_FILE}
|
|||||||
-rm -f calc.1
|
-rm -f calc.1
|
||||||
${SED} -e 's:$${LIBDIR}:${LIBDIR}:g' \
|
${SED} -e 's:$${LIBDIR}:${LIBDIR}:g' \
|
||||||
-e 's,$${CALCPATH},${CALCPATH},g' \
|
-e 's,$${CALCPATH},${CALCPATH},g' \
|
||||||
-e 's,$${CALCRC},${CALCRC},g' \
|
-e 's,$${CALCRC},${CALCRC},g' < calc.man > calc.1
|
||||||
-e 's,$${CALCBINDINGS},${CALCBINDINGS},g' < calc.man > calc.1
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -1147,8 +1097,7 @@ custom.o: custom.c ${MAKE_FILE}
|
|||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
||||||
|
|
||||||
hist.o: hist.c ${MAKE_FILE}
|
hist.o: hist.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${TERMCONTROL} ${USE_READLINE} ${READLINE_INCLUDE} \
|
${CC} ${CFLAGS} ${TERMCONTROL} ${USE_READLINE} ${READLINE_INCLUDE} -c hist.c
|
||||||
-c hist.c
|
|
||||||
|
|
||||||
func.o: func.c ${MAKE_FILE}
|
func.o: func.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
||||||
@@ -1197,11 +1146,6 @@ conf.h: ${MAKE_FILE}
|
|||||||
${Q}echo '#define DEFAULTCALCRC "${CALCRC}"' >> conf.h
|
${Q}echo '#define DEFAULTCALCRC "${CALCRC}"' >> conf.h
|
||||||
${Q}echo '#endif /* DEFAULTCALCRC */' >> conf.h
|
${Q}echo '#endif /* DEFAULTCALCRC */' >> conf.h
|
||||||
${Q}echo '' >> conf.h
|
${Q}echo '' >> conf.h
|
||||||
${Q}echo '/* the default key bindings file */' >> conf.h
|
|
||||||
${Q}echo '#ifndef DEFAULTCALCBINDINGS' >> conf.h
|
|
||||||
${Q}echo '#define DEFAULTCALCBINDINGS "${CALCBINDINGS}"' >> conf.h
|
|
||||||
${Q}echo '#endif /* DEFAULTCALCBINDINGS */' >> conf.h
|
|
||||||
${Q}echo '' >> conf.h
|
|
||||||
${Q}echo '/* the location of the help directory */' >> conf.h
|
${Q}echo '/* the location of the help directory */' >> conf.h
|
||||||
${Q}echo '#ifndef HELPDIR' >> conf.h
|
${Q}echo '#ifndef HELPDIR' >> conf.h
|
||||||
${Q}echo '#define HELPDIR "${HELPDIR}"' >> conf.h
|
${Q}echo '#define HELPDIR "${HELPDIR}"' >> conf.h
|
||||||
@@ -1319,9 +1263,9 @@ have_malloc.h: ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_malloc.h
|
${Q}echo '' >> have_malloc.h
|
||||||
${Q}echo '/* do we have /usr/include/malloc.h? */' >> have_malloc.h
|
${Q}echo '/* do we have /usr/include/malloc.h? */' >> have_malloc.h
|
||||||
-${Q}if [ -f /usr/include/malloc.h ]; then \
|
-${Q}if [ -f /usr/include/malloc.h ]; then \
|
||||||
echo '#define HAVE_MALLOC_H /* yes */' >> have_malloc.h; \
|
echo '#define HAVE_MALLOC_H /* yes */' >> have_malloc.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_MALLOC_H /* no */' >> have_malloc.h; \
|
echo '#undef HAVE_MALLOC_H /* no */' >> have_malloc.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> have_malloc.h
|
${Q}echo '' >> have_malloc.h
|
||||||
${Q}echo '' >> have_malloc.h
|
${Q}echo '' >> have_malloc.h
|
||||||
@@ -1351,7 +1295,7 @@ have_times.h: ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_times.h
|
${Q}echo '' >> have_times.h
|
||||||
${Q}echo '/* do we have /usr/include/times.h? */' >> have_times.h
|
${Q}echo '/* do we have /usr/include/times.h? */' >> have_times.h
|
||||||
-${Q}if [ -f /usr/include/times.h ]; then \
|
-${Q}if [ -f /usr/include/times.h ]; then \
|
||||||
echo '#define HAVE_TIMES_H /* yes */' >> have_times.h; \
|
echo '#define HAVE_TIMES_H /* yes */' >> have_times.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_TIMES_H /* no */' >> have_times.h; \
|
echo '#undef HAVE_TIMES_H /* no */' >> have_times.h; \
|
||||||
fi
|
fi
|
||||||
@@ -1398,9 +1342,9 @@ have_stdlib.h: ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_stdlib.h
|
${Q}echo '' >> have_stdlib.h
|
||||||
${Q}echo '/* do we have /usr/include/stdlib.h? */' >> have_stdlib.h
|
${Q}echo '/* do we have /usr/include/stdlib.h? */' >> have_stdlib.h
|
||||||
-${Q}if [ -f /usr/include/stdlib.h ]; then \
|
-${Q}if [ -f /usr/include/stdlib.h ]; then \
|
||||||
echo '#define HAVE_STDLIB_H /* yes */' >> have_stdlib.h; \
|
echo '#define HAVE_STDLIB_H /* yes */' >> have_stdlib.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_STDLIB_H /* no */' >> have_stdlib.h; \
|
echo '#undef HAVE_STDLIB_H /* no */' >> have_stdlib.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> have_stdlib.h
|
${Q}echo '' >> have_stdlib.h
|
||||||
${Q}echo '' >> have_stdlib.h
|
${Q}echo '' >> have_stdlib.h
|
||||||
@@ -1430,9 +1374,9 @@ have_unistd.h: ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_unistd.h
|
${Q}echo '' >> have_unistd.h
|
||||||
${Q}echo '/* do we have /usr/include/unistd.h? */' >> have_unistd.h
|
${Q}echo '/* do we have /usr/include/unistd.h? */' >> have_unistd.h
|
||||||
-${Q}if [ -f /usr/include/unistd.h ]; then \
|
-${Q}if [ -f /usr/include/unistd.h ]; then \
|
||||||
echo '#define HAVE_UNISTD_H /* yes */' >> have_unistd.h; \
|
echo '#define HAVE_UNISTD_H /* yes */' >> have_unistd.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_UNISTD_H /* no */' >> have_unistd.h; \
|
echo '#undef HAVE_UNISTD_H /* no */' >> have_unistd.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> have_unistd.h
|
${Q}echo '' >> have_unistd.h
|
||||||
${Q}echo '' >> have_unistd.h
|
${Q}echo '' >> have_unistd.h
|
||||||
@@ -1462,9 +1406,9 @@ have_string.h: ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_string.h
|
${Q}echo '' >> have_string.h
|
||||||
${Q}echo '/* do we have /usr/include/string.h? */' >> have_string.h
|
${Q}echo '/* do we have /usr/include/string.h? */' >> have_string.h
|
||||||
-${Q}if [ -f /usr/include/string.h ]; then \
|
-${Q}if [ -f /usr/include/string.h ]; then \
|
||||||
echo '#define HAVE_STRING_H /* yes */' >> have_string.h; \
|
echo '#define HAVE_STRING_H /* yes */' >> have_string.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_STRING_H /* no */' >> have_string.h; \
|
echo '#undef HAVE_STRING_H /* no */' >> have_string.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> have_string.h
|
${Q}echo '' >> have_string.h
|
||||||
${Q}echo '' >> have_string.h
|
${Q}echo '' >> have_string.h
|
||||||
@@ -2135,7 +2079,7 @@ have_urandom.h: ${MAKE_FILE}
|
|||||||
-${Q}if [ -c /dev/urandom ]; then \
|
-${Q}if [ -c /dev/urandom ]; then \
|
||||||
echo '#define HAVE_URANDOM_H /* yes */' >> have_urandom.h; \
|
echo '#define HAVE_URANDOM_H /* yes */' >> have_urandom.h; \
|
||||||
else \
|
else \
|
||||||
echo '#undef HAVE_URANDOM_H /* no */' >> have_urandom.h; \
|
echo '#undef HAVE_URANDOM_H /* no */' >> have_urandom.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> have_urandom.h
|
${Q}echo '' >> have_urandom.h
|
||||||
${Q}echo '' >> have_urandom.h
|
${Q}echo '' >> have_urandom.h
|
||||||
@@ -2288,98 +2232,6 @@ args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
|||||||
true; \
|
true; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
calc_errno.h: calc_errno.c ${MAKE_FILE}
|
|
||||||
-${Q}rm -f calc_errno.h calc_errno calc_errno_tmp
|
|
||||||
${Q}echo 'forming calc_errno.h'
|
|
||||||
${Q}echo '/*' > calc_errno.h
|
|
||||||
${Q}echo ' * DO NOT EDIT -- generated by the Makefile' >> calc_errno.h
|
|
||||||
${Q}echo ' */' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '#if !defined(__CALC_ERRNO_H__)' >> calc_errno.h
|
|
||||||
${Q}echo '#define __CALC_ERRNO_H__' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
-${Q}if [ X"${ERRNO_DECL}" = X"-DERRNO_NO_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo '#include <stdio.h>' >> calc_errno.h; \
|
|
||||||
echo '#include <errno.h>' >> calc_errno.h; \
|
|
||||||
elif [ X"${ERRNO_DECL}" = X"-DERRNO_STD_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern const char *const sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
elif [ X"${ERRNO_DECL}" = X"-DERRNO_OLD_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern char *sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_NO_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_STD_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_OLD_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * We were unable to to determine' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' * So we will guess this will work' >> calc_errno.h; \
|
|
||||||
echo ' * and hope for the best.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern const char *const sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
fi
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '#endif /* !__CALC_ERRNO_H__ */' >> calc_errno.h
|
|
||||||
-${Q}rm -f calc_errno calc_errno_tmp
|
|
||||||
${Q}echo 'calc_errno.h formed'
|
|
||||||
-@if [ -z "${Q}" ]; then \
|
|
||||||
echo ''; \
|
|
||||||
echo '=-=-= start of $@ =-=-='; \
|
|
||||||
cat $@; \
|
|
||||||
echo '=-=-= end of $@ =-=-='; \
|
|
||||||
echo ''; \
|
|
||||||
else \
|
|
||||||
true; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
calcerr.h: calcerr.tbl calcerr_h.sed calcerr_h.awk ${MAKE_FILE}
|
calcerr.h: calcerr.tbl calcerr_h.sed calcerr_h.awk ${MAKE_FILE}
|
||||||
-${Q}rm -f calerr.h
|
-${Q}rm -f calerr.h
|
||||||
${Q}echo 'forming calcerr.h'
|
${Q}echo 'forming calcerr.h'
|
||||||
@@ -2553,7 +2405,7 @@ sample/all:
|
|||||||
##
|
##
|
||||||
#
|
#
|
||||||
# The BSDI cdrom makefile expects certain files to be pre-built in a sub-dir
|
# The BSDI cdrom makefile expects certain files to be pre-built in a sub-dir
|
||||||
# called gen_h. This rule creats this sub-directory so that the release can
|
# called gen_h. This rule creats this sub-directory so that the release can
|
||||||
# be shipped off to BSDI. You can ignore this rule.
|
# be shipped off to BSDI. You can ignore this rule.
|
||||||
#
|
#
|
||||||
##
|
##
|
||||||
@@ -2623,7 +2475,7 @@ depend: hsrc
|
|||||||
-${Q}rm -rf skel
|
-${Q}rm -rf skel
|
||||||
${Q}mkdir skel
|
${Q}mkdir skel
|
||||||
-${Q}for i in ${C_SRC} ${BUILD_C_SRC}; do \
|
-${Q}for i in ${C_SRC} ${BUILD_C_SRC}; do \
|
||||||
${SED} -n '/^#[ ]*include[ ]*"/p' "$$i" > "skel/$$i"; \
|
${SED} -n '/^#[ ]*include[ ]*"/p' "$$i" > "skel/$$i"; \
|
||||||
done
|
done
|
||||||
${Q}mkdir skel/custom
|
${Q}mkdir skel/custom
|
||||||
-${Q}for i in ${H_SRC} ${BUILD_H_SRC} custom.h; do \
|
-${Q}for i in ${H_SRC} ${BUILD_H_SRC} custom.h; do \
|
||||||
@@ -2685,17 +2537,29 @@ distlist: ${DISTLIST}
|
|||||||
${Q}(for i in ${DISTLIST}; do \
|
${Q}(for i in ${DISTLIST}; do \
|
||||||
echo $$i; \
|
echo $$i; \
|
||||||
done; \
|
done; \
|
||||||
(cd help; ${MAKE} ${HELP_PASSDOWN} distlist); \
|
(cd help; ${MAKE} ${HELP_PASSDOWN} $@); \
|
||||||
(cd lib; ${MAKE} ${LIB_PASSDOWN} distlist); \
|
(cd lib; ${MAKE} ${LIB_PASSDOWN} $@); \
|
||||||
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distlist); \
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} $@); \
|
||||||
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distlist)) | ${SORT}
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} $@)) | ${SORT}
|
||||||
|
|
||||||
distdir:
|
distdir:
|
||||||
${Q}(echo .; \
|
${Q}(echo .; \
|
||||||
(cd help; ${MAKE} ${HELP_PASSDOWN} distdir); \
|
(cd help; ${MAKE} ${HELP_PASSDOWN} $@); \
|
||||||
(cd lib; ${MAKE} ${LIB_PASSDOWN} distdir); \
|
(cd lib; ${MAKE} ${LIB_PASSDOWN} $@); \
|
||||||
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distdir); \
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} $@); \
|
||||||
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distdir)) | ${SORT}
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} $@)) | ${SORT}
|
||||||
|
|
||||||
|
calcliblist:
|
||||||
|
${Q}(for i in ${CALCLIBLIST}; do \
|
||||||
|
echo $$i; \
|
||||||
|
done; \
|
||||||
|
(cd help; ${MAKE} ${HELP_PASSDOWN} $@); \
|
||||||
|
(cd lib; ${MAKE} ${LIB_PASSDOWN} $@); \
|
||||||
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} $@); \
|
||||||
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} $@)) | ${SORT}
|
||||||
|
|
||||||
|
calcliblistfmt:
|
||||||
|
${Q}${MAKE} calcliblist | ${FMT} -64 | ${SED} -e 's/^/ /'
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -2709,10 +2573,10 @@ distdir:
|
|||||||
#
|
#
|
||||||
##
|
##
|
||||||
|
|
||||||
check: all ./lib/regress.cal ${REGRESS_CAL}
|
check: all ./lib/regress.cal
|
||||||
${CALC_ENV} ./calc -d -q read regress
|
${CALC_ENV} ./calc -d -q read regress
|
||||||
|
|
||||||
chk: ./lib/regress.cal ${REGRESS_CAL}
|
chk: ./lib/regress.cal
|
||||||
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
||||||
${CALC_ENV} ./calc -d -q read regress 2>&1 | ${AWK} -f check.awk
|
${CALC_ENV} ./calc -d -q read regress 2>&1 | ${AWK} -f check.awk
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
@@ -2755,7 +2619,6 @@ env:
|
|||||||
@echo "HAVE_GETPRID=${HAVE_GETPRID}"; echo ""
|
@echo "HAVE_GETPRID=${HAVE_GETPRID}"; echo ""
|
||||||
@echo "HAVE_URANDOM=${HAVE_URANDOM}"; echo ""
|
@echo "HAVE_URANDOM=${HAVE_URANDOM}"; echo ""
|
||||||
@echo "ALIGN32=${ALIGN32}"; echo ""
|
@echo "ALIGN32=${ALIGN32}"; echo ""
|
||||||
@echo "ERRNO_DECL=${ERRNO_DECL}"; echo ""
|
|
||||||
@echo "BINDIR=${BINDIR}"; echo ""
|
@echo "BINDIR=${BINDIR}"; echo ""
|
||||||
@echo "TOPDIR=${TOPDIR}"; echo ""
|
@echo "TOPDIR=${TOPDIR}"; echo ""
|
||||||
@echo "LIBDIR=${LIBDIR}"; echo ""
|
@echo "LIBDIR=${LIBDIR}"; echo ""
|
||||||
@@ -2771,7 +2634,6 @@ env:
|
|||||||
@echo "MANMAKE=${MANMAKE}"; echo ""
|
@echo "MANMAKE=${MANMAKE}"; echo ""
|
||||||
@echo "CALCPATH=${CALCPATH}"; echo ""
|
@echo "CALCPATH=${CALCPATH}"; echo ""
|
||||||
@echo "CALCRC=${CALCRC}"; echo ""
|
@echo "CALCRC=${CALCRC}"; echo ""
|
||||||
@echo "CALCBINDINGS=${CALCBINDINGS}"; echo ""
|
|
||||||
@echo "CALCPAGER=${CALCPAGER}"; echo ""
|
@echo "CALCPAGER=${CALCPAGER}"; echo ""
|
||||||
@echo "DEBUG=${DEBUG}"; echo ""
|
@echo "DEBUG=${DEBUG}"; echo ""
|
||||||
@echo "NO_SHARED=${NO_SHARED}"; echo ""
|
@echo "NO_SHARED=${NO_SHARED}"; echo ""
|
||||||
@@ -2817,7 +2679,6 @@ env:
|
|||||||
@echo "UTIL_TMP=${UTIL_TMP}"; echo ""
|
@echo "UTIL_TMP=${UTIL_TMP}"; echo ""
|
||||||
@echo "UTIL_PROGS=${UTIL_PROGS}"; echo ""
|
@echo "UTIL_PROGS=${UTIL_PROGS}"; echo ""
|
||||||
@echo "LIB_H_SRC=${LIB_H_SRC}"; echo ""
|
@echo "LIB_H_SRC=${LIB_H_SRC}"; echo ""
|
||||||
@echo "REGRESS_CAL=${REGRESS_CAL}"; echo ""
|
|
||||||
@echo "CUSTOM_PASSDOWN=${CUSTOM_PASSDOWN}"; echo ""
|
@echo "CUSTOM_PASSDOWN=${CUSTOM_PASSDOWN}"; echo ""
|
||||||
@echo "SAMPLE_PASSDOWN=${SAMPLE_PASSDOWN}"; echo ""
|
@echo "SAMPLE_PASSDOWN=${SAMPLE_PASSDOWN}"; echo ""
|
||||||
@echo "HELP_PASSDOWN=${HELP_PASSDOWN}"; echo ""
|
@echo "HELP_PASSDOWN=${HELP_PASSDOWN}"; echo ""
|
||||||
@@ -3082,6 +2943,9 @@ install: calc libcalc.a ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
-rm -f ${LIBDIR}/stdarg.h stdarg.h
|
-rm -f ${LIBDIR}/stdarg.h stdarg.h
|
||||||
-rm -f ${LIBDIR}/prototype.h prototype.h
|
-rm -f ${LIBDIR}/prototype.h prototype.h
|
||||||
-rm -f ${LIBDIR}/libcalcerr.a libcalcerr.a
|
-rm -f ${LIBDIR}/libcalcerr.a libcalcerr.a
|
||||||
|
-rm -f ${LIBDIR}/calc_errno.h calc_errno.h ${INCDIRCALC}/calc_errno.h
|
||||||
|
-rm -f calc_errno.c calc_errno.o calc_errno
|
||||||
|
-rm -f ${LIBDIR}/altbind ${HELPDIR}/altbind
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
##
|
##
|
||||||
@@ -3249,7 +3113,6 @@ calc.o: symbol.h
|
|||||||
calc.o: token.h
|
calc.o: token.h
|
||||||
calc.o: value.h
|
calc.o: value.h
|
||||||
calc.o: zmath.h
|
calc.o: zmath.h
|
||||||
calc_errno.o: calc_errno.c
|
|
||||||
calcerr.o: calcerr.c
|
calcerr.o: calcerr.c
|
||||||
calcerr.o: calcerr.h
|
calcerr.o: calcerr.h
|
||||||
calcerr.o: have_const.h
|
calcerr.o: have_const.h
|
||||||
@@ -3430,7 +3293,6 @@ func.o: alloc.h
|
|||||||
func.o: block.h
|
func.o: block.h
|
||||||
func.o: byteswap.h
|
func.o: byteswap.h
|
||||||
func.o: calc.h
|
func.o: calc.h
|
||||||
func.o: calc_errno.h
|
|
||||||
func.o: calcerr.h
|
func.o: calcerr.h
|
||||||
func.o: cmath.h
|
func.o: cmath.h
|
||||||
func.o: config.h
|
func.o: config.h
|
||||||
|
16
README
16
README
@@ -27,7 +27,7 @@ If you run into problems, see the BUGS file.
|
|||||||
Calc is distributed with an extensive collection of help files that
|
Calc is distributed with an extensive collection of help files that
|
||||||
are accessible from the command line. The following assume that you
|
are accessible from the command line. The following assume that you
|
||||||
are running calc from the distribution directory or that you have
|
are running calc from the distribution directory or that you have
|
||||||
installed calc. In these examples, the ">" is the calc prompt, not
|
installed calc. In these examples, the ">" is the calc prompt, not
|
||||||
something that you type in.
|
something that you type in.
|
||||||
|
|
||||||
For list of help topics:
|
For list of help topics:
|
||||||
@@ -52,7 +52,7 @@ C programmers should note some unexpected differences in the calc syntax:
|
|||||||
|
|
||||||
> help unexpected
|
> help unexpected
|
||||||
|
|
||||||
Calc is shipped with a library of calc scripts. For a list see:
|
Calc is shipped with a library of calc scripts. For a list see:
|
||||||
|
|
||||||
> help stdlib
|
> help stdlib
|
||||||
|
|
||||||
@@ -74,7 +74,9 @@ for a wish/todo list. Code contributions are welcome.
|
|||||||
|
|
||||||
To join the calc-tester mailing list. Send a request to:
|
To join the calc-tester mailing list. Send a request to:
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
calc-tester-request at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
Your message body (not the subject) should consist of:
|
||||||
|
|
||||||
@@ -85,6 +87,14 @@ Your message body (not the subject) should consist of:
|
|||||||
where ``address'' is your EMail address and ``your_full_name'' is
|
where ``address'' is your EMail address and ``your_full_name'' is
|
||||||
your full name.
|
your full name.
|
||||||
|
|
||||||
|
Calc bug reports, however should be sent to:
|
||||||
|
|
||||||
|
calc-bugs at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
|
but see the BUGS file first.
|
||||||
|
|
||||||
The calc web site is located at:
|
The calc web site is located at:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc/
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
110
addop.c
110
addop.c
@@ -16,12 +16,13 @@
|
|||||||
#include "symbol.h"
|
#include "symbol.h"
|
||||||
|
|
||||||
|
|
||||||
#define FUNCALLOCSIZE 20 /* reallocate size for functions */
|
#define FUNCALLOCSIZE 20 /* reallocate size for functions */
|
||||||
#define OPCODEALLOCSIZE 100 /* reallocate size for opcodes in functions */
|
#define OPCODEALLOCSIZE 100 /* reallocate size for opcodes in functions */
|
||||||
|
|
||||||
|
|
||||||
static long maxopcodes; /* number of opcodes available */
|
static long maxopcodes; /* number of opcodes available */
|
||||||
static long newindex; /* index of new function */
|
static long newindex; /* index of new function */
|
||||||
|
static char *newname; /* name of new function */
|
||||||
static long oldop; /* previous opcode */
|
static long oldop; /* previous opcode */
|
||||||
static long oldoldop; /* opcode before previous opcode */
|
static long oldoldop; /* opcode before previous opcode */
|
||||||
static long debugline; /* line number of latest debug opcode */
|
static long debugline; /* line number of latest debug opcode */
|
||||||
@@ -61,26 +62,49 @@ initfunctions(void)
|
|||||||
void
|
void
|
||||||
showfunctions(void)
|
showfunctions(void)
|
||||||
{
|
{
|
||||||
FUNC **fpp; /* pointer into function table */
|
|
||||||
FUNC *fp; /* current function */
|
FUNC *fp; /* current function */
|
||||||
long count;
|
long count;
|
||||||
|
long index;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
if (funccount > 0) {
|
if (funccount > 0) {
|
||||||
for (fpp = &functions[funccount - 1]; fpp >= functions; fpp--) {
|
if (conf->lib_debug & LIBDBG_FUNC_INFO)
|
||||||
fp = *fpp;
|
math_str("Index\tName \tArgs\tOpcodes\n"
|
||||||
if (fp == NULL)
|
"-----\t------ \t---- \t------\n");
|
||||||
continue;
|
else
|
||||||
if (count++ == 0) {
|
math_str("Name\tArguments\n"
|
||||||
printf("Name Arguments\n---- ---------\n");
|
"----\t---------\n");
|
||||||
|
for (index = 0; index < funccount; index++) {
|
||||||
|
fp = functions[index];
|
||||||
|
if (conf->lib_debug & LIBDBG_FUNC_INFO) {
|
||||||
|
|
||||||
|
math_fmt("%5ld\t%-12s\t", index,
|
||||||
|
namestr(&funcnames,index));
|
||||||
|
if (fp) {
|
||||||
|
count++;
|
||||||
|
math_fmt("%-5d\t%-5ld\n",
|
||||||
|
fp->f_paramcount, fp->f_opcodecount);
|
||||||
|
} else {
|
||||||
|
math_str("null\t0\n");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (fp == NULL)
|
||||||
|
continue;
|
||||||
|
count++;
|
||||||
|
math_fmt("%-12s\t%-2d\n", namestr(&funcnames,
|
||||||
|
index), fp->f_paramcount);
|
||||||
}
|
}
|
||||||
printf("%-12s %-2d\n", fp->f_name, fp->f_paramcount);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (count > 0) {
|
if (conf->lib_debug & LIBDBG_FUNC_INFO) {
|
||||||
printf("\nNumber: %ld\n", count);
|
math_fmt("\nNumber non-null: %ld\n", count);
|
||||||
|
math_fmt("Number null: %ld\n", funccount - count);
|
||||||
|
math_fmt("Total number: %ld\n", funccount);
|
||||||
} else {
|
} else {
|
||||||
printf("No user functions defined\n");
|
if (count > 0)
|
||||||
|
math_fmt("\nNumber: %ld\n", count);
|
||||||
|
else
|
||||||
|
math_str("No user functions defined\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -114,7 +138,9 @@ beginfunc(char *name, BOOL newflag)
|
|||||||
fp->f_localcount = 0;
|
fp->f_localcount = 0;
|
||||||
fp->f_opcodecount = 0;
|
fp->f_opcodecount = 0;
|
||||||
fp->f_savedvalue.v_type = V_NULL;
|
fp->f_savedvalue.v_type = V_NULL;
|
||||||
fp->f_name = namestr(&funcnames, newindex);
|
fp->f_savedvalue.v_subtype = V_NOSUBTYPE;
|
||||||
|
newname = namestr(&funcnames, newindex);
|
||||||
|
fp->f_name = newname;
|
||||||
curfunc = fp;
|
curfunc = fp;
|
||||||
initlocals();
|
initlocals();
|
||||||
initlabels();
|
initlabels();
|
||||||
@@ -141,10 +167,11 @@ endfunc(void)
|
|||||||
addop(OP_UNDEF);
|
addop(OP_UNDEF);
|
||||||
addop(OP_RETURN);
|
addop(OP_RETURN);
|
||||||
}
|
}
|
||||||
|
|
||||||
checklabels();
|
checklabels();
|
||||||
|
|
||||||
if (errorcount) {
|
if (errorcount) {
|
||||||
freefunc(curfunc);
|
printf("\"%s\": %ld error%s\n", newname, errorcount,
|
||||||
printf("\"%s\": %ld error%s\n", curfunc->f_name, errorcount,
|
|
||||||
((errorcount == 1) ? "" : "s"));
|
((errorcount == 1) ? "" : "s"));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -166,8 +193,8 @@ endfunc(void)
|
|||||||
}
|
}
|
||||||
if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
|
if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
|
||||||
(!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC)) {
|
(!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC)) {
|
||||||
printf("%s(", fp->f_name);
|
printf("%s(", newname);
|
||||||
for (index = 0; index < fp->f_paramcount; index++) {
|
for (index = 0; index < fp->f_paramcount; index++) {
|
||||||
if (index)
|
if (index)
|
||||||
putchar(',');
|
putchar(',');
|
||||||
printf("%s", paramname(index));
|
printf("%s", paramname(index));
|
||||||
@@ -230,7 +257,7 @@ rmuserfunc(char *name)
|
|||||||
|
|
||||||
index = findstr(&funcnames, name);
|
index = findstr(&funcnames, name);
|
||||||
if (index < 0) {
|
if (index < 0) {
|
||||||
printf("%s() has never been defined\n",
|
fprintf(stderr, "%s() has never been defined\n",
|
||||||
name);
|
name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -251,12 +278,25 @@ rmuserfunc(char *name)
|
|||||||
void
|
void
|
||||||
freefunc(FUNC *fp)
|
freefunc(FUNC *fp)
|
||||||
{
|
{
|
||||||
|
long index;
|
||||||
long i;
|
long i;
|
||||||
|
|
||||||
if (fp == NULL)
|
if (fp == NULL)
|
||||||
return;
|
return;
|
||||||
|
if (fp == curfunc) {
|
||||||
|
index = newindex;
|
||||||
|
} else {
|
||||||
|
for (index = 0; index < funccount; index++) {
|
||||||
|
if (functions[index] == fp)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (index == funccount) {
|
||||||
|
math_error("Bad call to freefunc!!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
}
|
||||||
if (conf->traceflags & TRACE_FNCODES) {
|
if (conf->traceflags & TRACE_FNCODES) {
|
||||||
printf("Freeing function \"%s\"\n", fp->f_name);
|
printf("Freeing function \"%s\"\n",namestr(&funcnames,index));
|
||||||
dumpnames = FALSE;
|
dumpnames = FALSE;
|
||||||
for (i = 0; i < fp->f_opcodecount; ) {
|
for (i = 0; i < fp->f_opcodecount; ) {
|
||||||
printf("%ld: ", i);
|
printf("%ld: ", i);
|
||||||
@@ -272,12 +312,14 @@ freefunc(FUNC *fp)
|
|||||||
void
|
void
|
||||||
rmalluserfunc(void)
|
rmalluserfunc(void)
|
||||||
{
|
{
|
||||||
FUNC **fpp;
|
FUNC *fp;
|
||||||
|
long index;
|
||||||
|
|
||||||
for (fpp = functions; fpp < &functions[funccount]; fpp++) {
|
for (index = 0; index < funccount; index++) {
|
||||||
if (*fpp) {
|
fp = functions[index];
|
||||||
freefunc(*fpp);
|
if (fp) {
|
||||||
*fpp = NULL;
|
freefunc(fp);
|
||||||
|
functions[index] = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -290,12 +332,12 @@ rmalluserfunc(void)
|
|||||||
long
|
long
|
||||||
getuserfunc(char *name)
|
getuserfunc(char *name)
|
||||||
{
|
{
|
||||||
long index;
|
long index;
|
||||||
|
|
||||||
index = findstr(&funcnames, name);
|
index = findstr(&funcnames, name);
|
||||||
if (index >= 0 && functions[index] != NULL)
|
if (index >= 0 && functions[index] != NULL)
|
||||||
return index;
|
return index;
|
||||||
return -1L;
|
return -1L;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -461,7 +503,8 @@ addop(long op)
|
|||||||
fp->f_opcodecount -= diff;
|
fp->f_opcodecount -= diff;
|
||||||
oldop = OP_NOP;
|
oldop = OP_NOP;
|
||||||
oldoldop = OP_NOP;
|
oldoldop = OP_NOP;
|
||||||
fprintf(stderr, "%ld: unused value ignored\n",
|
fprintf(stderr,
|
||||||
|
"Line %ld: unused value ignored\n",
|
||||||
linenumber());
|
linenumber());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -534,8 +577,7 @@ addop(long op)
|
|||||||
qfree(q);
|
qfree(q);
|
||||||
fp->f_opcodes[count - 2] = OP_ZERO;
|
fp->f_opcodes[count - 2] = OP_ZERO;
|
||||||
fp->f_opcodecount--;
|
fp->f_opcodecount--;
|
||||||
}
|
} else if (qisone(q)) {
|
||||||
else if (qisone(q)) {
|
|
||||||
qfree(q);
|
qfree(q);
|
||||||
fp->f_opcodes[count - 2] = OP_ONE;
|
fp->f_opcodes[count - 2] = OP_ONE;
|
||||||
fp->f_opcodecount--;
|
fp->f_opcodecount--;
|
||||||
@@ -638,5 +680,3 @@ addoplabel(long op, LABEL *label)
|
|||||||
addop(op);
|
addop(op);
|
||||||
uselabel(label);
|
uselabel(label);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* END CODE */
|
|
||||||
|
10
align32.c
10
align32.c
@@ -12,11 +12,11 @@
|
|||||||
* copyright this code.
|
* copyright this code.
|
||||||
*
|
*
|
||||||
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
||||||
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MER-
|
* THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MER-
|
||||||
* CHANTABILITY AND FITNESS. IN NO EVENT SHALL LANDON CURT
|
* CHANTABILITY AND FITNESS. IN NO EVENT SHALL LANDON CURT
|
||||||
* NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
|
* NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
|
||||||
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
*/
|
*/
|
||||||
@@ -70,7 +70,7 @@ main(void)
|
|||||||
* buserr - catch an alignment error
|
* buserr - catch an alignment error
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* arg to keep ANSI C happy
|
* arg to keep ANSI C happy
|
||||||
*/
|
*/
|
||||||
/*ARGSUSED*/
|
/*ARGSUSED*/
|
||||||
static void
|
static void
|
||||||
|
46
assocfunc.c
46
assocfunc.c
@@ -14,10 +14,10 @@
|
|||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
|
||||||
|
|
||||||
#define MINHASHSIZE 31 /* minimum size of hash tables */
|
#define MINHASHSIZE 31 /* minimum size of hash tables */
|
||||||
#define GROWHASHSIZE 50 /* approximate growth for hash tables */
|
#define GROWHASHSIZE 50 /* approximate growth for hash tables */
|
||||||
#define CHAINLENGTH 10 /* desired number of elements on a hash chain */
|
#define CHAINLENGTH 10 /* desired number of elements on a hash chain */
|
||||||
#define ELEMSIZE(n) (sizeof(ASSOCELEM) + (sizeof(VALUE) * ((n) - 1)))
|
#define ELEMSIZE(n) (sizeof(ASSOCELEM) + (sizeof(VALUE) * ((n) - 1)))
|
||||||
|
|
||||||
|
|
||||||
static ASSOCELEM *elemindex(ASSOC *ap, long index);
|
static ASSOCELEM *elemindex(ASSOC *ap, long index);
|
||||||
@@ -47,8 +47,8 @@ associndex(ASSOC *ap, BOOL create, long dim, VALUE *indices)
|
|||||||
QCKHASH hash;
|
QCKHASH hash;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (dim <= 0) {
|
if (dim < 0) {
|
||||||
math_error("No dimensions for indexing association");
|
math_error("Negative dimension for indexing association");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -80,6 +80,7 @@ associndex(ASSOC *ap, BOOL create, long dim, VALUE *indices)
|
|||||||
*/
|
*/
|
||||||
if (!create) {
|
if (!create) {
|
||||||
val.v_type = V_NULL;
|
val.v_type = V_NULL;
|
||||||
|
val.v_subtype = V_NOSUBTYPE;
|
||||||
return &val;
|
return &val;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -216,6 +217,27 @@ assocfindex(ASSOC *ap, long index)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns the list of indices for an association element with specified
|
||||||
|
* double-bracket index.
|
||||||
|
*/
|
||||||
|
LIST *
|
||||||
|
associndices(ASSOC *ap, long index)
|
||||||
|
{
|
||||||
|
ASSOCELEM *ep;
|
||||||
|
LIST *lp;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
ep = elemindex(ap, index);
|
||||||
|
if (ep == NULL)
|
||||||
|
return NULL;
|
||||||
|
lp = listalloc();
|
||||||
|
for (i = 0; i < ep->e_dim; i++)
|
||||||
|
insertlistlast(lp, &ep->e_indices[i]);
|
||||||
|
return lp;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Compare two associations to see if they are identical.
|
* Compare two associations to see if they are identical.
|
||||||
* Returns TRUE if they are different.
|
* Returns TRUE if they are different.
|
||||||
@@ -244,8 +266,7 @@ assoccmp(ASSOC *ap1, ASSOC *ap2)
|
|||||||
hash = ep1->e_hash;
|
hash = ep1->e_hash;
|
||||||
dim = ep1->e_dim;
|
dim = ep1->e_dim;
|
||||||
for (ep2 = ap2->a_table[hash % size2]; ;
|
for (ep2 = ap2->a_table[hash % size2]; ;
|
||||||
ep2 = ep2->e_next)
|
ep2 = ep2->e_next) {
|
||||||
{
|
|
||||||
if (ep2 == NULL)
|
if (ep2 == NULL)
|
||||||
return TRUE;
|
return TRUE;
|
||||||
if (ep2->e_hash != hash)
|
if (ep2->e_hash != hash)
|
||||||
@@ -282,8 +303,7 @@ assoccopy(ASSOC *oldap)
|
|||||||
|
|
||||||
for (oldhi = 0; oldhi < oldap->a_size; oldhi++) {
|
for (oldhi = 0; oldhi < oldap->a_size; oldhi++) {
|
||||||
for (oldep = oldap->a_table[oldhi]; oldep;
|
for (oldep = oldap->a_table[oldhi]; oldep;
|
||||||
oldep = oldep->e_next)
|
oldep = oldep->e_next) {
|
||||||
{
|
|
||||||
ep = (ASSOCELEM *) malloc(ELEMSIZE(oldep->e_dim));
|
ep = (ASSOCELEM *) malloc(ELEMSIZE(oldep->e_dim));
|
||||||
if (ep == NULL) {
|
if (ep == NULL) {
|
||||||
math_error("Cannot allocate association element");
|
math_error("Cannot allocate association element");
|
||||||
@@ -292,6 +312,7 @@ assoccopy(ASSOC *oldap)
|
|||||||
ep->e_dim = oldep->e_dim;
|
ep->e_dim = oldep->e_dim;
|
||||||
ep->e_hash = oldep->e_hash;
|
ep->e_hash = oldep->e_hash;
|
||||||
ep->e_value.v_type = V_NULL;
|
ep->e_value.v_type = V_NULL;
|
||||||
|
ep->e_value.v_subtype = V_NOSUBTYPE;
|
||||||
for (i = 0; i < ep->e_dim; i++)
|
for (i = 0; i < ep->e_dim; i++)
|
||||||
copyvalue(&oldep->e_indices[i], &ep->e_indices[i]);
|
copyvalue(&oldep->e_indices[i], &ep->e_indices[i]);
|
||||||
copyvalue(&oldep->e_value, &ep->e_value);
|
copyvalue(&oldep->e_value, &ep->e_value);
|
||||||
@@ -447,8 +468,7 @@ assocprint(ASSOC *ap, long max_print)
|
|||||||
((ap->a_count == 1) ? "" : "s"));
|
((ap->a_count == 1) ? "" : "s"));
|
||||||
|
|
||||||
for (index = 0; ((index < max_print) && (index < ap->a_count));
|
for (index = 0; ((index < max_print) && (index < ap->a_count));
|
||||||
index++)
|
index++) {
|
||||||
{
|
|
||||||
ep = elemindex(ap, index);
|
ep = elemindex(ap, index);
|
||||||
if (ep == NULL)
|
if (ep == NULL)
|
||||||
continue;
|
continue;
|
||||||
@@ -489,5 +509,3 @@ compareindices(VALUE *v1, VALUE *v2, long dim)
|
|||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* END CODE */
|
|
||||||
|
17
blkcpy.c
17
blkcpy.c
@@ -330,6 +330,7 @@ copyblk2mat(BLOCK *blk, long ssi, long num, MATRIX *dmat, long dsi)
|
|||||||
i = num;
|
i = num;
|
||||||
while (i-- > 0) {
|
while (i-- > 0) {
|
||||||
vp->v_type = V_NUM;
|
vp->v_type = V_NUM;
|
||||||
|
vp->v_subtype = V_NOSUBTYPE;
|
||||||
vp->v_num = itoq((long) *op++);
|
vp->v_num = itoq((long) *op++);
|
||||||
vp++;
|
vp++;
|
||||||
}
|
}
|
||||||
@@ -546,7 +547,7 @@ copylist2list(LIST *slp, long ssi, long num, LIST *dlp, long dsi)
|
|||||||
int
|
int
|
||||||
copyblk2file(BLOCK *sblk, long ssi, long num, FILEID id, long dsi)
|
copyblk2file(BLOCK *sblk, long ssi, long num, FILEID id, long dsi)
|
||||||
{
|
{
|
||||||
FILEIO *fiop;
|
FILEIO *fiop;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
unsigned int numw;
|
unsigned int numw;
|
||||||
|
|
||||||
@@ -562,7 +563,7 @@ copyblk2file(BLOCK *sblk, long ssi, long num, FILEID id, long dsi)
|
|||||||
return E_COPYF1;
|
return E_COPYF1;
|
||||||
fp = fiop->fp;
|
fp = fiop->fp;
|
||||||
if (id == 1 || id == 2) {
|
if (id == 1 || id == 2) {
|
||||||
numw = idfputstr(id, (char *)sblk->data + ssi); /* XXX */
|
numw = idfputstr(id, (char *)sblk->data + ssi); /* XXX */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (dsi >= 0) {
|
if (dsi >= 0) {
|
||||||
@@ -583,7 +584,7 @@ copyblk2file(BLOCK *sblk, long ssi, long num, FILEID id, long dsi)
|
|||||||
int
|
int
|
||||||
copyfile2blk(FILEID id, long ssi, long num, BLOCK *dblk, long dsi, BOOL noreloc)
|
copyfile2blk(FILEID id, long ssi, long num, BLOCK *dblk, long dsi, BOOL noreloc)
|
||||||
{
|
{
|
||||||
FILEIO *fiop;
|
FILEIO *fiop;
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
unsigned int numw;
|
unsigned int numw;
|
||||||
ZVALUE fsize;
|
ZVALUE fsize;
|
||||||
@@ -671,7 +672,7 @@ copystr2file(STRING *str, long ssi, long num, FILEID id, long dsi)
|
|||||||
return E_COPYF1;
|
return E_COPYF1;
|
||||||
fp = fiop->fp;
|
fp = fiop->fp;
|
||||||
if (id == 1 || id == 2) {
|
if (id == 1 || id == 2) {
|
||||||
numw = idfputstr(id, str->s_str + ssi); /* XXX */
|
numw = idfputstr(id, str->s_str + ssi); /* XXX */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (dsi >= 0) {
|
if (dsi >= 0) {
|
||||||
@@ -829,7 +830,7 @@ int
|
|||||||
copyostr2str(char *sstr, long ssi, long num, STRING *dstr, long dsi)
|
copyostr2str(char *sstr, long ssi, long num, STRING *dstr, long dsi)
|
||||||
{
|
{
|
||||||
long len;
|
long len;
|
||||||
char *c, *c1;
|
char *c, *c1;
|
||||||
|
|
||||||
len = (long)strlen(sstr);
|
len = (long)strlen(sstr);
|
||||||
|
|
||||||
@@ -897,8 +898,8 @@ copyostr2blk(char *str,long ssi,long num,BLOCK *dblk,long dsi,BOOL noreloc)
|
|||||||
* Copying between objects that overlap will take place correctly.
|
* Copying between objects that overlap will take place correctly.
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* s1 destination
|
* s1 destination
|
||||||
* s2 source
|
* s2 source
|
||||||
* n octet count
|
* n octet count
|
||||||
*
|
*
|
||||||
* returns:
|
* returns:
|
||||||
@@ -958,7 +959,7 @@ copynum2blk(NUMBER *snum, long ssi, long num, BLOCK *dblk, long dsi, BOOL norelo
|
|||||||
long newsize;
|
long newsize;
|
||||||
USB8 *newdata;
|
USB8 *newdata;
|
||||||
#if CALC_BYTE_ORDER == BIG_ENDIAN
|
#if CALC_BYTE_ORDER == BIG_ENDIAN
|
||||||
ZVALUE *swnum; /* byte swapped numerator */
|
ZVALUE *swnum; /* byte swapped numerator */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (ssi > snum->num.len)
|
if (ssi > snum->num.len)
|
||||||
|
2
blkcpy.h
2
blkcpy.h
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#if !defined(__BLKCPY_H__)
|
#if !defined(__BLKCPY_H__)
|
||||||
#define __BLKCPY_H__
|
#define __BLKCPY_H__
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* the main copy gateway function
|
* the main copy gateway function
|
||||||
|
27
block.c
27
block.c
@@ -23,7 +23,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
@@ -141,7 +141,7 @@ blk_free(BLOCK *blk)
|
|||||||
/*
|
/*
|
||||||
* blkchk - check the sanity of a block
|
* blkchk - check the sanity of a block
|
||||||
*
|
*
|
||||||
* These checks should never fail if calc is working correctly. During
|
* These checks should never fail if calc is working correctly. During
|
||||||
* debug time, we plan to call this function often. Once we are satisfied,
|
* debug time, we plan to call this function often. Once we are satisfied,
|
||||||
* we will normally call this code only in a few places.
|
* we will normally call this code only in a few places.
|
||||||
*
|
*
|
||||||
@@ -205,13 +205,13 @@ blkchk(BLOCK *blk)
|
|||||||
*
|
*
|
||||||
* Reallocation of a block can change several aspects of a block.
|
* Reallocation of a block can change several aspects of a block.
|
||||||
*
|
*
|
||||||
* It can change the much data it holds or can hold.
|
* It can change the much data it holds or can hold.
|
||||||
*
|
*
|
||||||
* It can change the memory footprint (in terms of
|
* It can change the memory footprint (in terms of
|
||||||
* how much storage is malloced for current or future use).
|
* how much storage is malloced for current or future use).
|
||||||
*
|
*
|
||||||
* It can change the chunk size used to grow malloced size
|
* It can change the chunk size used to grow malloced size
|
||||||
* as the data size grows.
|
* as the data size grows.
|
||||||
*
|
*
|
||||||
* Each of the len and chunksize may be kept the same.
|
* Each of the len and chunksize may be kept the same.
|
||||||
*
|
*
|
||||||
@@ -329,7 +329,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
|
|||||||
/*
|
/*
|
||||||
* blktrunc - truncate a BLOCK down to a minimal fixed block
|
* blktrunc - truncate a BLOCK down to a minimal fixed block
|
||||||
*
|
*
|
||||||
* NOTE: THIS IS NOT THE INTERNAL CALC FREE FUNCTION!! This
|
* NOTE: THIS IS NOT THE INTERNAL CALC FREE FUNCTION!! This
|
||||||
* is what blktrunc() builtin calls to reduce storage of a block
|
* is what blktrunc() builtin calls to reduce storage of a block
|
||||||
* down to an absolute minimum.
|
* down to an absolute minimum.
|
||||||
*
|
*
|
||||||
@@ -479,7 +479,7 @@ blk_print(BLOCK *blk)
|
|||||||
BOOL havetail;
|
BOOL havetail;
|
||||||
USB8 *ptr;
|
USB8 *ptr;
|
||||||
|
|
||||||
/* XXX - use the config parameters for better print control */
|
/* XXX - should use the config parameters for better print control */
|
||||||
|
|
||||||
printf("chunksize = %d, maxsize = %d, datalen = %d\n\t",
|
printf("chunksize = %d, maxsize = %d, datalen = %d\n\t",
|
||||||
(int)blk->blkchunk, (int)blk->maxsize, (int)blk->datalen);
|
(int)blk->blkchunk, (int)blk->maxsize, (int)blk->datalen);
|
||||||
@@ -512,9 +512,9 @@ nblock_print(NBLOCK *nblk)
|
|||||||
printf("chunksize = %d, maxsize = %d, datalen = %d\n\t",
|
printf("chunksize = %d, maxsize = %d, datalen = %d\n\t",
|
||||||
(int)blk->blkchunk, (int)blk->maxsize, (int)blk->datalen);
|
(int)blk->blkchunk, (int)blk->maxsize, (int)blk->datalen);
|
||||||
printf("NULL");
|
printf("NULL");
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
blk_print(blk);
|
blk_print(blk);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -556,8 +556,7 @@ reallocnblock(int id, int len, int chunk)
|
|||||||
math_error("Allocation failed");
|
math_error("Allocation failed");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
}
|
} else if (newsize != oldsize) {
|
||||||
else if (newsize != oldsize) {
|
|
||||||
newdata = realloc(blk->data, newsize);
|
newdata = realloc(blk->data, newsize);
|
||||||
if (newdata == NULL) {
|
if (newdata == NULL) {
|
||||||
math_error("Reallocation failed");
|
math_error("Reallocation failed");
|
||||||
@@ -719,7 +718,7 @@ findnblock(int id)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a new block with specified newlen and new chunksize and copy
|
* Create a new block with specified newlen and new chunksize and copy
|
||||||
* min(newlen, oldlen) octets to the new block. The old block is
|
* min(newlen, oldlen) octets to the new block. The old block is
|
||||||
* not changed.
|
* not changed.
|
||||||
*/
|
*/
|
||||||
BLOCK *
|
BLOCK *
|
||||||
@@ -730,7 +729,7 @@ copyrealloc(BLOCK *blk, int newlen, int newchunk)
|
|||||||
|
|
||||||
oldlen = blk->datalen;
|
oldlen = blk->datalen;
|
||||||
|
|
||||||
if (newlen < 0) /* retain length */
|
if (newlen < 0) /* retain length */
|
||||||
newlen = oldlen;
|
newlen = oldlen;
|
||||||
|
|
||||||
if (newchunk < 0) /* retain chunksize */
|
if (newchunk < 0) /* retain chunksize */
|
||||||
|
8
block.h
8
block.h
@@ -23,7 +23,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
@@ -35,7 +35,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#if !defined(__BLOCK_H__)
|
#if !defined(__BLOCK_H__)
|
||||||
#define __BLOCK_H__
|
#define __BLOCK_H__
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -139,8 +139,8 @@
|
|||||||
* style of output = {
|
* style of output = {
|
||||||
* "line", lines in blkbase with no spaces between octets
|
* "line", lines in blkbase with no spaces between octets
|
||||||
* "string", as one long line with no spaces between octets
|
* "string", as one long line with no spaces between octets
|
||||||
* "od_style", position, spaces between octets
|
* "od_style", position, spaces between octets
|
||||||
* "hd_style"} position, spaces between octets, chars on end
|
* "hd_style"} position, spaces between octets, chars on end
|
||||||
*/
|
*/
|
||||||
struct block {
|
struct block {
|
||||||
LEN blkchunk; /* allocation chunk size */
|
LEN blkchunk; /* allocation chunk size */
|
||||||
|
@@ -28,9 +28,9 @@
|
|||||||
* swap_b8_in_HALFs - swap 8 and if needed, 16 bits in an array of HALFs
|
* swap_b8_in_HALFs - swap 8 and if needed, 16 bits in an array of HALFs
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* dest - pointer to where the swapped src wil be put or
|
* dest - pointer to where the swapped src wil be put or
|
||||||
* NULL to allocate the storage
|
* NULL to allocate the storage
|
||||||
* src - pointer to a HALF array to swap
|
* src - pointer to a HALF array to swap
|
||||||
* len - length of the src HALF array
|
* len - length of the src HALF array
|
||||||
*
|
*
|
||||||
* returns:
|
* returns:
|
||||||
@@ -263,9 +263,9 @@ swap_b8_in_COMPLEX(COMPLEX *dest, COMPLEX *src, BOOL all)
|
|||||||
* swap_b16_in_HALFs - swap 16 bits in an array of HALFs
|
* swap_b16_in_HALFs - swap 16 bits in an array of HALFs
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* dest - pointer to where the swapped src wil be put or
|
* dest - pointer to where the swapped src wil be put or
|
||||||
* NULL to allocate the storage
|
* NULL to allocate the storage
|
||||||
* src - pointer to a HALF array to swap
|
* src - pointer to a HALF array to swap
|
||||||
* len - length of the src HALF array
|
* len - length of the src HALF array
|
||||||
*
|
*
|
||||||
* returns:
|
* returns:
|
||||||
|
2
calc.c
2
calc.c
@@ -394,7 +394,7 @@ main(int argc, char **argv)
|
|||||||
printf("DEBUG: run_state from %s to %s\n",
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
run_state_name(run_state),
|
run_state_name(run_state),
|
||||||
run_state_name(RUN_EXIT_WITH_ERROR));
|
run_state_name(RUN_EXIT_WITH_ERROR));
|
||||||
run_state = RUN_EXIT_WITH_ERROR;
|
run_state = RUN_EXIT_WITH_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
63
calc.h
63
calc.h
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#if !defined(__CALC_H__)
|
#if !defined(__CALC_H__)
|
||||||
#define __CALC_H__
|
#define __CALC_H__
|
||||||
|
|
||||||
#include <setjmp.h>
|
#include <setjmp.h>
|
||||||
|
|
||||||
@@ -20,42 +20,43 @@
|
|||||||
/*
|
/*
|
||||||
* Configuration definitions
|
* Configuration definitions
|
||||||
*/
|
*/
|
||||||
#define CALCPATH "CALCPATH" /* environment variable for files */
|
#define CALCPATH "CALCPATH" /* environment variable for files */
|
||||||
#define CALCRC "CALCRC" /* environment variable for startup */
|
#define CALCRC "CALCRC" /* environment variable for startup */
|
||||||
#define CALCBINDINGS "CALCBINDINGS" /* environment variable for hist bindings */
|
#define CALCBINDINGS "CALCBINDINGS" /* env variable for hist bindings */
|
||||||
#define HOME "HOME" /* environment variable for home dir */
|
#define HOME "HOME" /* environment variable for home dir */
|
||||||
#define PAGER "PAGER" /* environment variable for help */
|
#define PAGER "PAGER" /* environment variable for help */
|
||||||
#define SHELL "SHELL" /* environment variable for shell */
|
#define SHELL "SHELL" /* environment variable for shell */
|
||||||
#define DEFAULTCALCHELP "help" /* help file that -h prints */
|
#define DEFAULTCALCBINDINGS "bindings" /* default calc bindings file */
|
||||||
|
#define DEFAULTCALCHELP "help" /* help file that -h prints */
|
||||||
#define DEFAULTSHELL "sh" /* default shell to use */
|
#define DEFAULTSHELL "sh" /* default shell to use */
|
||||||
#define CALCEXT ".cal" /* extension for files read in */
|
#define CALCEXT ".cal" /* extension for files read in */
|
||||||
#define MAX_CALCRC 1024 /* maximum length of $CALCRC */
|
#define MAX_CALCRC 1024 /* maximum length of $CALCRC */
|
||||||
#define HOMECHAR '~' /* char which indicates home directory */
|
#define HOMECHAR '~' /* char which indicates home directory */
|
||||||
#define DOTCHAR '.' /* char which indicates current directory */
|
#define DOTCHAR '.' /* char which indicates current directory */
|
||||||
#define PATHCHAR '/' /* char which separates path components */
|
#define PATHCHAR '/' /* char which separates path components */
|
||||||
#define LISTCHAR ':' /* char which separates paths in a list */
|
#define LISTCHAR ':' /* char which separates paths in a list */
|
||||||
#define MAXCMD 16384 /* maximum length of command invocation */
|
#define MAXCMD 16384 /* maximum length of command invocation */
|
||||||
#define MAXERROR 512 /* maximum length of error message string */
|
#define MAXERROR 512 /* maximum length of error message string */
|
||||||
|
|
||||||
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
||||||
#define MAXINDICES 20 /* maximum number of indices for objects */
|
#define MAXINDICES 20 /* maximum number of indices for objects */
|
||||||
#define MAXLABELS 100 /* maximum number of user labels in function */
|
#define MAXLABELS 100 /* maximum number of user labels in function */
|
||||||
#define MAXSTRING 1024 /* maximum size of string constant */
|
#define MAXSTRING 1024 /* maximum size of string constant */
|
||||||
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
||||||
#define MAXFILES 20 /* maximum number of opened files */
|
#define MAXFILES 20 /* maximum number of opened files */
|
||||||
#define PROMPT1 "> " /* default normal prompt*/
|
#define PROMPT1 "> " /* default normal prompt*/
|
||||||
#define PROMPT2 ">> " /* default prompt inside multi-line input */
|
#define PROMPT2 ">> " /* default prompt inside multi-line input */
|
||||||
|
|
||||||
|
|
||||||
#define TRACE_NORMAL 0x00 /* normal trace flags */
|
#define TRACE_NORMAL 0x00 /* normal trace flags */
|
||||||
#define TRACE_OPCODES 0x01 /* trace every opcode */
|
#define TRACE_OPCODES 0x01 /* trace every opcode */
|
||||||
#define TRACE_NODEBUG 0x02 /* suppress debugging opcodes */
|
#define TRACE_NODEBUG 0x02 /* suppress debugging opcodes */
|
||||||
#define TRACE_LINKS 0x04 /* display links for real and complex numbers */
|
#define TRACE_LINKS 0x04 /* display links for real and complex numbers */
|
||||||
#define TRACE_FNCODES 0x08 /* display code for newly defined function */
|
#define TRACE_FNCODES 0x08 /* display code for newly defined function */
|
||||||
#define TRACE_MAX 0x0f /* maximum value for trace flag */
|
#define TRACE_MAX 0x0f /* maximum value for trace flag */
|
||||||
|
|
||||||
#define ABORT_NONE 0 /* abort not needed yet */
|
#define ABORT_NONE 0 /* abort not needed yet */
|
||||||
#define ABORT_STATEMENT 1 /* abort on statement boundary */
|
#define ABORT_STATEMENT 1 /* abort on statement boundary */
|
||||||
#define ABORT_OPCODE 2 /* abort on any opcode boundary */
|
#define ABORT_OPCODE 2 /* abort on any opcode boundary */
|
||||||
#define ABORT_MATH 3 /* abort on any math operation */
|
#define ABORT_MATH 3 /* abort on any math operation */
|
||||||
#define ABORT_NOW 4 /* abort right away */
|
#define ABORT_NOW 4 /* abort right away */
|
||||||
@@ -65,10 +66,10 @@
|
|||||||
/*
|
/*
|
||||||
* File ids corresponding to standard in, out, error, and when not in use.
|
* File ids corresponding to standard in, out, error, and when not in use.
|
||||||
*/
|
*/
|
||||||
#define FILEID_STDIN ((FILEID) 0)
|
#define FILEID_STDIN ((FILEID) 0)
|
||||||
#define FILEID_STDOUT ((FILEID) 1)
|
#define FILEID_STDOUT ((FILEID) 1)
|
||||||
#define FILEID_STDERR ((FILEID) 2)
|
#define FILEID_STDERR ((FILEID) 2)
|
||||||
#define FILEID_NONE ((FILEID) -1)
|
#define FILEID_NONE ((FILEID) -1)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* File I/O routines.
|
* File I/O routines.
|
||||||
@@ -192,7 +193,7 @@ extern int errmax; /* if >= 0, error when errcount exceeds errmax */
|
|||||||
extern int new_std; /* TRUE (-n) => use newstd configuration */
|
extern int new_std; /* TRUE (-n) => use newstd configuration */
|
||||||
|
|
||||||
extern int allow_read; /* FALSE => may not open any files for reading */
|
extern int allow_read; /* FALSE => may not open any files for reading */
|
||||||
extern int allow_write; /* FALSE => may not open any files for writing */
|
extern int allow_write; /* FALSE => may not open any files for writing */
|
||||||
extern int allow_exec; /* FALSE => may not execute any commands */
|
extern int allow_exec; /* FALSE => may not execute any commands */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
50
calc.man
50
calc.man
@@ -340,7 +340,7 @@ Normally on startup,
|
|||||||
attempts to execute a collection of
|
attempts to execute a collection of
|
||||||
library scripts.
|
library scripts.
|
||||||
The environment variable $CALCRC (if non-existent
|
The environment variable $CALCRC (if non-existent
|
||||||
then a compiled in value) contains a : separated list of startup
|
then a compiled in value) contains a : separated list of startup
|
||||||
library scripts.
|
library scripts.
|
||||||
No error conditions are produced if these startup
|
No error conditions are produced if these startup
|
||||||
library scripts are not found.
|
library scripts are not found.
|
||||||
@@ -555,9 +555,10 @@ line, or \fI\-m\fP disallows opening files for reading),
|
|||||||
reads
|
reads
|
||||||
key bindings from the filename specified
|
key bindings from the filename specified
|
||||||
by this environment variable.
|
by this environment variable.
|
||||||
.br
|
The key binding file is searched for along the $CALCPATH list
|
||||||
|
of directories.
|
||||||
.sp
|
.sp
|
||||||
Default value: ${CALCBINDINGS}
|
Default value: binding
|
||||||
.sp
|
.sp
|
||||||
This variable is not used if calc was compiled with GNU-readline support.
|
This variable is not used if calc was compiled with GNU-readline support.
|
||||||
In that case, the standard readline mechanisms (see readline(3)) are used.
|
In that case, the standard readline mechanisms (see readline(3)) are used.
|
||||||
@@ -570,7 +571,11 @@ The majority of
|
|||||||
was written by David I. Bell.
|
was written by David I. Bell.
|
||||||
.sp
|
.sp
|
||||||
.B Calc
|
.B Calc
|
||||||
archives and calc-tester mailing list maintained by Landon Curt Noll.
|
The Calc primary mirror, calc mailing list and calc bug report
|
||||||
|
processing is performed by Landon Curt Noll.
|
||||||
|
.sp
|
||||||
|
Landon Curt Noll maintains the master reference source, performs
|
||||||
|
release control functions as well as other calc maintenance functions.
|
||||||
.sp
|
.sp
|
||||||
Thanks for suggestions and encouragement from Peter Miller,
|
Thanks for suggestions and encouragement from Peter Miller,
|
||||||
Neil Justusson, and Landon Noll.
|
Neil Justusson, and Landon Noll.
|
||||||
@@ -585,7 +590,7 @@ Ernest also supplied the original text for many of the help files.
|
|||||||
.sp
|
.sp
|
||||||
Portions of this program are derived from an earlier set of
|
Portions of this program are derived from an earlier set of
|
||||||
public domain arbitrarily precision routines which was posted
|
public domain arbitrarily precision routines which was posted
|
||||||
to the net around 1984. By now, there is almost no recognizable
|
to the net around 1984. By now, there is almost no recognizable
|
||||||
code left from that original source.
|
code left from that original source.
|
||||||
.sp
|
.sp
|
||||||
Most of this source and binary has one of the following copyrights:
|
Most of this source and binary has one of the following copyrights:
|
||||||
@@ -610,9 +615,36 @@ scripts that you would like you see included
|
|||||||
in future distributions to:
|
in future distributions to:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
calc-tester@postofc.corp.sgi.com
|
.nf
|
||||||
|
calc-tester at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
.fi
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
|
Bug reports are sent to:
|
||||||
|
.in +0.5i
|
||||||
|
.nf
|
||||||
|
calc-bugs at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
.fi
|
||||||
|
.in -0.5i
|
||||||
|
.sp
|
||||||
|
See the
|
||||||
|
.I BUGS
|
||||||
|
source file or use the
|
||||||
|
.I calc
|
||||||
|
command:
|
||||||
|
.sp
|
||||||
|
.in +0.5i
|
||||||
|
.nf
|
||||||
|
help bugs
|
||||||
|
.fi
|
||||||
|
.in -0.5i
|
||||||
|
.sp
|
||||||
|
for more information about bug reporting.
|
||||||
|
.sp
|
||||||
Landon Noll maintains the the
|
Landon Noll maintains the the
|
||||||
.B calc
|
.B calc
|
||||||
web site is located at:
|
web site is located at:
|
||||||
@@ -626,7 +658,11 @@ One may join the
|
|||||||
testing group by sending a request to:
|
testing group by sending a request to:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
.nf
|
||||||
|
calc-tester-request at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
.fi
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
Your message body (not the subject) should consist of:
|
Your message body (not the subject) should consist of:
|
||||||
|
123
calc_errno.c
123
calc_errno.c
@@ -1,123 +0,0 @@
|
|||||||
/*
|
|
||||||
* errno - Determine how to declare errno, sys_errlist and sys_nerr
|
|
||||||
*
|
|
||||||
* On most machines: errno sys_errlist and sys_nerr are declared
|
|
||||||
* by either <stdio.h> and/or <errno.h>. But some systems declare
|
|
||||||
* them somewhere else or do not declare them at all!
|
|
||||||
*
|
|
||||||
* If the system were doing a proper job in headers, this should declare them:
|
|
||||||
*
|
|
||||||
* #include <stdio.h>
|
|
||||||
* #include <errno.h>
|
|
||||||
*
|
|
||||||
* But one some systems one must explicitly declare them as:
|
|
||||||
*
|
|
||||||
* extern int errno;
|
|
||||||
* extern const char *const sys_errlist[];
|
|
||||||
* extern int sys_nerr;
|
|
||||||
*
|
|
||||||
* and on some old systems they must be explicitly and incorrectly declared as:
|
|
||||||
*
|
|
||||||
* extern int errno;
|
|
||||||
* extern char *sys_errlist[];
|
|
||||||
* extern int sys_nerr;
|
|
||||||
*
|
|
||||||
* The purpose of this utility is try and find the right way to declare
|
|
||||||
* them and to output the middle of a header file called calc_errno.h.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Permission to use, copy, modify, and distribute this software and
|
|
||||||
* its documentation for any purpose and without fee is hereby granted,
|
|
||||||
* provided that the above copyright, this permission notice and text
|
|
||||||
* this comment, and the disclaimer below appear in all of the following:
|
|
||||||
*
|
|
||||||
* supporting documentation
|
|
||||||
* source copies
|
|
||||||
* source works derived from this source
|
|
||||||
* binaries derived from this source or from derived source
|
|
||||||
*
|
|
||||||
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
||||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO
|
|
||||||
* EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
|
||||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
|
||||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
||||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
||||||
* PERFORMANCE OF THIS SOFTWARE.
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#if defined(TRY_ERRNO_NO_DECL)
|
|
||||||
# include <errno.h>
|
|
||||||
#endif /* TRY_ERRNO_NO_DECL */
|
|
||||||
|
|
||||||
int
|
|
||||||
main(void)
|
|
||||||
{
|
|
||||||
|
|
||||||
#if defined(TRY_ERRNO_NO_DECL)
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("#include <stdio.h>\n");
|
|
||||||
printf("#include <errno.h>\n");
|
|
||||||
#elif defined(TRY_ERRNO_OLD_DECL)
|
|
||||||
extern int errno; /* last system error */
|
|
||||||
extern char *sys_errlist[]; /* system error messages */
|
|
||||||
extern int sys_nerr; /* number of system errors*/
|
|
||||||
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("extern int errno;\t\t/* last system error */\n");
|
|
||||||
printf("extern char *sys_errlist[];\t"
|
|
||||||
"/* system error messages */\n");
|
|
||||||
printf("extern int sys_nerr;\t\t/* number of system errors*/\n");
|
|
||||||
#else /* assume defined(TRY_ERRNO_STD_DECL) */
|
|
||||||
extern int errno; /* last system error */
|
|
||||||
extern const char *const sys_errlist[]; /* system error messages */
|
|
||||||
extern int sys_nerr; /* number of system errors*/
|
|
||||||
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("extern int errno;\t\t\t/* last system error */\n");
|
|
||||||
printf("extern const char *const sys_errlist[];\t"
|
|
||||||
"/* system error messages */\n");
|
|
||||||
printf("extern int sys_nerr;\t\t\t/* number of system errors*/\n");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* exit(0); */
|
|
||||||
return 0;
|
|
||||||
}
|
|
@@ -336,3 +336,5 @@ E_STRCPY Bad argument type for strcpy
|
|||||||
E_STRNCPY Bad argument type for strncpy
|
E_STRNCPY Bad argument type for strncpy
|
||||||
E_BACKSLASH Bad argument type for unary backslash
|
E_BACKSLASH Bad argument type for unary backslash
|
||||||
E_SETMINUS Bad argument type for setminus
|
E_SETMINUS Bad argument type for setminus
|
||||||
|
E_INDICES1 Bad first argument type for indices
|
||||||
|
E_INDICES2 Bad second argument for indices
|
||||||
|
@@ -6,12 +6,12 @@ BEGIN {
|
|||||||
printf(" * names of calc error values\n");
|
printf(" * names of calc error values\n");
|
||||||
printf(" */\n");
|
printf(" */\n");
|
||||||
printf("CONST char *error_table[E__COUNT+2] = {\n");
|
printf("CONST char *error_table[E__COUNT+2] = {\n");
|
||||||
printf(" \"No error\",\n");
|
printf(" \"No error\",\n");
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
print $0;
|
print $0;
|
||||||
}
|
}
|
||||||
END {
|
END {
|
||||||
printf(" NULL\n");
|
printf(" NULL\n");
|
||||||
printf("};\n");
|
printf("};\n");
|
||||||
}
|
}
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
# This awk script will print 3 lines before and after any non-blank line that
|
# This awk script will print 3 lines before and after any non-blank line that
|
||||||
# does not begin with a number. This allows the 'make debug' rule to remove
|
# does not begin with a number. This allows the 'make debug' rule to remove
|
||||||
# all non-interest lines the the 'make check' regression output while providing
|
# all non-interest lines the the 'make check' regression output while providing
|
||||||
# 3 lines of context around unexpected output.
|
# 3 lines of context around unexpected output.
|
||||||
#
|
#
|
||||||
|
4
cmath.h
4
cmath.h
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#if !defined(__CMATH_H__)
|
#if !defined(__CMATH_H__)
|
||||||
#define __CMATH_H__
|
#define __CMATH_H__
|
||||||
|
|
||||||
|
|
||||||
#include "qmath.h"
|
#include "qmath.h"
|
||||||
@@ -114,7 +114,7 @@ extern COMPLEX *swap_HALF_in_COMPLEX(COMPLEX *dest, COMPLEX *src, BOOL all);
|
|||||||
#define cisnegone(c) (cisreal(c) && qisnegone((c)->real))
|
#define cisnegone(c) (cisreal(c) && qisnegone((c)->real))
|
||||||
#define cisrunit(c) (cisreal(c) && qisunit((c)->real))
|
#define cisrunit(c) (cisreal(c) && qisunit((c)->real))
|
||||||
#define cisiunit(c) (qiszero((c)->real) && qisunit((c)->imag))
|
#define cisiunit(c) (qiszero((c)->real) && qisunit((c)->imag))
|
||||||
#define cisunit(c) (cisrunit(c) || cisiunit(c))
|
#define cisunit(c) (cisrunit(c) || cisiunit(c))
|
||||||
#define cistwo(c) (cisreal(c) && qistwo((c)->real))
|
#define cistwo(c) (cisreal(c) && qistwo((c)->real))
|
||||||
#define cisint(c) (qisint((c)->real) && qisint((c)->imag))
|
#define cisint(c) (qisint((c)->real) && qisint((c)->imag))
|
||||||
#define ciseven(c) (qiseven((c)->real) && qiseven((c)->imag))
|
#define ciseven(c) (qiseven((c)->real) && qiseven((c)->imag))
|
||||||
|
133
codegen.c
133
codegen.c
@@ -180,8 +180,8 @@ getcommands(BOOL toplevel)
|
|||||||
/*
|
/*
|
||||||
* Evaluate a line of statements.
|
* Evaluate a line of statements.
|
||||||
* This is done by treating the current line as a function body,
|
* This is done by treating the current line as a function body,
|
||||||
* compiling it, and then executing it. Returns TRUE if the line
|
* compiling it, and then executing it. Returns TRUE if the line
|
||||||
* successfully compiled and executed. The last expression result
|
* successfully compiled and executed. The last expression result
|
||||||
* is saved in the f_savedvalue element of the current function.
|
* is saved in the f_savedvalue element of the current function.
|
||||||
* The nestflag variable should be FALSE for the outermost evaluation
|
* The nestflag variable should be FALSE for the outermost evaluation
|
||||||
* level, and TRUE for all other calls (such as the 'eval' function).
|
* level, and TRUE for all other calls (such as the 'eval' function).
|
||||||
@@ -956,7 +956,7 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
/*
|
/*
|
||||||
* Read in an object declaration.
|
* Read in an object declaration.
|
||||||
* This is of the following form:
|
* This is of the following form:
|
||||||
* OBJ type [ '{' id [ ',' id ] ... '}' ] [ objlist ].
|
* OBJ type [ '{' id [ ',' id ] ... '}' ] [ objlist ].
|
||||||
* The OBJ keyword has already been read. Symtype is SYM_UNDEFINED if this
|
* The OBJ keyword has already been read. Symtype is SYM_UNDEFINED if this
|
||||||
* is an OBJ statement, otherwise this is part of a declaration which will
|
* is an OBJ statement, otherwise this is part of a declaration which will
|
||||||
* define new symbols with the specified type.
|
* define new symbols with the specified type.
|
||||||
@@ -1135,6 +1135,21 @@ getonematrix(int symtype)
|
|||||||
}
|
}
|
||||||
rescantoken();
|
rescantoken();
|
||||||
|
|
||||||
|
if (gettoken() == T_LEFTPAREN) {
|
||||||
|
if (isrvalue(getexprlist())) {
|
||||||
|
scanerror(T_SEMICOLON, "Lvalue expected");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (gettoken() != T_RIGHTPAREN) {
|
||||||
|
scanerror(T_SEMICOLON, "Missing right parenthesis");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
getonematrix(symtype);
|
||||||
|
addop(OP_ASSIGN);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
rescantoken();
|
||||||
|
|
||||||
if (gettoken() != T_LEFTBRACKET) {
|
if (gettoken() != T_LEFTBRACKET) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
scanerror(T_SEMICOLON, "Left-bracket expected");
|
scanerror(T_SEMICOLON, "Left-bracket expected");
|
||||||
@@ -1150,23 +1165,32 @@ getonematrix(int symtype)
|
|||||||
* will patch the correct value back into the opcode.
|
* will patch the correct value back into the opcode.
|
||||||
*/
|
*/
|
||||||
if (gettoken() == T_RIGHTBRACKET) {
|
if (gettoken() == T_RIGHTBRACKET) {
|
||||||
clearopt();
|
if (gettoken() == T_ASSIGN) {
|
||||||
patchpc = curfunc->f_opcodecount + 1;
|
clearopt();
|
||||||
addopone(OP_NUMBER, (long) -1);
|
patchpc = curfunc->f_opcodecount + 1;
|
||||||
clearopt();
|
addopone(OP_NUMBER, (long) -1);
|
||||||
addop(OP_ZERO);
|
clearopt();
|
||||||
addopone(OP_MATCREATE, dim);
|
addop(OP_ZERO);
|
||||||
addop(OP_ZERO);
|
addopone(OP_MATCREATE, dim);
|
||||||
addop(OP_INITFILL);
|
addop(OP_ZERO);
|
||||||
count = 0;
|
addop(OP_INITFILL);
|
||||||
if (gettoken() == T_ASSIGN)
|
count = 0;
|
||||||
count = getinitlist();
|
count = getinitlist();
|
||||||
else
|
index = addqconstant(itoq(count));
|
||||||
|
if (index < 0)
|
||||||
|
math_error("Cannot allocate constant");
|
||||||
|
curfunc->f_opcodes[patchpc] = index;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
rescantoken();
|
||||||
|
addopone(OP_MATCREATE, 0);
|
||||||
|
if (gettoken() == T_LEFTBRACKET) {
|
||||||
|
creatematrix();
|
||||||
|
} else {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
index = addqconstant(itoq(count));
|
addop(OP_ZERO);
|
||||||
if (index < 0)
|
}
|
||||||
math_error("Cannot allocate constant");
|
addop(OP_INITFILL);
|
||||||
curfunc->f_opcodes[patchpc] = index;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1186,41 +1210,45 @@ creatematrix(void)
|
|||||||
{
|
{
|
||||||
long dim;
|
long dim;
|
||||||
|
|
||||||
dim = 1;
|
dim = 0;
|
||||||
|
|
||||||
while (TRUE) {
|
for (;;) {
|
||||||
|
if (gettoken() == T_RIGHTBRACKET) {
|
||||||
|
addopone(OP_MATCREATE, dim);
|
||||||
|
if (gettoken() == T_LEFTBRACKET) {
|
||||||
|
creatematrix();
|
||||||
|
} else {
|
||||||
|
rescantoken();
|
||||||
|
addop(OP_ZERO);
|
||||||
|
}
|
||||||
|
addop(OP_INITFILL);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
rescantoken();
|
||||||
|
if (++dim > MAXDIM) {
|
||||||
|
scanerror(T_SEMICOLON, "Only %ld dimensions allowed", MAXDIM);
|
||||||
|
return;
|
||||||
|
}
|
||||||
(void) getopassignment();
|
(void) getopassignment();
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_RIGHTBRACKET:
|
case T_RIGHTBRACKET:
|
||||||
case T_COMMA:
|
|
||||||
rescantoken();
|
rescantoken();
|
||||||
|
case T_COMMA:
|
||||||
addop(OP_ONE);
|
addop(OP_ONE);
|
||||||
addop(OP_SUB);
|
addop(OP_SUB);
|
||||||
addop(OP_ZERO);
|
addop(OP_ZERO);
|
||||||
break;
|
break;
|
||||||
case T_COLON:
|
case T_COLON:
|
||||||
(void) getopassignment();
|
(void) getopassignment();
|
||||||
break;
|
switch(gettoken()) {
|
||||||
|
case T_RIGHTBRACKET:
|
||||||
|
rescantoken();
|
||||||
|
case T_COMMA:
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
/*FALLTHRU*/
|
||||||
default:
|
default:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
}
|
|
||||||
switch (gettoken()) {
|
|
||||||
case T_RIGHTBRACKET:
|
|
||||||
addopone(OP_MATCREATE, dim);
|
|
||||||
if (gettoken() == T_LEFTBRACKET) {
|
|
||||||
creatematrix();
|
|
||||||
} else {
|
|
||||||
rescantoken();
|
|
||||||
addop(OP_ZERO);
|
|
||||||
}
|
|
||||||
addop(OP_INITFILL);
|
|
||||||
return;
|
|
||||||
case T_COMMA:
|
|
||||||
if (++dim <= MAXDIM)
|
|
||||||
break;
|
|
||||||
scanerror(T_SEMICOLON, "Only %ld dimensions allowed", MAXDIM);
|
|
||||||
return;
|
|
||||||
default:
|
|
||||||
scanerror(T_SEMICOLON, "Illegal matrix definition");
|
scanerror(T_SEMICOLON, "Illegal matrix definition");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -1305,7 +1333,7 @@ getcondition(void)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Get an expression list consisting of one or more expressions,
|
* Get an expression list consisting of one or more expressions,
|
||||||
* separated by commas. The value of the list is that of the final expression.
|
* separated by commas. The value of the list is that of the final expression.
|
||||||
* This is the top level routine for parsing expressions.
|
* This is the top level routine for parsing expressions.
|
||||||
* Returns flags describing the type of the last assignment or expression found.
|
* Returns flags describing the type of the last assignment or expression found.
|
||||||
* exprlist = assignment [ ',' assignment ] ...
|
* exprlist = assignment [ ',' assignment ] ...
|
||||||
@@ -1359,8 +1387,8 @@ getopassignment(void)
|
|||||||
case T_MODEQUALS: op = OP_MOD; break;
|
case T_MODEQUALS: op = OP_MOD; break;
|
||||||
case T_ANDEQUALS: op = OP_AND; break;
|
case T_ANDEQUALS: op = OP_AND; break;
|
||||||
case T_OREQUALS: op = OP_OR; break;
|
case T_OREQUALS: op = OP_OR; break;
|
||||||
case T_LSHIFTEQUALS: op = OP_LEFTSHIFT; break;
|
case T_LSHIFTEQUALS: op = OP_LEFTSHIFT; break;
|
||||||
case T_RSHIFTEQUALS: op = OP_RIGHTSHIFT; break;
|
case T_RSHIFTEQUALS: op = OP_RIGHTSHIFT; break;
|
||||||
case T_POWEREQUALS: op = OP_POWER; break;
|
case T_POWEREQUALS: op = OP_POWER; break;
|
||||||
case T_HASHEQUALS: op = OP_HASHOP; break;
|
case T_HASHEQUALS: op = OP_HASHOP; break;
|
||||||
case T_TILDEEQUALS: op = OP_XOR; break;
|
case T_TILDEEQUALS: op = OP_XOR; break;
|
||||||
@@ -1400,8 +1428,8 @@ getopassignment(void)
|
|||||||
case T_MODEQUALS: op = OP_MOD; break;
|
case T_MODEQUALS: op = OP_MOD; break;
|
||||||
case T_ANDEQUALS: op = OP_AND; break;
|
case T_ANDEQUALS: op = OP_AND; break;
|
||||||
case T_OREQUALS: op = OP_OR; break;
|
case T_OREQUALS: op = OP_OR; break;
|
||||||
case T_LSHIFTEQUALS: op = OP_LEFTSHIFT; break;
|
case T_LSHIFTEQUALS: op = OP_LEFTSHIFT; break;
|
||||||
case T_RSHIFTEQUALS: op = OP_RIGHTSHIFT; break;
|
case T_RSHIFTEQUALS: op = OP_RIGHTSHIFT; break;
|
||||||
case T_POWEREQUALS: op = OP_POWER; break;
|
case T_POWEREQUALS: op = OP_POWER; break;
|
||||||
case T_HASHEQUALS: op = OP_HASHOP; break;
|
case T_HASHEQUALS: op = OP_HASHOP; break;
|
||||||
case T_TILDEEQUALS: op = OP_XOR; break;
|
case T_TILDEEQUALS: op = OP_XOR; break;
|
||||||
@@ -1746,7 +1774,7 @@ getshiftexpr(void)
|
|||||||
case T_NOT: op = OP_NOT; break;
|
case T_NOT: op = OP_NOT; break;
|
||||||
case T_DIV: op = OP_INVERT; break;
|
case T_DIV: op = OP_INVERT; break;
|
||||||
case T_BACKSLASH: op = OP_BACKSLASH; break;
|
case T_BACKSLASH: op = OP_BACKSLASH; break;
|
||||||
case T_TILDE: op = OP_COMP; break;
|
case T_TILDE: op = OP_COMP; break;
|
||||||
case T_HASH: op = OP_CONTENT; break;
|
case T_HASH: op = OP_CONTENT; break;
|
||||||
}
|
}
|
||||||
if (op) {
|
if (op) {
|
||||||
@@ -1759,7 +1787,7 @@ getshiftexpr(void)
|
|||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_POWER: op = OP_POWER; break;
|
case T_POWER: op = OP_POWER; break;
|
||||||
case T_LEFTSHIFT: op = OP_LEFTSHIFT; break;
|
case T_LEFTSHIFT: op = OP_LEFTSHIFT; break;
|
||||||
case T_RIGHTSHIFT: op = OP_RIGHTSHIFT; break;
|
case T_RIGHTSHIFT: op = OP_RIGHTSHIFT; break;
|
||||||
default:
|
default:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
return type;
|
return type;
|
||||||
@@ -2187,12 +2215,18 @@ getmatargs(void)
|
|||||||
/*
|
/*
|
||||||
* Normal indexing with the indexes separated by commas.
|
* Normal indexing with the indexes separated by commas.
|
||||||
* Initialize the flag in the opcode to assume that the array
|
* Initialize the flag in the opcode to assume that the array
|
||||||
* element will only be referenced for reading. If the parser
|
* element will only be referenced for reading. If the parser
|
||||||
* finds that the element will be referenced for writing, then
|
* finds that the element will be referenced for writing, then
|
||||||
* it will call writeindexop to change the flag in the opcode.
|
* it will call writeindexop to change the flag in the opcode.
|
||||||
*/
|
*/
|
||||||
dim = 1;
|
dim = 0;
|
||||||
|
if (gettoken() == T_RIGHTBRACKET) {
|
||||||
|
addoptwo(OP_INDEXADDR, (long) dim, (long) FALSE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
rescantoken();
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
++dim;
|
||||||
(void) getopassignment();
|
(void) getopassignment();
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_RIGHTBRACKET:
|
case T_RIGHTBRACKET:
|
||||||
@@ -2200,7 +2234,6 @@ getmatargs(void)
|
|||||||
(long) FALSE);
|
(long) FALSE);
|
||||||
return;
|
return;
|
||||||
case T_COMMA:
|
case T_COMMA:
|
||||||
dim++;
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
|
45
comfunc.c
45
comfunc.c
@@ -138,38 +138,6 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
|
|
||||||
up1 = up2 = 0;
|
up1 = up2 = 0;
|
||||||
sign = (R & 64) != 0;
|
sign = (R & 64) != 0;
|
||||||
#if 0
|
|
||||||
if (qiszero(epsilon)) {
|
|
||||||
aes = qsquare(c->real);
|
|
||||||
bes = qsquare(c->imag);
|
|
||||||
v = qqadd(aes, bes);
|
|
||||||
qfree(aes);
|
|
||||||
qfree(bes);
|
|
||||||
u = qsqrt(v, epsilon, 0);
|
|
||||||
qfree(v);
|
|
||||||
if (qiszero(u)) {
|
|
||||||
qfree(u);
|
|
||||||
return clink(&_czero_);
|
|
||||||
}
|
|
||||||
aes = qqadd(u, c->real);
|
|
||||||
qfree(u);
|
|
||||||
bes = qscale(aes, -1);
|
|
||||||
qfree(aes);
|
|
||||||
u = qsqrt(bes, epsilon, R);
|
|
||||||
qfree(bes);
|
|
||||||
if (qiszero(u)) {
|
|
||||||
qfree(u);
|
|
||||||
return clink(&_czero_);
|
|
||||||
}
|
|
||||||
aes = qscale(c->imag, -1);
|
|
||||||
v = qqdiv(aes, u);
|
|
||||||
qfree(aes);
|
|
||||||
r = comalloc();
|
|
||||||
r->real = u;
|
|
||||||
r->imag = v;
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
imsign = c->imag->num.sign;
|
imsign = c->imag->num.sign;
|
||||||
es = qsquare(epsilon);
|
es = qsquare(epsilon);
|
||||||
aes = qqdiv(c->real, es);
|
aes = qqdiv(c->real, es);
|
||||||
@@ -255,8 +223,7 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
up2 = -1;
|
up2 = -1;
|
||||||
zfree(tmp1);
|
zfree(tmp1);
|
||||||
zfree(aa);
|
zfree(aa);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
s1 = zsqrt(tmp3, &cc, 0);
|
s1 = zsqrt(tmp3, &cc, 0);
|
||||||
zfree(tmp3);
|
zfree(tmp3);
|
||||||
zadd(cc, a, &tmp1);
|
zadd(cc, a, &tmp1);
|
||||||
@@ -333,9 +300,9 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
zfree(mul2);
|
zfree(mul2);
|
||||||
mul2 = tmp2;
|
mul2 = tmp2;
|
||||||
}
|
}
|
||||||
if (ziszero(mul1))
|
if (ziszero(mul1)) {
|
||||||
u = qlink(&_qzero_);
|
u = qlink(&_qzero_);
|
||||||
else {
|
} else {
|
||||||
mul1.sign = sign ^ epsilon->num.sign;
|
mul1.sign = sign ^ epsilon->num.sign;
|
||||||
u = qalloc();
|
u = qalloc();
|
||||||
zreduce(mul1, epsilon->den, &tmp2, &u->den);
|
zreduce(mul1, epsilon->den, &tmp2, &u->den);
|
||||||
@@ -343,9 +310,9 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
zfree(tmp2);
|
zfree(tmp2);
|
||||||
}
|
}
|
||||||
zfree(mul1);
|
zfree(mul1);
|
||||||
if (ziszero(mul2))
|
if (ziszero(mul2)) {
|
||||||
v = qlink(&_qzero_);
|
v = qlink(&_qzero_);
|
||||||
else {
|
} else {
|
||||||
mul2.sign = imsign ^ sign ^ epsilon->num.sign;
|
mul2.sign = imsign ^ sign ^ epsilon->num.sign;
|
||||||
v = qalloc();
|
v = qalloc();
|
||||||
zreduce(mul2, epsilon->den, &tmp2, &v->den);
|
zreduce(mul2, epsilon->den, &tmp2, &v->den);
|
||||||
@@ -1147,5 +1114,3 @@ cprintfr(COMPLEX *c)
|
|||||||
zprintval(i->den, 0L, 0L);
|
zprintval(i->den, 0L, 0L);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* END CODE */
|
|
||||||
|
@@ -69,7 +69,7 @@ csub(COMPLEX *c1, COMPLEX *c2)
|
|||||||
/*
|
/*
|
||||||
* Multiply two complex numbers.
|
* Multiply two complex numbers.
|
||||||
* This saves one multiplication over the obvious algorithm by
|
* This saves one multiplication over the obvious algorithm by
|
||||||
* trading it for several extra additions, as follows. Let
|
* trading it for several extra additions, as follows. Let
|
||||||
* q1 = (a + b) * (c + d)
|
* q1 = (a + b) * (c + d)
|
||||||
* q2 = a * c
|
* q2 = a * c
|
||||||
* q3 = b * d
|
* q3 = b * d
|
||||||
|
332
config.c
332
config.c
@@ -48,7 +48,7 @@ NAMETYPE configs[] = {
|
|||||||
{"maxerr", CONFIG_MAXSCAN}, /* old name for maxscan */
|
{"maxerr", CONFIG_MAXSCAN}, /* old name for maxscan */
|
||||||
{"prompt", CONFIG_PROMPT},
|
{"prompt", CONFIG_PROMPT},
|
||||||
{"more", CONFIG_MORE},
|
{"more", CONFIG_MORE},
|
||||||
{"blkmaxprint", CONFIG_BLKMAXPRINT},
|
{"blkmaxprint", CONFIG_BLKMAXPRINT},
|
||||||
{"blkverbose", CONFIG_BLKVERBOSE},
|
{"blkverbose", CONFIG_BLKVERBOSE},
|
||||||
{"blkbase", CONFIG_BLKBASE},
|
{"blkbase", CONFIG_BLKBASE},
|
||||||
{"blkfmt", CONFIG_BLKFMT},
|
{"blkfmt", CONFIG_BLKFMT},
|
||||||
@@ -56,6 +56,8 @@ NAMETYPE configs[] = {
|
|||||||
{"calc_debug", CONFIG_CALC_DEBUG},
|
{"calc_debug", CONFIG_CALC_DEBUG},
|
||||||
{"user_debug", CONFIG_USER_DEBUG},
|
{"user_debug", CONFIG_USER_DEBUG},
|
||||||
{"verbose_quit",CONFIG_VERBOSE_QUIT},
|
{"verbose_quit",CONFIG_VERBOSE_QUIT},
|
||||||
|
{"ctrl_d", CONFIG_CTRL_D},
|
||||||
|
{"ctrl-d", CONFIG_CTRL_D}, /* alias for ctrl_d */
|
||||||
{NULL, 0}
|
{NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -96,8 +98,9 @@ CONFIG oldstd = { /* backward compatible standard configuration */
|
|||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
3, /* calc library debug level */
|
3, /* calc library debug level */
|
||||||
0, /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
TRUE /* print Quit or abort executed messages */
|
TRUE, /* print Quit or abort executed messages */
|
||||||
|
CTRL_D_VIRGIN /* ^D only exits on virgin lines */
|
||||||
};
|
};
|
||||||
CONFIG newstd = { /* new non-backward compatible configuration */
|
CONFIG newstd = { /* new non-backward compatible configuration */
|
||||||
MODE_INITIAL, /* current output mode */
|
MODE_INITIAL, /* current output mode */
|
||||||
@@ -132,8 +135,9 @@ CONFIG newstd = { /* new non-backward compatible configuration */
|
|||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
3, /* calc library debug level */
|
3, /* calc library debug level */
|
||||||
0, /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
TRUE /* print Quit or abort executed messages */
|
TRUE, /* print Quit or abort executed messages */
|
||||||
|
CTRL_D_VIRGIN /* ^D only exits on virgin lines */
|
||||||
};
|
};
|
||||||
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
||||||
|
|
||||||
@@ -142,13 +146,17 @@ CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
|||||||
* Possible output modes.
|
* Possible output modes.
|
||||||
*/
|
*/
|
||||||
static NAMETYPE modes[] = {
|
static NAMETYPE modes[] = {
|
||||||
|
{"fraction", MODE_FRAC},
|
||||||
{"frac", MODE_FRAC},
|
{"frac", MODE_FRAC},
|
||||||
{"decimal", MODE_FRAC},
|
{"integer", MODE_INT},
|
||||||
{"dec", MODE_FRAC},
|
|
||||||
{"int", MODE_INT},
|
{"int", MODE_INT},
|
||||||
{"real", MODE_REAL},
|
{"real", MODE_REAL},
|
||||||
|
{"float", MODE_REAL},
|
||||||
|
{"default", MODE_INITIAL}, /* MODE_REAL */
|
||||||
|
{"scientific", MODE_EXP},
|
||||||
|
{"sci", MODE_EXP},
|
||||||
{"exp", MODE_EXP},
|
{"exp", MODE_EXP},
|
||||||
{"hexadecimal", MODE_HEX},
|
{"hexadecimal", MODE_HEX},
|
||||||
{"hex", MODE_HEX},
|
{"hex", MODE_HEX},
|
||||||
{"octal", MODE_OCTAL},
|
{"octal", MODE_OCTAL},
|
||||||
{"oct", MODE_OCTAL},
|
{"oct", MODE_OCTAL},
|
||||||
@@ -158,34 +166,13 @@ static NAMETYPE modes[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Possible binary config state values
|
|
||||||
*/
|
|
||||||
static NAMETYPE truth[] = {
|
|
||||||
{"y", TRUE},
|
|
||||||
{"n", FALSE},
|
|
||||||
{"yes", TRUE},
|
|
||||||
{"no", FALSE},
|
|
||||||
{"set", TRUE},
|
|
||||||
{"unset", FALSE},
|
|
||||||
{"on", TRUE},
|
|
||||||
{"off", FALSE},
|
|
||||||
{"true", TRUE},
|
|
||||||
{"false", FALSE},
|
|
||||||
{"t", TRUE},
|
|
||||||
{"f", FALSE},
|
|
||||||
{"1", TRUE},
|
|
||||||
{"0", FALSE},
|
|
||||||
{NULL, 0}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Possible block base output modes
|
* Possible block base output modes
|
||||||
*/
|
*/
|
||||||
static NAMETYPE blk_base[] = {
|
static NAMETYPE blk_base[] = {
|
||||||
{"hexadecimal", BLK_BASE_HEX},
|
{"hexadecimal", BLK_BASE_HEX},
|
||||||
{"hex", BLK_BASE_HEX},
|
{"hex", BLK_BASE_HEX},
|
||||||
|
{"default", BLK_BASE_HEX},
|
||||||
{"octal", BLK_BASE_OCT},
|
{"octal", BLK_BASE_OCT},
|
||||||
{"oct", BLK_BASE_OCT},
|
{"oct", BLK_BASE_OCT},
|
||||||
{"character", BLK_BASE_CHAR},
|
{"character", BLK_BASE_CHAR},
|
||||||
@@ -202,17 +189,60 @@ static NAMETYPE blk_base[] = {
|
|||||||
* Possible block output formats
|
* Possible block output formats
|
||||||
*/
|
*/
|
||||||
static NAMETYPE blk_fmt[] = {
|
static NAMETYPE blk_fmt[] = {
|
||||||
{"line", BLK_FMT_LINE},
|
|
||||||
{"lines", BLK_FMT_LINE},
|
{"lines", BLK_FMT_LINE},
|
||||||
{"str", BLK_FMT_STRING},
|
{"line", BLK_FMT_LINE},
|
||||||
{"string", BLK_FMT_STRING},
|
|
||||||
{"strings", BLK_FMT_STRING},
|
{"strings", BLK_FMT_STRING},
|
||||||
{"od", BLK_FMT_OD_STYLE},
|
{"string", BLK_FMT_STRING},
|
||||||
{"odstyle", BLK_FMT_OD_STYLE},
|
{"str", BLK_FMT_STRING},
|
||||||
{"od_style", BLK_FMT_OD_STYLE},
|
{"od_style", BLK_FMT_OD_STYLE},
|
||||||
{"hd", BLK_FMT_HD_STYLE},
|
{"odstyle", BLK_FMT_OD_STYLE},
|
||||||
{"hdstyle", BLK_FMT_HD_STYLE},
|
{"od", BLK_FMT_OD_STYLE},
|
||||||
{"hd_style", BLK_FMT_HD_STYLE},
|
{"hd_style", BLK_FMT_HD_STYLE},
|
||||||
|
{"hdstyle", BLK_FMT_HD_STYLE},
|
||||||
|
{"hd", BLK_FMT_HD_STYLE},
|
||||||
|
{"default", BLK_FMT_HD_STYLE},
|
||||||
|
{NULL, 0}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Possible ctrl_d styles
|
||||||
|
*/
|
||||||
|
static NAMETYPE ctrl_d[] = {
|
||||||
|
{"virgin_eof", CTRL_D_VIRGIN},
|
||||||
|
{"virgineof", CTRL_D_VIRGIN},
|
||||||
|
{"virgin", CTRL_D_VIRGIN},
|
||||||
|
{"default", CTRL_D_VIRGIN},
|
||||||
|
{"never_eof", CTRL_D_EMACS},
|
||||||
|
{"nevereof", CTRL_D_EMACS},
|
||||||
|
{"never", CTRL_D_EMACS},
|
||||||
|
{"empty_eof", CTRL_D_EOF},
|
||||||
|
{"emptyeof", CTRL_D_EOF},
|
||||||
|
{"empty", CTRL_D_EOF},
|
||||||
|
{NULL, 0}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Possible binary config state values
|
||||||
|
*/
|
||||||
|
#define TRUE_STRING "on"
|
||||||
|
#define FALSE_STRING "off"
|
||||||
|
static NAMETYPE truth[] = {
|
||||||
|
{TRUE_STRING, TRUE},
|
||||||
|
{"true", TRUE},
|
||||||
|
{"t", TRUE},
|
||||||
|
{"yes", TRUE},
|
||||||
|
{"y", TRUE},
|
||||||
|
{"set", TRUE},
|
||||||
|
{"1", TRUE},
|
||||||
|
{FALSE_STRING, FALSE},
|
||||||
|
{"false", FALSE},
|
||||||
|
{"f", FALSE},
|
||||||
|
{"no", FALSE},
|
||||||
|
{"n", FALSE},
|
||||||
|
{"unset", FALSE},
|
||||||
|
{"0", FALSE},
|
||||||
{NULL, 0}
|
{NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -220,11 +250,8 @@ static NAMETYPE blk_fmt[] = {
|
|||||||
/*
|
/*
|
||||||
* declate static functions
|
* declate static functions
|
||||||
*/
|
*/
|
||||||
static int modetype(char *name);
|
static long lookup_long(NAMETYPE *set, char *name);
|
||||||
static int blkbase(char *name);
|
static char *lookup_name(NAMETYPE *set, long val);
|
||||||
static int blkfmt(char *name);
|
|
||||||
static int truthtype(char *name);
|
|
||||||
static char *modename(int type);
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -249,18 +276,21 @@ configtype(char *name)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Given the name of a mode, convert it to the internal format.
|
* lookup_long - given a name and a NAMETYPE, return the int
|
||||||
* Returns -1 if the string is unknown.
|
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* name mode name
|
* set the NAMESET array of name/int pairs
|
||||||
|
* name mode name
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* numeric value of the name or -1 if not found
|
||||||
*/
|
*/
|
||||||
static int
|
static long
|
||||||
modetype(char *name)
|
lookup_long(NAMETYPE *set, char *name)
|
||||||
{
|
{
|
||||||
NAMETYPE *cp; /* current config pointer */
|
NAMETYPE *cp; /* current config pointer */
|
||||||
|
|
||||||
for (cp = modes; cp->name; cp++) {
|
for (cp = set; cp->name; cp++) {
|
||||||
if (strcmp(cp->name, name) == 0)
|
if (strcmp(cp->name, name) == 0)
|
||||||
return cp->type;
|
return cp->type;
|
||||||
}
|
}
|
||||||
@@ -269,78 +299,22 @@ modetype(char *name)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Given the name of a block output base, convert it to the internal format.
|
* lookup_name - given numeric value and a NAMETYPE, return the name
|
||||||
* Returns -1 if the string is unknown.
|
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* name mode name
|
* set the NAMESET array of name/int pairs
|
||||||
*/
|
* val numeric value to lookup
|
||||||
static int
|
|
||||||
blkbase(char *name)
|
|
||||||
{
|
|
||||||
NAMETYPE *cp; /* current config pointer */
|
|
||||||
|
|
||||||
for (cp = blk_base; cp->name; cp++) {
|
|
||||||
if (strcmp(cp->name, name) == 0)
|
|
||||||
return cp->type;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Given the name of a block output format, convert it to the internal format.
|
|
||||||
* Returns -1 if the string is unknown.
|
|
||||||
*
|
*
|
||||||
* given:
|
* returns:
|
||||||
* name mode name
|
* name of the value found of NULL
|
||||||
*/
|
|
||||||
static int
|
|
||||||
blkfmt(char *name)
|
|
||||||
{
|
|
||||||
NAMETYPE *cp; /* current config pointer */
|
|
||||||
|
|
||||||
for (cp = blk_fmt; cp->name; cp++) {
|
|
||||||
if (strcmp(cp->name, name) == 0)
|
|
||||||
return cp->type;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Given the name of a truth value, convert it to a BOOL or -1.
|
|
||||||
* Returns -1 if the string is unknown.
|
|
||||||
*
|
|
||||||
* given:
|
|
||||||
* name mode name
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
truthtype(char *name)
|
|
||||||
{
|
|
||||||
NAMETYPE *cp; /* current config pointer */
|
|
||||||
|
|
||||||
for (cp = truth; cp->name; cp++) {
|
|
||||||
if (strcmp(cp->name, name) == 0)
|
|
||||||
return cp->type;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Given the mode type, convert it to a string representing that mode.
|
|
||||||
* Where there are multiple strings representing the same mode, the first
|
|
||||||
* one in the table is used. Returns NULL if the node type is unknown.
|
|
||||||
* The returned string cannot be modified.
|
|
||||||
*/
|
*/
|
||||||
static char *
|
static char *
|
||||||
modename(int type)
|
lookup_name(NAMETYPE *set, long val)
|
||||||
{
|
{
|
||||||
NAMETYPE *cp; /* current config pointer */
|
NAMETYPE *cp; /* current config pointer */
|
||||||
|
|
||||||
for (cp = modes; cp->name; cp++) {
|
for (cp = set; cp->name; cp++) {
|
||||||
if (type == cp->type)
|
if (val == cp->type)
|
||||||
return cp->name;
|
return cp->name;
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
@@ -361,7 +335,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case CONFIG_ALL:
|
case CONFIG_ALL:
|
||||||
newconf = NULL; /* firewall */
|
newconf = NULL; /* firewall */
|
||||||
if (vp->v_type == V_STR) {
|
if (vp->v_type == V_STR) {
|
||||||
if (strcmp(vp->v_str->s_str, "oldstd") == 0) {
|
if (strcmp(vp->v_str->s_str, "oldstd") == 0) {
|
||||||
newconf = &oldstd;
|
newconf = &oldstd;
|
||||||
@@ -417,7 +391,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
math_error("Non-string for mode");
|
math_error("Non-string for mode");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
temp = modetype(vp->v_str->s_str);
|
temp = lookup_long(modes, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Unknown mode \"%s\"", vp->v_str);
|
math_error("Unknown mode \"%s\"", vp->v_str);
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -526,7 +500,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->tilde_ok = !qiszero(q);
|
conf->tilde_ok = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Illegal truth value for tilde");
|
math_error("Illegal truth value for tilde");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -540,7 +514,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->tab_ok = !qiszero(q);
|
conf->tab_ok = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Illegal truth value for tab");
|
math_error("Illegal truth value for tab");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -680,7 +654,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->leadzero = !qiszero(q);
|
conf->leadzero = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) { {
|
if (temp < 0) { {
|
||||||
math_error("Illegal truth value for leadzero");
|
math_error("Illegal truth value for leadzero");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -695,7 +669,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->fullzero = !qiszero(q);
|
conf->fullzero = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) { {
|
if (temp < 0) { {
|
||||||
math_error("Illegal truth value for fullzero");
|
math_error("Illegal truth value for fullzero");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -772,7 +746,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->blkverbose = !qiszero(q);
|
conf->blkverbose = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Illegal truth value for blkverbose");
|
math_error("Illegal truth value for blkverbose");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -786,7 +760,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
math_error("Non-string for blkbase");
|
math_error("Non-string for blkbase");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
temp = blkbase(vp->v_str->s_str);
|
temp = lookup_long(blk_base, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Unknown mode \"%s\" for blkbase",
|
math_error("Unknown mode \"%s\" for blkbase",
|
||||||
vp->v_str->s_str);
|
vp->v_str->s_str);
|
||||||
@@ -800,7 +774,7 @@ setconfig(int type, VALUE *vp)
|
|||||||
math_error("Non-string for blkfmt");
|
math_error("Non-string for blkfmt");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
temp = blkfmt(vp->v_str->s_str);
|
temp = lookup_long(blk_fmt, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Unknown mode \"%s\" for blkfmt",
|
math_error("Unknown mode \"%s\" for blkfmt",
|
||||||
vp->v_str->s_str);
|
vp->v_str->s_str);
|
||||||
@@ -856,9 +830,9 @@ setconfig(int type, VALUE *vp)
|
|||||||
q = vp->v_num;
|
q = vp->v_num;
|
||||||
conf->verbose_quit = !qiszero(q);
|
conf->verbose_quit = !qiszero(q);
|
||||||
} else if (vp->v_type == V_STR) {
|
} else if (vp->v_type == V_STR) {
|
||||||
temp = truthtype(vp->v_str->s_str);
|
temp = lookup_long(truth, vp->v_str->s_str);
|
||||||
if (temp < 0) {
|
if (temp < 0) {
|
||||||
math_error("Illegal truth value"
|
math_error("Illegal truth value "
|
||||||
"for verbose_quit");
|
"for verbose_quit");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
@@ -866,6 +840,20 @@ setconfig(int type, VALUE *vp)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_CTRL_D:
|
||||||
|
if (vp->v_type != V_STR) {
|
||||||
|
math_error("Non-string for ctrl_d");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
temp = lookup_long(ctrl_d, vp->v_str->s_str);
|
||||||
|
if (temp < 0) {
|
||||||
|
math_error("Unknown mode \"%s\" for ctrl_d",
|
||||||
|
vp->v_str->s_str);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
conf->ctrl_d = temp;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Setting illegal config parameter");
|
math_error("Setting illegal config parameter");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -986,6 +974,7 @@ void
|
|||||||
config_value(CONFIG *cfg, int type, VALUE *vp)
|
config_value(CONFIG *cfg, int type, VALUE *vp)
|
||||||
{
|
{
|
||||||
long i=0;
|
long i=0;
|
||||||
|
char *p;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* firewall
|
* firewall
|
||||||
@@ -1000,6 +989,7 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
* convert element to value
|
* convert element to value
|
||||||
*/
|
*/
|
||||||
vp->v_type = V_NUM;
|
vp->v_type = V_NUM;
|
||||||
|
vp->v_subtype = V_NOSUBTYPE;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case CONFIG_ALL:
|
case CONFIG_ALL:
|
||||||
vp->v_type = V_CONFIG;
|
vp->v_type = V_CONFIG;
|
||||||
@@ -1016,7 +1006,12 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
|
|
||||||
case CONFIG_MODE:
|
case CONFIG_MODE:
|
||||||
vp->v_type = V_STR;
|
vp->v_type = V_STR;
|
||||||
vp->v_str = makenewstring(modename(cfg->outmode));
|
p = lookup_name(modes, cfg->outmode);
|
||||||
|
if (p == NULL) {
|
||||||
|
math_error("invalid output mode: %d", cfg->outmode);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
vp->v_str = makenewstring(p);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case CONFIG_EPSILON:
|
case CONFIG_EPSILON:
|
||||||
@@ -1044,12 +1039,22 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_TILDE:
|
case CONFIG_TILDE:
|
||||||
i = cfg->tilde_ok;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->tilde_ok) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_TAB:
|
case CONFIG_TAB:
|
||||||
i = cfg->tab_ok;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->tab_ok) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_QUOMOD:
|
case CONFIG_QUOMOD:
|
||||||
i = cfg->quomod;
|
i = cfg->quomod;
|
||||||
@@ -1088,12 +1093,22 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_LEADZERO:
|
case CONFIG_LEADZERO:
|
||||||
i = cfg->leadzero;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->leadzero) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_FULLZERO:
|
case CONFIG_FULLZERO:
|
||||||
i = cfg->fullzero;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->fullzero) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_MAXSCAN:
|
case CONFIG_MAXSCAN:
|
||||||
i = cfg->maxscancount;
|
i = cfg->maxscancount;
|
||||||
@@ -1114,16 +1129,33 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_BLKVERBOSE:
|
case CONFIG_BLKVERBOSE:
|
||||||
i = cfg->blkverbose;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->blkverbose) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_BLKBASE:
|
case CONFIG_BLKBASE:
|
||||||
i = cfg->blkbase;
|
vp->v_type = V_STR;
|
||||||
break;
|
p = lookup_name(blk_base, cfg->blkbase);
|
||||||
|
if (p == NULL) {
|
||||||
|
math_error("invalid block base: %d", cfg->blkbase);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
vp->v_str = makenewstring(p);
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_BLKFMT:
|
case CONFIG_BLKFMT:
|
||||||
i = cfg->blkfmt;
|
vp->v_type = V_STR;
|
||||||
break;
|
p = lookup_name(blk_fmt, cfg->blkfmt);
|
||||||
|
if (p == NULL) {
|
||||||
|
math_error("invalid block format: %d", cfg->blkfmt);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
vp->v_str = makenewstring(p);
|
||||||
|
return;
|
||||||
|
|
||||||
case CONFIG_CALC_DEBUG:
|
case CONFIG_CALC_DEBUG:
|
||||||
i = cfg->calc_debug;
|
i = cfg->calc_debug;
|
||||||
@@ -1138,8 +1170,23 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_VERBOSE_QUIT:
|
case CONFIG_VERBOSE_QUIT:
|
||||||
i = cfg->verbose_quit;
|
vp->v_type = V_STR;
|
||||||
break;
|
if (cfg->verbose_quit) {
|
||||||
|
vp->v_str = makenewstring(TRUE_STRING);
|
||||||
|
} else {
|
||||||
|
vp->v_str = makenewstring(FALSE_STRING);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
|
||||||
|
case CONFIG_CTRL_D:
|
||||||
|
vp->v_type = V_STR;
|
||||||
|
p = lookup_name(ctrl_d, cfg->ctrl_d);
|
||||||
|
if (p == NULL) {
|
||||||
|
math_error("invalid Control-D: %d", cfg->ctrl_d);
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
vp->v_str = makenewstring(p);
|
||||||
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Getting illegal CONFIG element");
|
math_error("Getting illegal CONFIG element");
|
||||||
@@ -1217,5 +1264,6 @@ config_cmp(CONFIG *cfg1, CONFIG *cfg2)
|
|||||||
cfg1->calc_debug != cfg2->calc_debug ||
|
cfg1->calc_debug != cfg2->calc_debug ||
|
||||||
cfg1->lib_debug != cfg2->lib_debug ||
|
cfg1->lib_debug != cfg2->lib_debug ||
|
||||||
cfg1->user_debug != cfg2->user_debug ||
|
cfg1->user_debug != cfg2->user_debug ||
|
||||||
cfg1->verbose_quit != cfg2->verbose_quit;
|
cfg1->verbose_quit != cfg2->verbose_quit ||
|
||||||
|
cfg1->ctrl_d != cfg2->ctrl_d;
|
||||||
}
|
}
|
||||||
|
44
config.h
44
config.h
@@ -20,16 +20,16 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Prior to calc 2.9.3t9, these routines existed as a calc library called
|
* Prior to calc 2.9.3t9, these routines existed as a calc library called
|
||||||
* cryrand.cal. They have been rewritten in C for performance as well
|
* cryrand.cal. They have been rewritten in C for performance as well
|
||||||
* as to make them available directly from libcalc.a.
|
* as to make them available directly from libcalc.a.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -52,11 +52,11 @@
|
|||||||
#define CONFIG_EPSILON 3
|
#define CONFIG_EPSILON 3
|
||||||
#define CONFIG_EPSILONPREC 3 /* not a real type -- tied to CONFIG_EPSILON */
|
#define CONFIG_EPSILONPREC 3 /* not a real type -- tied to CONFIG_EPSILON */
|
||||||
#define CONFIG_TRACE 4
|
#define CONFIG_TRACE 4
|
||||||
#define CONFIG_MAXPRINT 5
|
#define CONFIG_MAXPRINT 5
|
||||||
#define CONFIG_MUL2 6
|
#define CONFIG_MUL2 6
|
||||||
#define CONFIG_SQ2 7
|
#define CONFIG_SQ2 7
|
||||||
#define CONFIG_POW2 8
|
#define CONFIG_POW2 8
|
||||||
#define CONFIG_REDC2 9
|
#define CONFIG_REDC2 9
|
||||||
#define CONFIG_TILDE 10
|
#define CONFIG_TILDE 10
|
||||||
#define CONFIG_TAB 11
|
#define CONFIG_TAB 11
|
||||||
#define CONFIG_QUOMOD 12
|
#define CONFIG_QUOMOD 12
|
||||||
@@ -66,10 +66,10 @@
|
|||||||
#define CONFIG_APPR 16
|
#define CONFIG_APPR 16
|
||||||
#define CONFIG_CFAPPR 17
|
#define CONFIG_CFAPPR 17
|
||||||
#define CONFIG_CFSIM 18
|
#define CONFIG_CFSIM 18
|
||||||
#define CONFIG_OUTROUND 19
|
#define CONFIG_OUTROUND 19
|
||||||
#define CONFIG_ROUND 20
|
#define CONFIG_ROUND 20
|
||||||
#define CONFIG_LEADZERO 21
|
#define CONFIG_LEADZERO 21
|
||||||
#define CONFIG_FULLZERO 22
|
#define CONFIG_FULLZERO 22
|
||||||
#define CONFIG_MAXSCAN 23
|
#define CONFIG_MAXSCAN 23
|
||||||
#define CONFIG_PROMPT 24
|
#define CONFIG_PROMPT 24
|
||||||
#define CONFIG_MORE 25
|
#define CONFIG_MORE 25
|
||||||
@@ -81,13 +81,14 @@
|
|||||||
#define CONFIG_CALC_DEBUG 31
|
#define CONFIG_CALC_DEBUG 31
|
||||||
#define CONFIG_USER_DEBUG 32
|
#define CONFIG_USER_DEBUG 32
|
||||||
#define CONFIG_VERBOSE_QUIT 33
|
#define CONFIG_VERBOSE_QUIT 33
|
||||||
|
#define CONFIG_CTRL_D 34
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* config default symbols
|
* config default symbols
|
||||||
*/
|
*/
|
||||||
#define DISPLAY_DEFAULT 20 /* default digits for float display */
|
#define DISPLAY_DEFAULT 20 /* default digits for float display */
|
||||||
#define EPSILON_DEFAULT "1e-20" /* allowed error for float calculations */
|
#define EPSILON_DEFAULT "1e-20" /* allowed error for float calculations */
|
||||||
#define EPSILONPREC_DEFAULT 67 /* 67 ==> 2^-67 <= EPSILON_DEFAULT < 2^-66 */
|
#define EPSILONPREC_DEFAULT 67 /* 67 ==> 2^-67 <= EPSILON_DEFAULT < 2^-66 */
|
||||||
#define NEW_EPSILON_DEFAULT "1e-10" /* newstd EPSILON_DEFAULT */
|
#define NEW_EPSILON_DEFAULT "1e-10" /* newstd EPSILON_DEFAULT */
|
||||||
#define NEW_EPSILONPREC_DEFAULT 34 /* 34 ==> 2^-34 <= 1e-10 < 2^-33 */
|
#define NEW_EPSILONPREC_DEFAULT 34 /* 34 ==> 2^-34 <= 1e-10 < 2^-33 */
|
||||||
@@ -102,7 +103,9 @@
|
|||||||
*
|
*
|
||||||
* quickhash.c - config_hash()
|
* quickhash.c - config_hash()
|
||||||
* hash.c - hash_value()
|
* hash.c - hash_value()
|
||||||
* config.c - setconfig(), config_value(), config_cmp()
|
* config.c - configs[], oldstd, newstd, setconfig(),
|
||||||
|
* config_value(), config_cmp()
|
||||||
|
* config.h - CONFIG_XYZ_SYMBOL (see above)
|
||||||
*/
|
*/
|
||||||
struct config {
|
struct config {
|
||||||
int outmode; /* current output mode */
|
int outmode; /* current output mode */
|
||||||
@@ -139,8 +142,9 @@ struct config {
|
|||||||
long lib_debug; /* library debug, see LIB_DEBUG_XXX below */
|
long lib_debug; /* library debug, see LIB_DEBUG_XXX below */
|
||||||
long user_debug; /* user defined debug value: 0 default */
|
long user_debug; /* user defined debug value: 0 default */
|
||||||
BOOL verbose_quit; /* TRUE => print Quit or abort executed msg */
|
BOOL verbose_quit; /* TRUE => print Quit or abort executed msg */
|
||||||
|
int ctrl_d; /* see CTRL_D_xyz below */
|
||||||
};
|
};
|
||||||
typedef struct config CONFIG;
|
typedef struct config CONFIG;
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -148,7 +152,8 @@ typedef struct config CONFIG;
|
|||||||
*/
|
*/
|
||||||
#define LIBDBG_STDIN_FUNC (0x00000001) /* interactive func define debug */
|
#define LIBDBG_STDIN_FUNC (0x00000001) /* interactive func define debug */
|
||||||
#define LIBDBG_FILE_FUNC (0x00000002) /* file read func define debug */
|
#define LIBDBG_FILE_FUNC (0x00000002) /* file read func define debug */
|
||||||
#define LIBDBG_MASK (0x00000003)
|
#define LIBDBG_FUNC_INFO (0x00000004) /* print extra info for show func */
|
||||||
|
#define LIBDBG_MASK (0x00000007)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -162,6 +167,13 @@ typedef struct config CONFIG;
|
|||||||
#define CALCDBG_RUNSTATE (0x00000020) /* report run_state changes */
|
#define CALCDBG_RUNSTATE (0x00000020) /* report run_state changes */
|
||||||
#define CALCDBG_MASK (0x0000003f)
|
#define CALCDBG_MASK (0x0000003f)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ctrl-d meanings
|
||||||
|
*/
|
||||||
|
#define CTRL_D_VIRGIN (0) /* ^D only exits on virgin command lines */
|
||||||
|
#define CTRL_D_EMACS (1) /* ^D never exits, emacs binding meaning only */
|
||||||
|
#define CTRL_D_EOF (2) /* ^D always exits at start of line */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* global configuration states and aliases
|
* global configuration states and aliases
|
||||||
|
4
custom.c
4
custom.c
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
@@ -117,7 +117,7 @@ showcustom(void)
|
|||||||
{
|
{
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
|
|
||||||
CONST struct custom *p; /* current function */
|
CONST struct custom *p; /* current function */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* disable custom functions unless -C was given
|
* disable custom functions unless -C was given
|
||||||
|
8
custom.h
8
custom.h
@@ -20,16 +20,16 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Prior to calc 2.9.3t9, these routines existed as a calc library called
|
* Prior to calc 2.9.3t9, these routines existed as a calc library called
|
||||||
* cryrand.cal. They have been rewritten in C for performance as well
|
* cryrand.cal. They have been rewritten in C for performance as well
|
||||||
* as to make them available directly from libcalc.a.
|
* as to make them available directly from libcalc.a.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -6,7 +6,7 @@ Step 0: Determine if is should it be done?
|
|||||||
multi-precision calculations in a C-like environment. You should
|
multi-precision calculations in a C-like environment. You should
|
||||||
consider implementing algorithms in the calc language as a first
|
consider implementing algorithms in the calc language as a first
|
||||||
choice. Sometimes an algorithm requires use of special hardware, a
|
choice. Sometimes an algorithm requires use of special hardware, a
|
||||||
non-portable OS or pre-compiled C library. In these cases a custom
|
non-portable OS or pre-compiled C library. In these cases a custom
|
||||||
interface may be needed.
|
interface may be needed.
|
||||||
|
|
||||||
The custom function interface is intended to make is easy for
|
The custom function interface is intended to make is easy for
|
||||||
@@ -184,7 +184,7 @@ Step 5: Write your custom function
|
|||||||
The 3 args are passed in by the custom interface
|
The 3 args are passed in by the custom interface
|
||||||
and have the following meaning:
|
and have the following meaning:
|
||||||
|
|
||||||
name The name of the custom function that
|
name The name of the custom function that
|
||||||
was called. In particular, this is the first
|
was called. In particular, this is the first
|
||||||
string arg that was given to the custom()
|
string arg that was given to the custom()
|
||||||
builtin. This is the equivalent of argv[0] for
|
builtin. This is the equivalent of argv[0] for
|
||||||
@@ -215,11 +215,11 @@ Step 5: Write your custom function
|
|||||||
|
|
||||||
custom("curds", a, b, c)
|
custom("curds", a, b, c)
|
||||||
|
|
||||||
would cause vals to point to the following array:
|
would cause vals to point to the following array:
|
||||||
|
|
||||||
vals[0] points to a
|
vals[0] points to a
|
||||||
vals[1] points to b
|
vals[1] points to b
|
||||||
vals[2] points to c
|
vals[2] points to c
|
||||||
|
|
||||||
c) The return value is the function must be a VALUE.
|
c) The return value is the function must be a VALUE.
|
||||||
|
|
||||||
@@ -247,7 +247,7 @@ Step 5: Write your custom function
|
|||||||
|
|
||||||
The VALUE is a union of major value types found inside calc.
|
The VALUE is a union of major value types found inside calc.
|
||||||
The v_type VALUE element determines which union element is
|
The v_type VALUE element determines which union element is
|
||||||
being used. Assume that we have:
|
being used. Assume that we have:
|
||||||
|
|
||||||
VALUE *vp;
|
VALUE *vp;
|
||||||
|
|
||||||
@@ -427,12 +427,12 @@ Step 6: Register the function in the custom interface table
|
|||||||
level Makefile, one does not have unsatisfied symbols.
|
level Makefile, one does not have unsatisfied symbols.
|
||||||
|
|
||||||
The brief description should be brief so that 'show custom' looks well
|
The brief description should be brief so that 'show custom' looks well
|
||||||
formatted. If the brief description cannot fit on the same line as
|
formatted. If the brief description cannot fit on the same line as
|
||||||
the name without wrapping on a 80 col window, the description is
|
the name without wrapping on a 80 col window, the description is
|
||||||
probably too long and will not look nice in the show custom output.
|
probably too long and will not look nice in the show custom output.
|
||||||
|
|
||||||
The minargs places a lower bound on the number of args that
|
The minargs places a lower bound on the number of args that
|
||||||
must be supplied to the interface. This does NOT count
|
must be supplied to the interface. This does NOT count
|
||||||
the name argument given to custom(). So if minargs is 2:
|
the name argument given to custom(). So if minargs is 2:
|
||||||
|
|
||||||
custom("curds") /* call blocked at high level interface */
|
custom("curds") /* call blocked at high level interface */
|
||||||
|
@@ -22,7 +22,7 @@
|
|||||||
# PERFORMANCE OF THIS SOFTWARE.
|
# PERFORMANCE OF THIS SOFTWARE.
|
||||||
#
|
#
|
||||||
# Comments, suggestions, bug fixes and questions about these routines
|
# Comments, suggestions, bug fixes and questions about these routines
|
||||||
# are welcome. Send EMail to the address given below.
|
# are welcome. Send EMail to the address given below.
|
||||||
#
|
#
|
||||||
# Happy bit twiddling,
|
# Happy bit twiddling,
|
||||||
#
|
#
|
||||||
@@ -146,7 +146,7 @@ DEBUG= -O
|
|||||||
# BSD NO_SHARED=
|
# BSD NO_SHARED=
|
||||||
# SYSV NO_SHARED= -dn
|
# SYSV NO_SHARED= -dn
|
||||||
# IRIX NO_SHARED= -non_shared
|
# IRIX NO_SHARED= -non_shared
|
||||||
# disable NO_SHARED=
|
# disable NO_SHARED=
|
||||||
#
|
#
|
||||||
# If in doubt, use NO_SHARED=
|
# If in doubt, use NO_SHARED=
|
||||||
#
|
#
|
||||||
@@ -168,7 +168,7 @@ RANLIB=:
|
|||||||
# a default here just in case you want to build from this directory.
|
# a default here just in case you want to build from this directory.
|
||||||
#
|
#
|
||||||
# Normally certain files depend on the Makefile. If the Makefile is
|
# Normally certain files depend on the Makefile. If the Makefile is
|
||||||
# changed, then certain steps should be redone. If MAKE_FILE is
|
# changed, then certain steps should be redone. If MAKE_FILE is
|
||||||
# set to Makefile, then these files will depend on Makefile. If
|
# set to Makefile, then these files will depend on Makefile. If
|
||||||
# MAKE_FILE is empty, they they wont.
|
# MAKE_FILE is empty, they they wont.
|
||||||
#
|
#
|
||||||
@@ -192,7 +192,7 @@ MAKE_FILE= Makefile
|
|||||||
#
|
#
|
||||||
# By default, custom builtin functions may only be executed if calc
|
# By default, custom builtin functions may only be executed if calc
|
||||||
# is given the -C option. This is because custom builtin functions
|
# is given the -C option. This is because custom builtin functions
|
||||||
# may invoke non-standard or non-portable code. One may completely
|
# may invoke non-standard or non-portable code. One may completely
|
||||||
# disable custom builtin functions by not compiling any of code
|
# disable custom builtin functions by not compiling any of code
|
||||||
#
|
#
|
||||||
# ALLOW_CUSTOM= -DCUSTOM # allow custom only if -C is given
|
# ALLOW_CUSTOM= -DCUSTOM # allow custom only if -C is given
|
||||||
@@ -285,6 +285,10 @@ H_SRC= ${CUSTOM_H_SRC}
|
|||||||
DISTLIST= ${CUSTCALC_SRC} ${CUSTOM_CALC_FILES} ${CUSTOM_HELP} \
|
DISTLIST= ${CUSTCALC_SRC} ${CUSTOM_CALC_FILES} ${CUSTOM_HELP} \
|
||||||
${INSTALL_H_SRC} CUSTOM_CAL HOW_TO_ADD ${MAKE_FILE}
|
${INSTALL_H_SRC} CUSTOM_CAL HOW_TO_ADD ${MAKE_FILE}
|
||||||
|
|
||||||
|
# These files are used to make (but not built) a calc .a library
|
||||||
|
#
|
||||||
|
CALCLIBLIST= ${CUSTCALC_SRC} ${INSTALL_H_SRC} ${MAKE_FILE} HOW_TO_ADD
|
||||||
|
|
||||||
# complete list of targets
|
# complete list of targets
|
||||||
#
|
#
|
||||||
TARGETS= libcustcalc.a ${CUSTCALC_OBJ}
|
TARGETS= libcustcalc.a ${CUSTCALC_OBJ}
|
||||||
@@ -333,14 +337,14 @@ c_sysinfo.o: c_sysinfo.c ${MAKE_FILE}
|
|||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# File list generation. You can ignore this section.
|
# File list generation. You can ignore this section.
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# We will form the names of source files as if they were in a
|
# We will form the names of source files as if they were in a
|
||||||
# sub-directory called calc/lib.
|
# sub-directory called calc/lib.
|
||||||
#
|
#
|
||||||
# NOTE: Due to bogus shells found on one common system we must have
|
# NOTE: Due to bogus shells found on one common system we must have
|
||||||
# an non-emoty else clause for every if condition. *sigh*
|
# an non-emoty else clause for every if condition. *sigh*
|
||||||
#
|
#
|
||||||
##
|
##
|
||||||
|
|
||||||
@@ -352,6 +356,13 @@ distlist: ${DISTLIST}
|
|||||||
distdir:
|
distdir:
|
||||||
${Q}echo custom
|
${Q}echo custom
|
||||||
|
|
||||||
|
calcliblist: ${CALCLIBLIST}
|
||||||
|
${Q}for i in ${CALCLIBLIST} /dev/null; do \
|
||||||
|
if [ X"$$i" != X"/dev/null" ]; then \
|
||||||
|
echo custom/$$i; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# Home grown make dependency rules. Your system make not support
|
# Home grown make dependency rules. Your system make not support
|
||||||
@@ -376,7 +387,7 @@ depend:
|
|||||||
${Q}mkdir skel
|
${Q}mkdir skel
|
||||||
${Q}mkdir skel/custom
|
${Q}mkdir skel/custom
|
||||||
-${Q}for i in ${C_SRC}; do \
|
-${Q}for i in ${C_SRC}; do \
|
||||||
${SED} -n '/^#[ ]*include[ ]*"/p' \
|
${SED} -n '/^#[ ]*include[ ]*"/p' \
|
||||||
"$$i" > "skel/custom/$$i"; \
|
"$$i" > "skel/custom/$$i"; \
|
||||||
done
|
done
|
||||||
-${Q}for i in /dev/null ${H_SRC}; do \
|
-${Q}for i in /dev/null ${H_SRC}; do \
|
||||||
|
10
custom/argv
10
custom/argv
@@ -23,11 +23,11 @@ DESCRIPTION
|
|||||||
EXAMPLE
|
EXAMPLE
|
||||||
> foo=5^713; bar=17; baz=list(2,3,4);
|
> foo=5^713; bar=17; baz=list(2,3,4);
|
||||||
> custom("argv", foo, bar, baz, 3+4.5i, pi())
|
> custom("argv", foo, bar, baz, 3+4.5i, pi())
|
||||||
arg[0] rational_value size=1 sizeof=272
|
arg[0] rational_value size=1 sizeof=272
|
||||||
arg[1] rational_value size=1 sizeof=68
|
arg[1] rational_value size=1 sizeof=68
|
||||||
arg[2] list size=3 sizeof=256
|
arg[2] list size=3 sizeof=256
|
||||||
arg[3] complex_value size=1 sizeof=140
|
arg[3] complex_value size=1 sizeof=140
|
||||||
arg[4] rational_value size=1 sizeof=84
|
arg[4] rational_value size=1 sizeof=84
|
||||||
5
|
5
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
|
@@ -11,12 +11,12 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -98,13 +98,13 @@ c_argv(char *name, int count, VALUE **vals)
|
|||||||
case V_FILE: /* opened file id */
|
case V_FILE: /* opened file id */
|
||||||
type = "file";
|
type = "file";
|
||||||
break;
|
break;
|
||||||
case V_RAND: /* address of additive 55 random state */
|
case V_RAND: /* address of additive 55 random state */
|
||||||
type = "rand_state";
|
type = "rand_state";
|
||||||
break;
|
break;
|
||||||
case V_RANDOM: /* address of Blum random state */
|
case V_RANDOM: /* address of Blum random state */
|
||||||
type = "random_state";
|
type = "random_state";
|
||||||
break;
|
break;
|
||||||
case V_CONFIG: /* configuration state */
|
case V_CONFIG: /* configuration state */
|
||||||
type = "config_state";
|
type = "config_state";
|
||||||
break;
|
break;
|
||||||
case V_HASH: /* hash state */
|
case V_HASH: /* hash state */
|
||||||
@@ -115,7 +115,7 @@ c_argv(char *name, int count, VALUE **vals)
|
|||||||
break;
|
break;
|
||||||
#if 0
|
#if 0
|
||||||
/* XXX - V_OCTET is subject to change */
|
/* XXX - V_OCTET is subject to change */
|
||||||
case V_OCTET: /* octet (unsigned char) */
|
case V_OCTET: /* octet (unsigned char) */
|
||||||
type = "octet";
|
type = "octet";
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
@@ -11,12 +11,12 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -11,12 +11,12 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -2,7 +2,7 @@
|
|||||||
* Permission to use, copy, modify, and distribute this software and
|
* Permission to use, copy, modify, and distribute this software and
|
||||||
* its documentation for any purpose and without fee is hereby granted.
|
* its documentation for any purpose and without fee is hereby granted.
|
||||||
*
|
*
|
||||||
* Ernest Bowen, following Landon Curt Noll
|
* Ernest Bowen, following Landon Curt Noll
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* count = 1;
|
* count = 1;
|
||||||
* vals[0] real number;
|
* vals[0] real number;
|
||||||
*
|
*
|
||||||
* returns:
|
* returns:
|
||||||
* null
|
* null
|
||||||
@@ -29,7 +29,7 @@
|
|||||||
VALUE
|
VALUE
|
||||||
c_pzasusb8(char *name, int count, VALUE **vals)
|
c_pzasusb8(char *name, int count, VALUE **vals)
|
||||||
{
|
{
|
||||||
VALUE result; /* what we will return */
|
VALUE result; /* what we will return */
|
||||||
ZVALUE z; /* numerator of the value */
|
ZVALUE z; /* numerator of the value */
|
||||||
long half_cnt; /* number of HALFs in the numerator */
|
long half_cnt; /* number of HALFs in the numerator */
|
||||||
USB8 *h; /* octet pointer */
|
USB8 *h; /* octet pointer */
|
||||||
|
@@ -11,12 +11,12 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -20,12 +20,12 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Comments, suggestions, bug fixes and questions about these routines
|
* Comments, suggestions, bug fixes and questions about these routines
|
||||||
* are welcome. Send EMail to the address given below.
|
* are welcome. Send EMail to the address given below.
|
||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo/
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* NOTE: See the file CUSTOM for instructions on how to add
|
* NOTE: See the file CUSTOM for instructions on how to add
|
||||||
* custom functions.
|
* custom functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@@ -10,7 +10,7 @@ TYPES
|
|||||||
return null
|
return null
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This custom function does nothing. It is intented for testing
|
This custom function does nothing. It is intented for testing
|
||||||
of the general custom interface.
|
of the general custom interface.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
|
@@ -11,7 +11,7 @@ TYPES
|
|||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This custom function prints out the numerator of a real value
|
This custom function prints out the numerator of a real value
|
||||||
in octets. Each HALF value is printed in a separate line.
|
in octets. Each HALF value is printed in a separate line.
|
||||||
|
|
||||||
NOTE: The output will vary depending on the size of a HALF
|
NOTE: The output will vary depending on the size of a HALF
|
||||||
and the byte order of the system. See:
|
and the byte order of the system. See:
|
||||||
@@ -26,15 +26,15 @@ DESCRIPTION
|
|||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> custom("pzasusb8", 0x01020304050607080910111213141516);
|
> custom("pzasusb8", 0x01020304050607080910111213141516);
|
||||||
0: 13141516
|
0: 13141516
|
||||||
1: 09101112
|
1: 09101112
|
||||||
2: 05060708
|
2: 05060708
|
||||||
3: 01020304
|
3: 01020304
|
||||||
|
|
||||||
> custom("pzasusb8", 10^25)
|
> custom("pzasusb8", 10^25)
|
||||||
0: 4a000000
|
0: 4a000000
|
||||||
1: 16140148
|
1: 16140148
|
||||||
2: 00084595
|
2: 00084595
|
||||||
|
|
||||||
> printf("%x\n", 10^25);
|
> printf("%x\n", 10^25);
|
||||||
0x84595161401484a000000
|
0x84595161401484a000000
|
||||||
|
37
file.c
37
file.c
@@ -19,7 +19,7 @@
|
|||||||
#include "file.h"
|
#include "file.h"
|
||||||
#include "calcerr.h"
|
#include "calcerr.h"
|
||||||
|
|
||||||
#define READSIZE 1024 /* buffer size for reading */
|
#define READSIZE 1024 /* buffer size for reading */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* external STDIO functions
|
* external STDIO functions
|
||||||
@@ -34,7 +34,7 @@ extern FILE *f_open(char *name, char *mode);
|
|||||||
* and cannot be closed. Their file ids are always 0, 1, and 2.
|
* and cannot be closed. Their file ids are always 0, 1, and 2.
|
||||||
*/
|
*/
|
||||||
static FILEIO files[MAXFILES] = {
|
static FILEIO files[MAXFILES] = {
|
||||||
{FILEID_STDIN, NULL, (dev_t)0, (ino_t)0,
|
{FILEID_STDIN, NULL, (dev_t)0, (ino_t)0,
|
||||||
"(stdin)", TRUE, FALSE, 'r', "r"},
|
"(stdin)", TRUE, FALSE, 'r', "r"},
|
||||||
{FILEID_STDOUT, NULL, (dev_t)0, (ino_t)0,
|
{FILEID_STDOUT, NULL, (dev_t)0, (ino_t)0,
|
||||||
"(stdout)", FALSE, TRUE, 'w', "w"},
|
"(stdout)", FALSE, TRUE, 'w', "w"},
|
||||||
@@ -43,7 +43,7 @@ static FILEIO files[MAXFILES] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static int ioindex[MAXFILES] = {0,1,2}; /* Indices for FILEIO table */
|
static int ioindex[MAXFILES] = {0,1,2}; /* Indices for FILEIO table */
|
||||||
static FILEID lastid = FILEID_STDERR; /* Last allocated file id */
|
static FILEID lastid = FILEID_STDERR; /* Last allocated file id */
|
||||||
static int idnum = 3; /* Number of allocated file ids */
|
static int idnum = 3; /* Number of allocated file ids */
|
||||||
|
|
||||||
@@ -398,7 +398,7 @@ indexid(long index)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Close the specified file id. Returns TRUE if there was an error.
|
* Close the specified file id. Returns TRUE if there was an error.
|
||||||
* Closing of stdin, stdout, or stderr is illegal, but closing of already
|
* Closing of stdin, stdout, or stderr is illegal, but closing of already
|
||||||
* closed files is allowed.
|
* closed files is allowed.
|
||||||
*/
|
*/
|
||||||
@@ -536,7 +536,7 @@ flushall(void)
|
|||||||
*
|
*
|
||||||
* bit 0: at newline
|
* bit 0: at newline
|
||||||
* bit 1: at null character
|
* bit 1: at null character
|
||||||
* bit 2: at white space (also skips leading white space)
|
* bit 2: at white space (also skips leading white space)
|
||||||
*
|
*
|
||||||
* If neither '\n' nor '\0' is encountered reading continues until EOF.
|
* If neither '\n' nor '\0' is encountered reading continues until EOF.
|
||||||
* If bit 3 is set the stop character is removed.
|
* If bit 3 is set the stop character is removed.
|
||||||
@@ -725,7 +725,7 @@ printid(FILEID id, int flags)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Print a formatted string similar to printf. Various formats of output
|
* Print a formatted string similar to printf. Various formats of output
|
||||||
* are possible, depending on the format string AND the actual types of the
|
* are possible, depending on the format string AND the actual types of the
|
||||||
* values. Mismatches do not cause errors, instead something reasonable is
|
* values. Mismatches do not cause errors, instead something reasonable is
|
||||||
* printed instead. The output goes to the file with the specified id.
|
* printed instead. The output goes to the file with the specified id.
|
||||||
@@ -1294,7 +1294,7 @@ getloc(FILEID id, ZVALUE *res)
|
|||||||
*/
|
*/
|
||||||
fiop = findid(id, 0);
|
fiop = findid(id, 0);
|
||||||
if (fiop == NULL) {
|
if (fiop == NULL) {
|
||||||
/* file not open */
|
/* file not open */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
fp = fiop->fp;
|
fp = fiop->fp;
|
||||||
@@ -1467,7 +1467,7 @@ setloc(FILEID id, ZVALUE zpos)
|
|||||||
*/
|
*/
|
||||||
fiop = findid(id, 0);
|
fiop = findid(id, 0);
|
||||||
if (fiop == NULL) {
|
if (fiop == NULL) {
|
||||||
/* file not open */
|
/* file not open */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
fp = fiop->fp;
|
fp = fiop->fp;
|
||||||
@@ -1635,7 +1635,7 @@ getsize(FILEID id, ZVALUE *res)
|
|||||||
*/
|
*/
|
||||||
fiop = findid(id, 0);
|
fiop = findid(id, 0);
|
||||||
if (fiop == NULL) {
|
if (fiop == NULL) {
|
||||||
/* file not open */
|
/* file not open */
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
fp = fiop->fp;
|
fp = fiop->fp;
|
||||||
@@ -1671,7 +1671,7 @@ get_device(FILEID id, ZVALUE *dev)
|
|||||||
*/
|
*/
|
||||||
fiop = findid(id, 0);
|
fiop = findid(id, 0);
|
||||||
if (fiop == NULL) {
|
if (fiop == NULL) {
|
||||||
/* file not open */
|
/* file not open */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1704,7 +1704,7 @@ get_inode(FILEID id, ZVALUE *inode)
|
|||||||
*/
|
*/
|
||||||
fiop = findid(id, 0);
|
fiop = findid(id, 0);
|
||||||
if (fiop == NULL) {
|
if (fiop == NULL) {
|
||||||
/* file not open */
|
/* file not open */
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2144,7 +2144,7 @@ scanfstr(char *str, char *fmt, int count, VALUE **vals)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Read a number in floating-point format from a file. The first dot,
|
* Read a number in floating-point format from a file. The first dot,
|
||||||
* if any, is considered as the decimal point; later dots are ignored.
|
* if any, is considered as the decimal point; later dots are ignored.
|
||||||
* For example, -23.45..67. is interpreted as -23.4567
|
* For example, -23.45..67. is interpreted as -23.4567
|
||||||
* An optional 'e' or 'E' indicates multiplication by a power or 10,
|
* An optional 'e' or 'E' indicates multiplication by a power or 10,
|
||||||
@@ -2228,15 +2228,16 @@ freadnum(FILE *fp, VALUE *valptr)
|
|||||||
ch = fgetc(fp);
|
ch = fgetc(fp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ch == 'i' || ch == 'I')
|
if (ch == 'i' || ch == 'I') {
|
||||||
imag = TRUE;
|
imag = TRUE;
|
||||||
else {
|
} else {
|
||||||
ungetc(ch, fp);
|
ungetc(ch, fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ziszero(num)) {
|
if (ziszero(num)) {
|
||||||
zfree(num);
|
zfree(num);
|
||||||
val.v_type = V_NUM;
|
val.v_type = V_NUM;
|
||||||
|
val.v_subtype = V_NOSUBTYPE;
|
||||||
val.v_num = qlink(&_qzero_);
|
val.v_num = qlink(&_qzero_);
|
||||||
*valptr = val;
|
*valptr = val;
|
||||||
return;
|
return;
|
||||||
@@ -2281,11 +2282,11 @@ freadnum(FILE *fp, VALUE *valptr)
|
|||||||
c->imag = q;
|
c->imag = q;
|
||||||
val.v_type = V_COM;
|
val.v_type = V_COM;
|
||||||
val.v_com = c;
|
val.v_com = c;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
val.v_type = V_NUM;
|
val.v_type = V_NUM;
|
||||||
val.v_num = q;
|
val.v_num = q;
|
||||||
}
|
}
|
||||||
|
val.v_subtype = V_NOSUBTYPE;
|
||||||
*valptr = val;
|
*valptr = val;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2393,7 +2394,7 @@ isattyid(FILEID id)
|
|||||||
* zero if string found, position stored at res
|
* zero if string found, position stored at res
|
||||||
*
|
*
|
||||||
* XXX - This search is a translation of the original search that did not
|
* XXX - This search is a translation of the original search that did not
|
||||||
* work with large files. The search algorithm used is slow and
|
* work with large files. The search algorithm used is slow and
|
||||||
* should be spead up much more.
|
* should be spead up much more.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
@@ -2512,7 +2513,7 @@ fsearch(FILEID id, char *str, ZVALUE start, ZVALUE end, ZVALUE *res)
|
|||||||
* zero if string found, position stored at res
|
* zero if string found, position stored at res
|
||||||
*
|
*
|
||||||
* XXX - This search is a translation of the original search that did not
|
* XXX - This search is a translation of the original search that did not
|
||||||
* work with large files. The search algorithm used is so slow
|
* work with large files. The search algorithm used is so slow
|
||||||
* as to be painful to the user and needs to be sped up much more.
|
* as to be painful to the user and needs to be sped up much more.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
|
4
file.h
4
file.h
@@ -42,7 +42,7 @@ typedef struct {
|
|||||||
* We assume that if your system does not have fgetpos/fsetpos,
|
* We assume that if your system does not have fgetpos/fsetpos,
|
||||||
* then it will have a FILEPOS that is a scalar type (e.g., long).
|
* then it will have a FILEPOS that is a scalar type (e.g., long).
|
||||||
* Some obscure systems without fgetpos/fsetpos may not have a simple
|
* Some obscure systems without fgetpos/fsetpos may not have a simple
|
||||||
* scalar type. In these cases the f_tell macro below will fail.
|
* scalar type. In these cases the f_tell macro below will fail.
|
||||||
*/
|
*/
|
||||||
#if defined(HAVE_FPOS)
|
#if defined(HAVE_FPOS)
|
||||||
|
|
||||||
@@ -51,7 +51,7 @@ typedef struct {
|
|||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#define f_seek_set(stream, loc) \
|
#define f_seek_set(stream, loc) \
|
||||||
fseek((FILE*)(stream), *(FILEPOS*)(loc), SEEK_SET)
|
fseek((FILE*)(stream), *(FILEPOS*)(loc), SEEK_SET)
|
||||||
#define f_tell(stream, loc) (*((FILEPOS*)(loc)) = ftell((FILE*)(stream)))
|
#define f_tell(stream, loc) (*((FILEPOS*)(loc)) = ftell((FILE*)(stream)))
|
||||||
|
|
||||||
|
@@ -12,7 +12,7 @@
|
|||||||
*
|
*
|
||||||
* We will #define of 8 symbols:
|
* We will #define of 8 symbols:
|
||||||
*
|
*
|
||||||
* FILEPOS_BITS length in bits of the type FILEPOS
|
* FILEPOS_BITS length in bits of the type FILEPOS
|
||||||
* SWAP_HALF_IN_FILEPOS will copy/swap FILEPOS into an HALF array
|
* SWAP_HALF_IN_FILEPOS will copy/swap FILEPOS into an HALF array
|
||||||
* OFF_T_BITS length in bits of the st_size stat element
|
* OFF_T_BITS length in bits of the st_size stat element
|
||||||
* SWAP_HALF_IN_OFF_T will copy/swap st_size into an HALF array
|
* SWAP_HALF_IN_OFF_T will copy/swap st_size into an HALF array
|
||||||
|
2
func.h
2
func.h
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#if !defined(__FUNC_H__)
|
#if !defined(__FUNC_H__)
|
||||||
#define __FUNC_H__
|
#define __FUNC_H__
|
||||||
|
|
||||||
|
|
||||||
#include "calc.h"
|
#include "calc.h"
|
||||||
|
78
hash.c
78
hash.c
@@ -39,6 +39,15 @@ extern void shs1_init_state(HASH*);
|
|||||||
extern void MD5_init_state(HASH*);
|
extern void MD5_init_state(HASH*);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* hash_long can deal with BOOL's, int's, FLAGS's and LEN's
|
||||||
|
*/
|
||||||
|
#define hash_bool(type, val, state) (hash_long((type), (long)(val), (state)))
|
||||||
|
#define hash_int(type, val, state) (hash_long((type), (long)(val), (state)))
|
||||||
|
#define hash_flag(type, val, state) (hash_long((type), (long)(val), (state)))
|
||||||
|
#define hash_len(type, val, state) (hash_long((type), (long)(val), (state)))
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash_setup - setup the hash state for a given hash
|
* hash_setup - setup the hash state for a given hash
|
||||||
*/
|
*/
|
||||||
@@ -248,15 +257,18 @@ hash_final(HASH *state)
|
|||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* type - hash type (see hash.h)
|
* type - hash type (see hash.h)
|
||||||
* longval - a long value
|
* longval - a long value
|
||||||
* state - the state to hash
|
* state - the state to hash
|
||||||
*
|
*
|
||||||
* returns:
|
* returns:
|
||||||
* the new state
|
* the new state
|
||||||
*
|
*
|
||||||
* This function will hash a long value as if it were a 64 bit value.
|
* This function will hash a long value as if it were a 64 bit value.
|
||||||
* The input is a long. If a long is smaller than 64 bits, we will
|
* The input is a long. If a long is smaller than 64 bits, we will
|
||||||
* hash a final 32 bits of zeros.
|
* hash a final 32 bits of zeros.
|
||||||
|
*
|
||||||
|
* This function is OK to hash BOOL's, unslogned long's, unsigned int's
|
||||||
|
* signed int's as well as FLAG's and LEN's.
|
||||||
*/
|
*/
|
||||||
HASH *
|
HASH *
|
||||||
hash_long(int type, long longval, HASH *state)
|
hash_long(int type, long longval, HASH *state)
|
||||||
@@ -734,11 +746,10 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
(state->type)(value->v_type, state);
|
(state->type)(value->v_type, state);
|
||||||
|
|
||||||
/* hash as if we have a 64 bit value */
|
/* hash as if we have a 64 bit value */
|
||||||
state = hash_long(type, (long)value->v_int, state);
|
state = hash_int(type, value->v_int, state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case V_NUM:
|
case V_NUM:
|
||||||
|
|
||||||
/* hash this type */
|
/* hash this type */
|
||||||
state = hash_number(type, value->v_num, state);
|
state = hash_number(type, value->v_num, state);
|
||||||
break;
|
break;
|
||||||
@@ -884,12 +895,12 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
(state->type)(value->v_type, state);
|
(state->type)(value->v_type, state);
|
||||||
|
|
||||||
/* hash the RAND state */
|
/* hash the RAND state */
|
||||||
state = hash_long(type, (long)value->v_rand->seeded, state);
|
state = hash_int(type, value->v_rand->seeded, state);
|
||||||
state = hash_long(type, (long)value->v_rand->bits, state);
|
state = hash_int(type, value->v_rand->bits, state);
|
||||||
(state->update)(state,
|
(state->update)(state,
|
||||||
(USB8 *)value->v_rand->buffer, SLEN*FULL_BITS/8);
|
(USB8 *)value->v_rand->buffer, SLEN*FULL_BITS/8);
|
||||||
state = hash_long(type, (long)value->v_rand->j, state);
|
state = hash_int(type, value->v_rand->j, state);
|
||||||
state = hash_long(type, (long)value->v_rand->k, state);
|
state = hash_int(type, value->v_rand->k, state);
|
||||||
(state->update)(state,
|
(state->update)(state,
|
||||||
(USB8 *)value->v_rand->slot, SCNT*FULL_BITS/8);
|
(USB8 *)value->v_rand->slot, SCNT*FULL_BITS/8);
|
||||||
(state->update)(state,
|
(state->update)(state,
|
||||||
@@ -903,8 +914,8 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
(state->type)(value->v_type, state);
|
(state->type)(value->v_type, state);
|
||||||
|
|
||||||
/* hash the RANDOM state */
|
/* hash the RANDOM state */
|
||||||
state = hash_long(type, (long)value->v_random->seeded, state);
|
state = hash_int(type, value->v_random->seeded, state);
|
||||||
state = hash_long(type, (long)value->v_random->bits, state);
|
state = hash_int(type, value->v_random->bits, state);
|
||||||
(state->update)(state,
|
(state->update)(state,
|
||||||
(USB8 *)&(value->v_random->buffer), BASEB/8);
|
(USB8 *)&(value->v_random->buffer), BASEB/8);
|
||||||
state = hash_zvalue(type, value->v_random->r, state);
|
state = hash_zvalue(type, value->v_random->r, state);
|
||||||
@@ -918,20 +929,19 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
(state->type)(value->v_type, state);
|
(state->type)(value->v_type, state);
|
||||||
|
|
||||||
/* hash the CONFIG state */
|
/* hash the CONFIG state */
|
||||||
state = hash_long(type, (long)value->v_config->outmode, state);
|
state = hash_int(type, value->v_config->outmode, state);
|
||||||
state = hash_long(type,(long)value->v_config->outdigits, state);
|
state = hash_long(type,(long)value->v_config->outdigits, state);
|
||||||
state = hash_number(type, value->v_config->epsilon, state);
|
state = hash_number(type, value->v_config->epsilon, state);
|
||||||
state = hash_long(type,
|
state = hash_long(type,
|
||||||
(long)value->v_config->epsilonprec, state);
|
(long)value->v_config->epsilonprec, state);
|
||||||
state = hash_long(type,
|
state = hash_flag(type, value->v_config->traceflags, state);
|
||||||
(long)value->v_config->traceflags, state);
|
|
||||||
state = hash_long(type, (long)value->v_config->maxprint, state);
|
state = hash_long(type, (long)value->v_config->maxprint, state);
|
||||||
state = hash_long(type, (long)value->v_config->mul2, state);
|
state = hash_len(type, value->v_config->mul2, state);
|
||||||
state = hash_long(type, (long)value->v_config->sq2, state);
|
state = hash_len(type, value->v_config->sq2, state);
|
||||||
state = hash_long(type, (long)value->v_config->pow2, state);
|
state = hash_len(type, value->v_config->pow2, state);
|
||||||
state = hash_long(type, (long)value->v_config->redc2, state);
|
state = hash_len(type, value->v_config->redc2, state);
|
||||||
state = hash_long(type, (long)value->v_config->tilde_ok, state);
|
state = hash_bool(type, value->v_config->tilde_ok, state);
|
||||||
state = hash_long(type, (long)value->v_config->tab_ok, state);
|
state = hash_bool(type, value->v_config->tab_ok, state);
|
||||||
state = hash_long(type, (long)value->v_config->quomod, state);
|
state = hash_long(type, (long)value->v_config->quomod, state);
|
||||||
state = hash_long(type, (long)value->v_config->quo, state);
|
state = hash_long(type, (long)value->v_config->quo, state);
|
||||||
state = hash_long(type, (long)value->v_config->mod, state);
|
state = hash_long(type, (long)value->v_config->mod, state);
|
||||||
@@ -941,28 +951,26 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
state = hash_long(type, (long)value->v_config->cfsim, state);
|
state = hash_long(type, (long)value->v_config->cfsim, state);
|
||||||
state = hash_long(type, (long)value->v_config->outround, state);
|
state = hash_long(type, (long)value->v_config->outround, state);
|
||||||
state = hash_long(type, (long)value->v_config->round, state);
|
state = hash_long(type, (long)value->v_config->round, state);
|
||||||
state = hash_long(type, (long)value->v_config->leadzero, state);
|
state = hash_bool(type, value->v_config->leadzero, state);
|
||||||
state = hash_long(type, (long)value->v_config->fullzero, state);
|
state = hash_bool(type, value->v_config->fullzero, state);
|
||||||
state = hash_long(type,
|
state = hash_long(type,
|
||||||
(long)value->v_config->maxscancount, state);
|
(long)value->v_config->maxscancount, state);
|
||||||
state = hash_str(type, value->v_config->prompt1, state);
|
state = hash_str(type, value->v_config->prompt1, state);
|
||||||
state->bytes = FALSE; /* as if just read words */
|
state->bytes = FALSE; /* as if just read words */
|
||||||
state = hash_str(type, value->v_config->prompt2, state);
|
state = hash_str(type, value->v_config->prompt2, state);
|
||||||
state->bytes = FALSE; /* as if just read words */
|
state->bytes = FALSE; /* as if just read words */
|
||||||
state = hash_long(type,
|
state = hash_int(type, value->v_config->blkmaxprint, state);
|
||||||
(long)value->v_config->blkmaxprint, state);
|
state = hash_bool(type, value->v_config->blkverbose, state);
|
||||||
state = hash_long(type,
|
state = hash_int(type, value->v_config->blkbase, state);
|
||||||
(long)value->v_config->blkverbose, state);
|
state = hash_int(type, value->v_config->blkfmt, state);
|
||||||
state = hash_long(type,
|
|
||||||
(long)value->v_config->blkbase, state);
|
|
||||||
state = hash_long(type,
|
|
||||||
(long)value->v_config->blkfmt, state);
|
|
||||||
state = hash_long(type,
|
state = hash_long(type,
|
||||||
(long)value->v_config->lib_debug, state);
|
(long)value->v_config->lib_debug, state);
|
||||||
state = hash_long(type,
|
state = hash_long(type,
|
||||||
(long)value->v_config->calc_debug, state);
|
(long)value->v_config->calc_debug, state);
|
||||||
state = hash_long(type,
|
state = hash_long(type,
|
||||||
(long)value->v_config->user_debug, state);
|
(long)value->v_config->user_debug, state);
|
||||||
|
state = hash_bool(type, value->v_config->verbose_quit, state);
|
||||||
|
state = hash_int(type, value->v_config->ctrl_d, state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case V_HASH:
|
case V_HASH:
|
||||||
@@ -971,11 +979,11 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
(state->type)(value->v_type, state);
|
(state->type)(value->v_type, state);
|
||||||
|
|
||||||
/* hash the HASH state */
|
/* hash the HASH state */
|
||||||
state = hash_long(type, (long)value->v_hash->type, state);
|
state = hash_int(type, value->v_hash->type, state);
|
||||||
state = hash_long(type, (long)value->v_hash->bytes,state);
|
state = hash_bool(type, value->v_hash->bytes,state);
|
||||||
state = hash_long(type, (long)value->v_hash->base, state);
|
state = hash_int(type, value->v_hash->base, state);
|
||||||
state = hash_long(type, (long)value->v_hash->chunksize, state);
|
state = hash_int(type, value->v_hash->chunksize, state);
|
||||||
state = hash_long(type, (long)value->v_hash->unionsize, state);
|
state = hash_int(type, value->v_hash->unionsize, state);
|
||||||
(state->update)(state,
|
(state->update)(state,
|
||||||
value->v_hash->h_union.data, state->unionsize);
|
value->v_hash->h_union.data, state->unionsize);
|
||||||
state->bytes = FALSE; /* as if reading words */
|
state->bytes = FALSE; /* as if reading words */
|
||||||
|
4
hash.h
4
hash.h
@@ -52,8 +52,8 @@
|
|||||||
*/
|
*/
|
||||||
typedef struct hashstate HASH;
|
typedef struct hashstate HASH;
|
||||||
struct hashstate {
|
struct hashstate {
|
||||||
int hashtype; /* XYZ_HASH_TYPE debug value */
|
int hashtype; /* XYZ_HASH_TYPE debug value */
|
||||||
BOOL bytes; /* TRUE => reading bytes rather than words */
|
BOOL bytes; /* TRUE => reading bytes rather than words */
|
||||||
void (*update)(HASH*, USB8*, USB32); /* update arbitrary length */
|
void (*update)(HASH*, USB8*, USB32); /* update arbitrary length */
|
||||||
void (*chkpt)(HASH*); /* checkpoint a state */
|
void (*chkpt)(HASH*); /* checkpoint a state */
|
||||||
void (*note)(int, HASH*); /* note a special value */
|
void (*note)(int, HASH*); /* note a special value */
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* have_offscl
|
* have_offscl
|
||||||
*
|
*
|
||||||
* On some systems, off_t is a scalar value on which one can perform
|
* On some systems, off_t is a scalar value on which one can perform
|
||||||
* arithmetic operations, assignments and comparisons. On some systems
|
* arithmetic operations, assignments and comparisons. On some systems
|
||||||
* off_t is some sort of union or struct which must be converted into
|
* off_t is some sort of union or struct which must be converted into
|
||||||
* a ZVALUE in order to perform arithmetic operations, assignments and
|
* a ZVALUE in order to perform arithmetic operations, assignments and
|
||||||
* comparisons.
|
* comparisons.
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* have_posscl
|
* have_posscl
|
||||||
*
|
*
|
||||||
* On some systems, FILEPOS is a scalar value on which one can perform
|
* On some systems, FILEPOS is a scalar value on which one can perform
|
||||||
* arithmetic operations, assignments and comparisons. On some systems
|
* arithmetic operations, assignments and comparisons. On some systems
|
||||||
* FILEPOS is some sort of union or struct which must be converted into
|
* FILEPOS is some sort of union or struct which must be converted into
|
||||||
* a ZVALUE in order to perform arithmetic operations, assignments and
|
* a ZVALUE in order to perform arithmetic operations, assignments and
|
||||||
* comparisons.
|
* comparisons.
|
||||||
@@ -51,7 +51,7 @@ main(void)
|
|||||||
{
|
{
|
||||||
#if !defined(FILEPOS_NON_SCALAR)
|
#if !defined(FILEPOS_NON_SCALAR)
|
||||||
FILEPOS value; /* an FILEPOS to perform arithmatic on */
|
FILEPOS value; /* an FILEPOS to perform arithmatic on */
|
||||||
FILEPOS value2; /* an FILEPOS to perform arithmatic on */
|
FILEPOS value2; /* an FILEPOS to perform arithmatic on */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* do some math opts on an FILEPOS
|
* do some math opts on an FILEPOS
|
||||||
|
@@ -9,7 +9,7 @@
|
|||||||
* as if it were vsprintf() and hope for the best.
|
* as if it were vsprintf() and hope for the best.
|
||||||
*
|
*
|
||||||
* This program will output #defines and exits 0 if vsprintf() (or sprintf())
|
* This program will output #defines and exits 0 if vsprintf() (or sprintf())
|
||||||
* produces the results that we expect. This program exits 1 if vsprintf()
|
* produces the results that we expect. This program exits 1 if vsprintf()
|
||||||
* (or sprintf()) produces unexpected results while using the <stdarg.h>
|
* (or sprintf()) produces unexpected results while using the <stdarg.h>
|
||||||
* include file.
|
* include file.
|
||||||
*/
|
*/
|
||||||
@@ -109,14 +109,14 @@ main(void)
|
|||||||
puts(" * SIMULATE_STDARG");
|
puts(" * SIMULATE_STDARG");
|
||||||
puts(" *");
|
puts(" *");
|
||||||
puts(" * WARNING: This type of stdarg makes assumptions about the stack");
|
puts(" * WARNING: This type of stdarg makes assumptions about the stack");
|
||||||
puts(" * that may not be true on your system. You may want to");
|
puts(" * that may not be true on your system. You may want to");
|
||||||
puts(" * define STDARG (if using ANSI C) or VARARGS.");
|
puts(" * define STDARG (if using ANSI C) or VARARGS.");
|
||||||
puts(" */");
|
puts(" */");
|
||||||
puts("typedef char *va_list;");
|
puts("typedef char *va_list;");
|
||||||
puts("#define va_start(ap,parmn) (void)((ap) = (char*)(&(parmn) + 1))");
|
puts("#define va_start(ap,parmn) (void)((ap) = (char*)(&(parmn) + 1))");
|
||||||
puts("#define va_end(ap) (void)((ap) = 0)");
|
puts("#define va_end(ap) (void)((ap) = 0)");
|
||||||
puts("#define va_arg(ap, type) \\");
|
puts("#define va_arg(ap, type) \\");
|
||||||
puts(" (((type*)((ap) = ((ap) + sizeof(type))))[-1])");
|
puts(" (((type*)((ap) = ((ap) + sizeof(type))))[-1])");
|
||||||
puts("#define SIMULATE_STDARG /* use std_arg.h to simulate <stdarg.h> */");
|
puts("#define SIMULATE_STDARG /* use std_arg.h to simulate <stdarg.h> */");
|
||||||
#else
|
#else
|
||||||
puts("#define STDARG /* use <stdarg.h> */");
|
puts("#define STDARG /* use <stdarg.h> */");
|
||||||
|
@@ -50,8 +50,8 @@ main(void)
|
|||||||
|
|
||||||
#else /* HAVE_NO_USTAT */
|
#else /* HAVE_NO_USTAT */
|
||||||
|
|
||||||
struct stat stat_dot; /* stat of "." */
|
struct stat stat_dot; /* stat of "." */
|
||||||
struct ustat ustat_dot; /* usage stat of "." */
|
struct ustat ustat_dot; /* usage stat of "." */
|
||||||
|
|
||||||
(void) stat(".", &stat_dot);
|
(void) stat(".", &stat_dot);
|
||||||
(void) ustat(stat_dot.st_dev, &ustat_dot);
|
(void) ustat(stat_dot.st_dev, &ustat_dot);
|
||||||
|
@@ -6,7 +6,7 @@
|
|||||||
* and hope for the best.
|
* and hope for the best.
|
||||||
*
|
*
|
||||||
* This program will output #defines and exits 0 if vsprintf() (or sprintf())
|
* This program will output #defines and exits 0 if vsprintf() (or sprintf())
|
||||||
* produces the results that we expect. This program exits 1 if vsprintf()
|
* produces the results that we expect. This program exits 1 if vsprintf()
|
||||||
* (or sprintf()) produces unexpected results while using the <stdarg.h>
|
* (or sprintf()) produces unexpected results while using the <stdarg.h>
|
||||||
* include file.
|
* include file.
|
||||||
*/
|
*/
|
||||||
|
@@ -67,7 +67,7 @@ BLT_HELP_FILES_9= stdlib
|
|||||||
|
|
||||||
STD_HELP_FILES_10= types usage unexpected variable
|
STD_HELP_FILES_10= types usage unexpected variable
|
||||||
|
|
||||||
BLT_HELP_FILES_11= altbind bindings custom_cal libcalc new_custom stdlib
|
BLT_HELP_FILES_11= bindings custom_cal libcalc new_custom stdlib
|
||||||
|
|
||||||
STD_HELP_FILES_12= archive
|
STD_HELP_FILES_12= archive
|
||||||
|
|
||||||
@@ -104,16 +104,16 @@ BLT_HELP_FILES= ${BLT_HELP_FILES_3} ${BLT_HELP_FILES_5} \
|
|||||||
# This list is prodiced by the detaillist rule when no WARNINGS are detected.
|
# This list is prodiced by the detaillist rule when no WARNINGS are detected.
|
||||||
#
|
#
|
||||||
DETAIL_HELP= abs access acos acosh acot acoth acsc acsch address agd append \
|
DETAIL_HELP= abs access acos acosh acot acoth acsc acsch address agd append \
|
||||||
appr arg arrow asec asech asin asinh assign atan atan2 atanh avg \
|
appr arg arrow asec asech asin asinh assign atan atan2 atanh avg base \
|
||||||
base bit blk blkcpy blkfree blocks bround btrunc calclevel ceil \
|
bit blk blkcpy blkfree blocks bround btrunc calclevel ceil cfappr \
|
||||||
cfappr cfsim char cmdbuf cmp comb conj cos cosh cot coth count cp \
|
cfsim char cmdbuf cmp comb conj cos cosh cot coth count cp csc csch \
|
||||||
csc csch ctime delete den dereference det digit digits dp epsilon \
|
ctime delete den dereference det digit digits dp epsilon errcount \
|
||||||
errcount errmax errno error eval exp fact factor fclose fcnt feof \
|
errmax errno error eval exp fact factor fclose fcnt feof ferror \
|
||||||
ferror fflush fgetc fgetfield fgetline fgets fgetstr fib files \
|
fflush fgetc fgetfield fgetline fgets fgetstr fib files floor fopen \
|
||||||
floor fopen forall fprintf fputc fputs fputstr frac free freeglobals \
|
forall fprintf fputc fputs fputstr frac free freeglobals freeredc \
|
||||||
freeredc freestatics frem freopen fscan fscanf fseek fsize ftell gcd \
|
freestatics frem freopen fscan fscanf fseek fsize ftell gcd gcdrem \
|
||||||
gcdrem gd getenv hash head highbit hmean hnrmod hypot ilog ilog10 \
|
gd getenv hash head highbit hmean hnrmod hypot ilog ilog10 ilog2 \
|
||||||
ilog2 im inputlevel insert int inverse iroot isassoc isatty isblk \
|
im indices inputlevel insert int inverse iroot isassoc isatty isblk \
|
||||||
isconfig isdefined iserror iseven isfile ishash isident isint islist \
|
isconfig isdefined iserror iseven isfile ishash isident isint islist \
|
||||||
ismat ismult isnull isnum isobj isobjtype isodd isprime isptr isqrt \
|
ismat ismult isnull isnum isobj isobjtype isodd isprime isptr isqrt \
|
||||||
isrand israndom isreal isrel issimple issq isstr istype jacobi join \
|
isrand israndom isreal isrel issimple issq isstr istype jacobi join \
|
||||||
@@ -147,13 +147,17 @@ DISTLIST= ${STD_HELP_FILES} ${DETAIL_HELP} ${MAKE_FILE} \
|
|||||||
obj.file builtin.top builtin.end funclist.sed \
|
obj.file builtin.top builtin.end funclist.sed \
|
||||||
errorcodes.hdr errorcodes.sed
|
errorcodes.hdr errorcodes.sed
|
||||||
|
|
||||||
|
# These files are used to make (but not built) a calc .a library
|
||||||
|
#
|
||||||
|
CALCLIBLIST=
|
||||||
|
|
||||||
all: ${FULL_HELP_FILES} full ${DETAIL_HELP} ${DETAIL_CLONE} \
|
all: ${FULL_HELP_FILES} full ${DETAIL_HELP} ${DETAIL_CLONE} \
|
||||||
${SINGULAR_FILES} calc .all
|
${SINGULAR_FILES} calc .all
|
||||||
|
|
||||||
# used by the upper level Makefile to determine of we have done all
|
# used by the upper level Makefile to determine of we have done all
|
||||||
#
|
#
|
||||||
# NOTE: Due to bogus shells found on one common system we must have
|
# NOTE: Due to bogus shells found on one common system we must have
|
||||||
# an non-emoty else clause for every if condition. *sigh*
|
# an non-emoty else clause for every if condition. *sigh*
|
||||||
#
|
#
|
||||||
.all:
|
.all:
|
||||||
rm -f .all
|
rm -f .all
|
||||||
@@ -171,18 +175,6 @@ bindings: ../lib/bindings
|
|||||||
true; \
|
true; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
altbind: ../lib/altbind
|
|
||||||
rm -f $@
|
|
||||||
cp ../lib/altbind $@
|
|
||||||
chmod 0444 $@
|
|
||||||
-@if [ -z "${Q}" ]; then \
|
|
||||||
echo ''; \
|
|
||||||
echo '=-=-= skipping the cat of help/$@ =-=-='; \
|
|
||||||
echo ''; \
|
|
||||||
else \
|
|
||||||
true; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
stdlib: ../lib/README
|
stdlib: ../lib/README
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp ../lib/README $@
|
cp ../lib/README $@
|
||||||
@@ -341,7 +333,7 @@ ${SINGULAR_FILES}: ${PLURAL_FILES}
|
|||||||
# Form the builtin file
|
# Form the builtin file
|
||||||
#
|
#
|
||||||
# We ave a "chicken-and-egg" problem. We want the builtn help file to
|
# We ave a "chicken-and-egg" problem. We want the builtn help file to
|
||||||
# accurately reflect the function list. It would be nice if we could
|
# accurately reflect the function list. It would be nice if we could
|
||||||
# just execute calc show builtin, but calc may not have been built or
|
# just execute calc show builtin, but calc may not have been built or
|
||||||
# buildable at this point. The hack-a-round used is to convert ../func.c
|
# buildable at this point. The hack-a-round used is to convert ../func.c
|
||||||
# into a standalone program that generates a suitable function list
|
# into a standalone program that generates a suitable function list
|
||||||
@@ -379,7 +371,7 @@ builtin: builtin.top builtin.end ../func.c funclist.sed
|
|||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# File list generation. You can ignore this section.
|
# File list generation. You can ignore this section.
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# We will form the names of source files as if they were in a
|
# We will form the names of source files as if they were in a
|
||||||
@@ -395,6 +387,13 @@ distlist: ${DISTLIST}
|
|||||||
distdir:
|
distdir:
|
||||||
${Q}echo help
|
${Q}echo help
|
||||||
|
|
||||||
|
calcliblist:
|
||||||
|
${Q}for i in ${CALCLIBLIST} /dev/null; do \
|
||||||
|
if [ X"$$i" != X"/dev/null" ]; then \
|
||||||
|
echo help/$$i; \
|
||||||
|
fi; \
|
||||||
|
done
|
||||||
|
|
||||||
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
||||||
# creats these fils so that the release can be shipped off to BSDI. You can
|
# creats these fils so that the release can be shipped off to BSDI. You can
|
||||||
# ignore this rule.
|
# ignore this rule.
|
||||||
|
@@ -17,7 +17,7 @@ DESCRIPTION
|
|||||||
acosh(x) is the nonnegative real number v for which cosh(v) = x.
|
acosh(x) is the nonnegative real number v for which cosh(v) = x.
|
||||||
It is given by
|
It is given by
|
||||||
|
|
||||||
acosh(x) = ln(x + sqrt(x^2 - 1))
|
acosh(x) = ln(x + sqrt(x^2 - 1))
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> print acosh(2, 1e-5), acosh(2, 1e-10), acosh(2, 1e-15), acosh(2, 1e-20)
|
> print acosh(2, 1e-5), acosh(2, 1e-10), acosh(2, 1e-15), acosh(2, 1e-20)
|
||||||
|
@@ -16,7 +16,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
acoth(x) is the real number v for which coth(v) = x.
|
acoth(x) is the real number v for which coth(v) = x.
|
||||||
It is given by
|
It is given by
|
||||||
acoth(x) = ln((x + 1)/(x - 1))/2
|
acoth(x) = ln((x + 1)/(x - 1))/2
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> print acoth(2, 1e-5), acoth(2, 1e-10), acoth(2, 1e-15), acoth(2, 1e-20)
|
> print acoth(2, 1e-5), acoth(2, 1e-10), acoth(2, 1e-15), acoth(2, 1e-20)
|
||||||
|
@@ -16,7 +16,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
acsch(x) is the real number v for which csch(v) = x. It is given by
|
acsch(x) is the real number v for which csch(v) = x. It is given by
|
||||||
|
|
||||||
acsch(x) = ln((1 + sqrt(1 + x^2))/x)
|
acsch(x) = ln((1 + sqrt(1 + x^2))/x)
|
||||||
|
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
|
@@ -20,7 +20,7 @@ DESCRIPTION
|
|||||||
otherwise accessing, such a vacated address may be catastrophic.
|
otherwise accessing, such a vacated address may be catastrophic.
|
||||||
|
|
||||||
An octet is normally expressed by B[i] where B is a block and
|
An octet is normally expressed by B[i] where B is a block and
|
||||||
0 <= i < sizeof(B). &B[i] then returns the address at which this
|
0 <= i < sizeof(B). &B[i] then returns the address at which this
|
||||||
octet is located until the block is freed or relocated. Freeing
|
octet is located until the block is freed or relocated. Freeing
|
||||||
of an unnamed block B occurs when a new value is assigned to B or
|
of an unnamed block B occurs when a new value is assigned to B or
|
||||||
when B ceases to exist; a named block B is freed by blkfree(B().
|
when B ceases to exist; a named block B is freed by blkfree(B().
|
||||||
@@ -96,7 +96,7 @@ DESCRIPTION
|
|||||||
> define f(a) = 27 + a;
|
> define f(a) = 27 + a;
|
||||||
|
|
||||||
the three occurrences of 27 have the same address which may be displayed
|
the three occurrences of 27 have the same address which may be displayed
|
||||||
by any of &27, &*x, &*y and &f(0). If x and y are assigned
|
by any of &27, &*x, &*y and &f(0). If x and y are assigned
|
||||||
other values and f is redefined or undefined and the 27 has not been
|
other values and f is redefined or undefined and the 27 has not been
|
||||||
stored elsewhere (e.g. as the "old value" or in another function
|
stored elsewhere (e.g. as the "old value" or in another function
|
||||||
definition or as an element in an association), the address assigned at
|
definition or as an element in an association), the address assigned at
|
||||||
@@ -105,7 +105,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
When a function returns a number value, that number value is usually
|
When a function returns a number value, that number value is usually
|
||||||
placed at a newly allocated address, even if an equal number is stored
|
placed at a newly allocated address, even if an equal number is stored
|
||||||
elsewhere. For example calls to f(a), as defined above, with the same
|
elsewhere. For example calls to f(a), as defined above, with the same
|
||||||
non-zero value for a will be assigned to different addresses as can be
|
non-zero value for a will be assigned to different addresses as can be
|
||||||
seen from printing &*A, &*B, &*C after
|
seen from printing &*A, &*B, &*C after
|
||||||
|
|
||||||
|
@@ -84,7 +84,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
Complex x:
|
Complex x:
|
||||||
|
|
||||||
Returns appr(re(x), y, z) + appr(im(x), y, z) * 1i
|
Returns appr(re(x), y, z) + appr(im(x), y, z) * 1i
|
||||||
|
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
If appr(x,y,z) != x, then abs(x - appr(x,y,z)) < abs(y).
|
If appr(x,y,z) != x, then abs(x - appr(x,y,z)) < abs(y).
|
||||||
|
@@ -16,7 +16,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
asech(x) is the real number v for which sech(v) = x. It is given by
|
asech(x) is the real number v for which sech(v) = x. It is given by
|
||||||
|
|
||||||
asech(x) = ln((1 + sqrt(1 - x^2))/x)
|
asech(x) = ln((1 + sqrt(1 - x^2))/x)
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> print asech(.5,1e-5), asech(.5,1e-10), asech(.5,1e-15), asech(.5,1e-20)
|
> print asech(.5,1e-5), asech(.5,1e-10), asech(.5,1e-15), asech(.5,1e-20)
|
||||||
|
@@ -16,7 +16,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
asinh(x) is the real number v for which sinh(v) = x. It is given by
|
asinh(x) is the real number v for which sinh(v) = x. It is given by
|
||||||
|
|
||||||
asinh(x) = ln(x + sqrt(1 + x^2))
|
asinh(x) = ln(x + sqrt(1 + x^2))
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> print asinh(2, 1e-5), asinh(2, 1e-10), asinh(2, 1e-15), asinh(2, 1e-20)
|
> print asinh(2, 1e-5), asinh(2, 1e-10), asinh(2, 1e-15), asinh(2, 1e-20)
|
||||||
|
@@ -44,7 +44,7 @@ DESCRIPTION
|
|||||||
In simple assignments, = associates from right to left so that, for
|
In simple assignments, = associates from right to left so that, for
|
||||||
example,
|
example,
|
||||||
|
|
||||||
a = b = c
|
a = b = c
|
||||||
|
|
||||||
has the effect of a = (b = c) and results in assigning the value of c
|
has the effect of a = (b = c) and results in assigning the value of c
|
||||||
to both a and b. The expression (a = b) = c is acceptable, but has the
|
to both a and b. The expression (a = b) = c is acceptable, but has the
|
||||||
@@ -66,7 +66,7 @@ DESCRIPTION
|
|||||||
that of A[0] = A[1].
|
that of A[0] = A[1].
|
||||||
|
|
||||||
If, in execution of a = b, a is changed by the evaluation of b, the
|
If, in execution of a = b, a is changed by the evaluation of b, the
|
||||||
value of b may be stored in an unintended or inaccessible location. For
|
value of b may be stored in an unintended or inaccessible location. For
|
||||||
example,
|
example,
|
||||||
mat A[2]= {1,2};
|
mat A[2]= {1,2};
|
||||||
A[0] = (A = 3);
|
A[0] = (A = 3);
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
assignments of the forms
|
assignments of the forms
|
||||||
|
|
||||||
A[a_1] = v_1
|
A[a_1] = v_1
|
||||||
A[a_1, a_2] = v_2
|
A[a_1, a_2] = v_2
|
||||||
A[a_1, a_2, a_3] = v_3
|
A[a_1, a_2, a_3] = v_3
|
||||||
A[a_1, a_2, a_3, a_4] = v_4
|
A[a_1, a_2, a_3, a_4] = v_4
|
||||||
|
|
||||||
@@ -53,7 +53,7 @@ DESCRIPTION
|
|||||||
a sequential scan through the elements difficult.
|
a sequential scan through the elements difficult.
|
||||||
|
|
||||||
The search and rsearch functions can search for an element in an
|
The search and rsearch functions can search for an element in an
|
||||||
association which has the specified value. They return the index
|
association which has the specified value. They return the index
|
||||||
of the found element, or a NULL value if the value was not found.
|
of the found element, or a NULL value if the value was not found.
|
||||||
|
|
||||||
Associations can be copied by an assignment, and can be compared
|
Associations can be copied by an assignment, and can be compared
|
||||||
|
49
help/base
49
help/base
@@ -18,19 +18,46 @@ DESCRIPTION
|
|||||||
|
|
||||||
The following convention is used to declare modes:
|
The following convention is used to declare modes:
|
||||||
|
|
||||||
base config
|
base equivalent
|
||||||
value string
|
config("mode")'s
|
||||||
|
|
||||||
2 "binary" binary fractions
|
2 "binary" base 2 fractions
|
||||||
8 "octal" octal fractions
|
"bin"
|
||||||
10 "real" decimal floating point
|
|
||||||
16 "hex" hexadecimal fractions
|
|
||||||
-10 "int" decimal integer
|
|
||||||
1/3 "frac" decimal fractions
|
|
||||||
1e20 "exp" decimal exponential
|
|
||||||
|
|
||||||
For convenience, any non-integer value is assumed to mean "frac",
|
8 "octal" base 8 fractions
|
||||||
and any integer >= 2^64 is assumed to mean "exp".
|
"oct"
|
||||||
|
|
||||||
|
10 "real" base 10 floating point
|
||||||
|
"float"
|
||||||
|
"default"
|
||||||
|
|
||||||
|
-10 "integer" base 10 integers
|
||||||
|
"int"
|
||||||
|
|
||||||
|
16 "hexadecimal" base 16 fractions
|
||||||
|
"hex"
|
||||||
|
|
||||||
|
1/3 "fraction" base 10 fractions
|
||||||
|
"frac"
|
||||||
|
|
||||||
|
1e20 "scientific" base 10 scientific notation
|
||||||
|
"sci"
|
||||||
|
"exp"
|
||||||
|
|
||||||
|
For convenience, any non-integer value is assumed to mean base 10
|
||||||
|
fractions and any integer >= 2^64 is assumed to mean base 10
|
||||||
|
scientific notation.
|
||||||
|
|
||||||
|
These base() calls have the same meaning as config("mode", "fraction"):
|
||||||
|
|
||||||
|
base(1/3) base(0.1415) base(16/37)
|
||||||
|
|
||||||
|
These base() calls have the same meaning as config("mode", "scientific"):
|
||||||
|
|
||||||
|
base(1e20) base(2^64) base(2^8191-1)
|
||||||
|
|
||||||
|
However the base() function will only return one of the base values
|
||||||
|
lised in the table above.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> base()
|
> base()
|
||||||
|
2
help/bit
2
help/bit
@@ -11,7 +11,7 @@ TYPES
|
|||||||
return int
|
return int
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
Determine if the binary bit y is set in x. If:
|
Determine if the binary bit y is set in x. If:
|
||||||
|
|
||||||
x
|
x
|
||||||
int(---) mod 2 == 1
|
int(---) mod 2 == 1
|
||||||
|
10
help/blk
10
help/blk
@@ -26,7 +26,7 @@ DESCRIPTION
|
|||||||
... , B[len-1], these all initially having zero value.
|
... , B[len-1], these all initially having zero value.
|
||||||
|
|
||||||
The octets B[i] for i >= len always have zero value. If B[i] with
|
The octets B[i] for i >= len always have zero value. If B[i] with
|
||||||
some i >= len is referenced, len is increased by 1. For example:
|
some i >= len is referenced, len is increased by 1. For example:
|
||||||
|
|
||||||
B[i] = x
|
B[i] = x
|
||||||
|
|
||||||
@@ -70,11 +70,11 @@ DESCRIPTION
|
|||||||
If a block value B created by B = blk(len, chunk) is assigned to
|
If a block value B created by B = blk(len, chunk) is assigned to
|
||||||
another variable by C = B, a new block of the same structure as B
|
another variable by C = B, a new block of the same structure as B
|
||||||
is created to become the value of C, and the octets in B are copied
|
is created to become the value of C, and the octets in B are copied
|
||||||
to this new block. A block with possibly different length or
|
to this new block. A block with possibly different length or
|
||||||
chunksize is created by C = blk(B, newlen, newchunk), only the first
|
chunksize is created by C = blk(B, newlen, newchunk), only the first
|
||||||
min(len, newlen) octets being copied from B; later octets are
|
min(len, newlen) octets being copied from B; later octets are
|
||||||
assigned zero value. If omitted, newlen and newchunk default to
|
assigned zero value. If omitted, newlen and newchunk default to
|
||||||
the current datalen and chunk-size for B. The curent datalen,
|
the current datalen and chunk-size for B. The current datalen,
|
||||||
chunksize and number of allocated octets for B may be changed by:
|
chunksize and number of allocated octets for B may be changed by:
|
||||||
|
|
||||||
B = blk(B, newlen, newchunk).
|
B = blk(B, newlen, newchunk).
|
||||||
@@ -120,14 +120,14 @@ DESCRIPTION
|
|||||||
last two avoid printing of the new value for A.
|
last two avoid printing of the new value for A.
|
||||||
|
|
||||||
Named blocks are assigned index numbers 0, 1, 2, ..., in the order
|
Named blocks are assigned index numbers 0, 1, 2, ..., in the order
|
||||||
of their creation. The block with index id is returned by blocks(id).
|
of their creation. The block with index id is returned by blocks(id).
|
||||||
With no argument, blocks() returns the number of current unfreed
|
With no argument, blocks() returns the number of current unfreed
|
||||||
named blocks. A named block may be used
|
named blocks. A named block may be used
|
||||||
|
|
||||||
The memory allocated to a named block is freed by the blkfree()
|
The memory allocated to a named block is freed by the blkfree()
|
||||||
function with argument the named block, its name, or its id number.
|
function with argument the named block, its name, or its id number.
|
||||||
The block remains in existence but with a null data pointer,
|
The block remains in existence but with a null data pointer,
|
||||||
its length and size being reduced to zero. A new block of memory
|
its length and size being reduced to zero. A new block of memory
|
||||||
may be allocated to it, with possibly new length and chunksize by:
|
may be allocated to it, with possibly new length and chunksize by:
|
||||||
|
|
||||||
blk(val [, len, chunk])
|
blk(val [, len, chunk])
|
||||||
|
@@ -90,7 +90,7 @@ DESCRIPTION
|
|||||||
so that num can be at most size(B) - ssi.
|
so that num can be at most size(B) - ssi.
|
||||||
|
|
||||||
For copying to a block B (named or unnamed), reallocation will be
|
For copying to a block B (named or unnamed), reallocation will be
|
||||||
required if dsi + num > sizeof(B). (This will not be permitted if
|
required if dsi + num > sizeof(B). (This will not be permitted if
|
||||||
protect(B) has bit 4 set.)
|
protect(B) has bit 4 set.)
|
||||||
|
|
||||||
For copying from a file stream fs, num can be at most size(fs) - ssi.
|
For copying from a file stream fs, num can be at most size(fs) - ssi.
|
||||||
|
12
help/blkfree
12
help/blkfree
@@ -12,7 +12,7 @@ TYPES
|
|||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
If val is a named block, or the name of a named block, or the
|
If val is a named block, or the name of a named block, or the
|
||||||
identifying index for a named block, blkfree(val) frees the
|
identifying index for a named block, blkfree(val) frees the
|
||||||
memory block allocated to this named block. The block remains
|
memory block allocated to this named block. The block remains
|
||||||
in existence with the same name, identifying index, and chunksize,
|
in existence with the same name, identifying index, and chunksize,
|
||||||
but its size and maxsize becomes zero and the pointer for the start
|
but its size and maxsize becomes zero and the pointer for the start
|
||||||
of its data block null.
|
of its data block null.
|
||||||
@@ -26,16 +26,16 @@ EXAMPLE
|
|||||||
> B1 = blk("foo")
|
> B1 = blk("foo")
|
||||||
> B2 = blk("Second block")
|
> B2 = blk("Second block")
|
||||||
show blocks
|
show blocks
|
||||||
id name
|
id name
|
||||||
---- -----
|
---- -----
|
||||||
0 foo
|
0 foo
|
||||||
1 Second block
|
1 Second block
|
||||||
|
|
||||||
> blkfree(B1)
|
> blkfree(B1)
|
||||||
> show blocks
|
> show blocks
|
||||||
id name
|
id name
|
||||||
---- -----
|
---- -----
|
||||||
1 Second block
|
1 Second block
|
||||||
|
|
||||||
> B1
|
> B1
|
||||||
block 0: foo
|
block 0: foo
|
||||||
|
@@ -12,7 +12,7 @@ TYPES
|
|||||||
Otherwise, if x is an object of type tt, or if x is not an object or
|
Otherwise, if x is an object of type tt, or if x is not an object or
|
||||||
number but y is an object of type tt, and the function tt_bround has
|
number but y is an object of type tt, and the function tt_bround has
|
||||||
to be defined; the types for x, plcs, rnd, and the returned value,
|
to be defined; the types for x, plcs, rnd, and the returned value,
|
||||||
if any, are as required for specified in tt_bround. For the object
|
if any, are as required for specified in tt_bround. For the object
|
||||||
case, plcs and rnd default to the null value.
|
case, plcs and rnd default to the null value.
|
||||||
|
|
||||||
For other cases:
|
For other cases:
|
||||||
@@ -31,7 +31,7 @@ DESCRIPTION
|
|||||||
If the number of binary places is n and eps = 10^-n, the
|
If the number of binary places is n and eps = 10^-n, the
|
||||||
result is the same as for appr(x, eps, rnd). This will be
|
result is the same as for appr(x, eps, rnd). This will be
|
||||||
exactly x if x is a multiple of eps; otherwise rounding occurs
|
exactly x if x is a multiple of eps; otherwise rounding occurs
|
||||||
to one of the nearest multiples of eps on either side of x. Which
|
to one of the nearest multiples of eps on either side of x. Which
|
||||||
of these multiples is returned is determined by z = rnd & 31, i.e.
|
of these multiples is returned is determined by z = rnd & 31, i.e.
|
||||||
the five low order bits of rnd, as follows:
|
the five low order bits of rnd, as follows:
|
||||||
|
|
||||||
|
@@ -4,25 +4,25 @@
|
|||||||
to be set or read. If only one argument is given, then the current
|
to be set or read. If only one argument is given, then the current
|
||||||
value of the named parameter is returned. If two arguments are given,
|
value of the named parameter is returned. If two arguments are given,
|
||||||
then the named parameter is set to the value of the second argument,
|
then the named parameter is set to the value of the second argument,
|
||||||
and the old value of the parameter is returned. Therefore you can
|
and the old value of the parameter is returned. Therefore you can
|
||||||
change a parameter and restore its old value later. The possible
|
change a parameter and restore its old value later. The possible
|
||||||
parameters are explained in the next section.
|
parameters are explained in the next section.
|
||||||
|
|
||||||
The scale function multiplies or divides a number by a power of 2.
|
The scale function multiplies or divides a number by a power of 2.
|
||||||
This is used for fractional calculations, unlike the << and >>
|
This is used for fractional calculations, unlike the << and >>
|
||||||
operators, which are only defined for integers. For example,
|
operators, which are only defined for integers. For example,
|
||||||
scale(6, -3) is 3/4.
|
scale(6, -3) is 3/4.
|
||||||
|
|
||||||
The quomod function is used to obtain both the quotient and remainder
|
The quomod function is used to obtain both the quotient and remainder
|
||||||
of a division in one operation. The first two arguments a and b are
|
of a division in one operation. The first two arguments a and b are
|
||||||
the numbers to be divided. The last two arguments c and d are two
|
the numbers to be divided. The last two arguments c and d are two
|
||||||
variables which will be assigned the quotient and remainder. For
|
variables which will be assigned the quotient and remainder. For
|
||||||
nonnegative arguments, the results are equivalent to computing a//b
|
nonnegative arguments, the results are equivalent to computing a//b
|
||||||
and a%b. If a is negative and the remainder is nonzero, then the
|
and a%b. If a is negative and the remainder is nonzero, then the
|
||||||
quotient will be one less than a//b. This makes the following three
|
quotient will be one less than a//b. This makes the following three
|
||||||
properties always hold: The quotient c is always an integer. The
|
properties always hold: The quotient c is always an integer. The
|
||||||
remainder d is always 0 <= d < b. The equation a = b * c + d always
|
remainder d is always 0 <= d < b. The equation a = b * c + d always
|
||||||
holds. This function returns 0 if there is no remainder, and 1 if
|
holds. This function returns 0 if there is no remainder, and 1 if
|
||||||
there is a remainder. For examples, quomod(10, 3, x, y) sets x to 3,
|
there is a remainder. For examples, quomod(10, 3, x, y) sets x to 3,
|
||||||
y to 1, and returns the value 1, and quomod(-4, 3.14159, x, y) sets x
|
y to 1, and returns the value 1, and quomod(-4, 3.14159, x, y) sets x
|
||||||
to -2, y to 2.28318, and returns the value 1.
|
to -2, y to 2.28318, and returns the value 1.
|
||||||
@@ -37,8 +37,8 @@
|
|||||||
|
|
||||||
The digit and bit functions return individual digits of a number,
|
The digit and bit functions return individual digits of a number,
|
||||||
either in base 10 or in base 2, where the lowest digit of a number
|
either in base 10 or in base 2, where the lowest digit of a number
|
||||||
is at digit position 0. For example, digit(5678, 3) is 5, and
|
is at digit position 0. For example, digit(5678, 3) is 5, and
|
||||||
bit(0b1000100, 2) is 1. Negative digit positions indicate places
|
bit(0b1000100, 2) is 1. Negative digit positions indicate places
|
||||||
to the right of the decimal or binary point, so that for example,
|
to the right of the decimal or binary point, so that for example,
|
||||||
digit(3.456, -1) is 4.
|
digit(3.456, -1) is 4.
|
||||||
|
|
||||||
@@ -139,11 +139,11 @@
|
|||||||
|
|
||||||
The functions rcin, rcmul, rcout, rcpow, and rcsq are used to
|
The functions rcin, rcmul, rcout, rcpow, and rcsq are used to
|
||||||
perform modular arithmetic calculations for large odd numbers
|
perform modular arithmetic calculations for large odd numbers
|
||||||
faster than the usual methods. To do this, you first use the
|
faster than the usual methods. To do this, you first use the
|
||||||
rcin function to convert all input values into numbers which are
|
rcin function to convert all input values into numbers which are
|
||||||
in a format called REDC format. Then you use rcmul, rcsq, and
|
in a format called REDC format. Then you use rcmul, rcsq, and
|
||||||
rcpow to multiply such numbers together to produce results also
|
rcpow to multiply such numbers together to produce results also
|
||||||
in REDC format. Finally, you use rcout to convert a number in
|
in REDC format. Finally, you use rcout to convert a number in
|
||||||
REDC format back to a normal number. The addition, subtraction,
|
REDC format back to a normal number. The addition, subtraction,
|
||||||
negation, and equality comparison between REDC numbers are done
|
negation, and equality comparison between REDC numbers are done
|
||||||
using the normal modular methods. For example, to calculate the
|
using the normal modular methods. For example, to calculate the
|
||||||
@@ -185,8 +185,8 @@
|
|||||||
|
|
||||||
The following convention is used to declare modes:
|
The following convention is used to declare modes:
|
||||||
|
|
||||||
base config
|
base config
|
||||||
value string
|
value string
|
||||||
|
|
||||||
2 "binary" binary fractions
|
2 "binary" binary fractions
|
||||||
8 "octal" octal fractions
|
8 "octal" octal fractions
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
Builtin functions
|
Builtin functions
|
||||||
|
|
||||||
There is a large number of built-in functions. Many of the
|
There is a large number of built-in functions. Many of the
|
||||||
functions work on several types of arguments, whereas some only
|
functions work on several types of arguments, whereas some only
|
||||||
work for the correct types (e.g., numbers or strings). In the
|
work for the correct types (e.g., numbers or strings). In the
|
||||||
following description, this is indicated by whether or not the
|
following description, this is indicated by whether or not the
|
||||||
description refers to values or numbers. This display is generated
|
description refers to values or numbers. This display is generated
|
||||||
by the 'show builtin' command.
|
by the 'show builtin' command.
|
||||||
|
@@ -10,7 +10,7 @@ TYPES
|
|||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This function returns the calculation level at which it is called.
|
This function returns the calculation level at which it is called.
|
||||||
When a command is being read from a terminal or from a file,
|
When a command is being read from a terminal or from a file,
|
||||||
calc is at calculation level zero. The level is increased
|
calc is at calculation level zero. The level is increased
|
||||||
by 1 each time calculation starts of a user-defined function
|
by 1 each time calculation starts of a user-defined function
|
||||||
or of eval(S) for some expression S which evaluates to a string. It
|
or of eval(S) for some expression S which evaluates to a string. It
|
||||||
decreases to zero if an error occurs or a quit or abort statement
|
decreases to zero if an error occurs or a quit or abort statement
|
||||||
|
@@ -6,7 +6,7 @@ SYNOPSIS
|
|||||||
|
|
||||||
TYPES
|
TYPES
|
||||||
x real
|
x real
|
||||||
eps real with abs(eps) < 1, defaults to epsilon()
|
eps real with abs(eps) < 1, defaults to epsilon()
|
||||||
n real with n >= 1
|
n real with n >= 1
|
||||||
rnd integer, defaults to config("cfappr")
|
rnd integer, defaults to config("cfappr")
|
||||||
|
|
||||||
@@ -21,7 +21,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
If n >= 1 and den(x) > n, cfappr(x, n) returns the nearest above,
|
If n >= 1 and den(x) > n, cfappr(x, n) returns the nearest above,
|
||||||
nearest below, or nearest, approximation to x with denominator less
|
nearest below, or nearest, approximation to x with denominator less
|
||||||
than or equal to n. If den(x) <= n, cfappr(x,n) returns x.
|
than or equal to n. If den(x) <= n, cfappr(x,n) returns x.
|
||||||
|
|
||||||
In either case when the result v is not x, how v relates to x is
|
In either case when the result v is not x, how v relates to x is
|
||||||
determined by bits 0, 1, 2 and 4 of the argument rnd in the same way as
|
determined by bits 0, 1, 2 and 4 of the argument rnd in the same way as
|
||||||
|
@@ -30,7 +30,7 @@ DESCRIPTION
|
|||||||
This corresponds to the use of rnd for functions like round(x, n, rnd).
|
This corresponds to the use of rnd for functions like round(x, n, rnd).
|
||||||
|
|
||||||
If bit 3 or 4 of rnd is set, the lower order bits are ignored; bit 3
|
If bit 3 or 4 of rnd is set, the lower order bits are ignored; bit 3
|
||||||
is ignored if bit 4 is set. Thusi, for rnd > 3, it sufficient to
|
is ignored if bit 4 is set. Thusi, for rnd > 3, it sufficient to
|
||||||
consider the two cases rnd = 8 and rnd = 16.
|
consider the two cases rnd = 8 and rnd = 16.
|
||||||
|
|
||||||
If den(x) > 2, cfsim(x, 8) returns the value of the penultimate simple
|
If den(x) > 2, cfsim(x, 8) returns the value of the penultimate simple
|
||||||
@@ -55,7 +55,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
rnd integer x half-integer x den(x) > 2
|
rnd integer x half-integer x den(x) > 2
|
||||||
|
|
||||||
8 0 x - sgn(x)/2 approximant
|
8 0 x - sgn(x)/2 approximant
|
||||||
16 x - sgn(x) x + sgn(x)/2 nearest
|
16 x - sgn(x) x + sgn(x)/2 nearest
|
||||||
|
|
||||||
From either cfsim(x, 0) and cfsim(x, 1), the other is easily
|
From either cfsim(x, 0) and cfsim(x, 1), the other is easily
|
||||||
@@ -72,7 +72,7 @@ DESCRIPTION
|
|||||||
Iteration of cfsim(x,8) until an integer is obtained gives a sequence of
|
Iteration of cfsim(x,8) until an integer is obtained gives a sequence of
|
||||||
"good" approximations to x with decreasing denominators and
|
"good" approximations to x with decreasing denominators and
|
||||||
correspondingly decreasing accuracy; each denominator is less than half
|
correspondingly decreasing accuracy; each denominator is less than half
|
||||||
the preceding denominator. (Unlike the "forward" sequence of
|
the preceding denominator. (Unlike the "forward" sequence of
|
||||||
continued-fraction approximants these are not necessarily alternately
|
continued-fraction approximants these are not necessarily alternately
|
||||||
greater than and less than x.)
|
greater than and less than x.)
|
||||||
|
|
||||||
|
4
help/cmp
4
help/cmp
@@ -17,7 +17,7 @@ TYPES
|
|||||||
|
|
||||||
return if x and y are both real: -1, 0, or 1
|
return if x and y are both real: -1, 0, or 1
|
||||||
if x and y are both numbers but not both real:
|
if x and y are both numbers but not both real:
|
||||||
-1, 0, 1, -1+1i, 1i, 1+1i, -1-1i, -1i, or 1-1i
|
-1, 0, 1, -1+1i, 1i, 1+1i, -1-1i, -1i, or 1-1i
|
||||||
if x and y are both strings: -1, 0, or 1
|
if x and y are both strings: -1, 0, or 1
|
||||||
all other cases: the null value
|
all other cases: the null value
|
||||||
|
|
||||||
@@ -47,7 +47,7 @@ DESCRIPTION
|
|||||||
obj point {x,y};
|
obj point {x,y};
|
||||||
|
|
||||||
if points with real components are to be partially ordered by their
|
if points with real components are to be partially ordered by their
|
||||||
euclidean distance from the origin, an appropriate point_rel
|
euclidean distance from the origin, an appropriate point_rel
|
||||||
function may be that given by
|
function may be that given by
|
||||||
|
|
||||||
define point_rel(a,b) = sgn(a.x^2 + a.y^2 - b.x^2 - b.y^2);
|
define point_rel(a,b) = sgn(a.x^2 + a.y^2 - b.x^2 - b.y^2);
|
||||||
|
14
help/command
14
help/command
@@ -3,7 +3,7 @@ Command sequence
|
|||||||
This is a sequence of any the following command formats, where
|
This is a sequence of any the following command formats, where
|
||||||
each command is terminated by a semicolon or newline. Long command
|
each command is terminated by a semicolon or newline. Long command
|
||||||
lines can be extended by using a back-slash followed by a newline
|
lines can be extended by using a back-slash followed by a newline
|
||||||
character. When this is done, the prompt shows a double angle
|
character. When this is done, the prompt shows a double angle
|
||||||
bracket to indicate that the line is still in progress. Certain
|
bracket to indicate that the line is still in progress. Certain
|
||||||
cases will automatically prompt for more input in a similar manner,
|
cases will automatically prompt for more input in a similar manner,
|
||||||
even without the back-slash. The most common case for this is when
|
even without the back-slash. The most common case for this is when
|
||||||
@@ -25,7 +25,7 @@ Command sequence
|
|||||||
The second form defines a simple function which calculates
|
The second form defines a simple function which calculates
|
||||||
the specified expression value from the specified parameters.
|
the specified expression value from the specified parameters.
|
||||||
The expression cannot be a statement. However, the comma
|
The expression cannot be a statement. However, the comma
|
||||||
and question mark operators can be useful. Examples of
|
and question mark operators can be useful. Examples of
|
||||||
simple functions are:
|
simple functions are:
|
||||||
|
|
||||||
define sumcubes(a, b) = a^3 + b^3
|
define sumcubes(a, b) = a^3 + b^3
|
||||||
@@ -45,7 +45,7 @@ Command sequence
|
|||||||
read filename
|
read filename
|
||||||
read -once filename
|
read -once filename
|
||||||
This reads definitions from the specified filename.
|
This reads definitions from the specified filename.
|
||||||
The name can be quoted if desired. The calculator
|
The name can be quoted if desired. The calculator
|
||||||
uses the CALCPATH environment variable to search
|
uses the CALCPATH environment variable to search
|
||||||
through the specified directories for the filename,
|
through the specified directories for the filename,
|
||||||
similarly to the use of the PATH environment variable.
|
similarly to the use of the PATH environment variable.
|
||||||
@@ -54,7 +54,7 @@ Command sequence
|
|||||||
directory followed by a general calc library directory).
|
directory followed by a general calc library directory).
|
||||||
The ".cal" extension is defaulted for input files, so
|
The ".cal" extension is defaulted for input files, so
|
||||||
that if "filename" is not found, then "filename.cal" is
|
that if "filename" is not found, then "filename.cal" is
|
||||||
then searched for. The contents of the filename are
|
then searched for. The contents of the filename are
|
||||||
command sequences which can consist of expressions to
|
command sequences which can consist of expressions to
|
||||||
evaluate or functions to define, just like at the top
|
evaluate or functions to define, just like at the top
|
||||||
level command level.
|
level command level.
|
||||||
@@ -82,7 +82,7 @@ Command sequence
|
|||||||
later read in order to recreate the variable values.
|
later read in order to recreate the variable values.
|
||||||
For speed reasons, values are written as hex fractions.
|
For speed reasons, values are written as hex fractions.
|
||||||
This command currently only saves simple types, so that
|
This command currently only saves simple types, so that
|
||||||
matrices, lists, and objects are not saved. Function
|
matrices, lists, and objects are not saved. Function
|
||||||
definitions are also not saved.
|
definitions are also not saved.
|
||||||
|
|
||||||
If the -m mode disallows opening of files for writing,
|
If the -m mode disallows opening of files for writing,
|
||||||
@@ -247,7 +247,7 @@ Command sequence
|
|||||||
> <==== calc interactive prompt
|
> <==== calc interactive prompt
|
||||||
|
|
||||||
because the '-i' calc causes ABORT to drop into an
|
because the '-i' calc causes ABORT to drop into an
|
||||||
interactive prompt. However typing a QUIT or ABORT
|
interactive prompt. However typing a QUIT or ABORT
|
||||||
at the interactive prompt level will always calc to exit,
|
at the interactive prompt level will always calc to exit,
|
||||||
even when calc is invoked with '-i'.
|
even when calc is invoked with '-i'.
|
||||||
|
|
||||||
@@ -304,5 +304,5 @@ Command sequence
|
|||||||
|
|
||||||
Also see the help topic:
|
Also see the help topic:
|
||||||
|
|
||||||
statement flow control and declaration statements
|
statement flow control and declaration statements
|
||||||
usage how to invoke the calc command and calc -options
|
usage how to invoke the calc command and calc -options
|
||||||
|
271
help/config
271
help/config
@@ -1,10 +1,10 @@
|
|||||||
Configuration parameters
|
Configuration parameters
|
||||||
|
|
||||||
Configuration parameters affect how the calculator performs certain
|
Configuration parameters affect how the calculator performs certain
|
||||||
operations. Among features that are controlled by these parameters
|
operations. Among features that are controlled by these parameters
|
||||||
are the accuracy of some calculations, the displayed format of results,
|
are the accuracy of some calculations, the displayed format of results,
|
||||||
the choice from possible alternative algorithms, and whether or not
|
the choice from possible alternative algorithms, and whether or not
|
||||||
debugging information is displayed. The parameters are
|
debugging information is displayed. The parameters are
|
||||||
read or set using the "config" built-in function; they remain in effect
|
read or set using the "config" built-in function; they remain in effect
|
||||||
until their values are changed by a config or equivalent instruction.
|
until their values are changed by a config or equivalent instruction.
|
||||||
The following parameters can be specified:
|
The following parameters can be specified:
|
||||||
@@ -44,7 +44,7 @@ Configuration parameters
|
|||||||
"lib_debug" controls library script debug information
|
"lib_debug" controls library script debug information
|
||||||
"user_debug" for user defined debug information
|
"user_debug" for user defined debug information
|
||||||
"verbose_quit" TRUE=>print message on empty quit or abort
|
"verbose_quit" TRUE=>print message on empty quit or abort
|
||||||
|
"ctrl_d" The interactive meaning of ^D (Control D)
|
||||||
|
|
||||||
The "all" config value allows one to save/restore the configuration
|
The "all" config value allows one to save/restore the configuration
|
||||||
set of values. The return of:
|
set of values. The return of:
|
||||||
@@ -65,7 +65,7 @@ Configuration parameters
|
|||||||
It allows functions to control their configuration without impacting
|
It allows functions to control their configuration without impacting
|
||||||
the calling function.
|
the calling function.
|
||||||
|
|
||||||
There are two configuration state aliases that may be set. To
|
There are two configuration state aliases that may be set. To
|
||||||
set the backward compatible standard configuration:
|
set the backward compatible standard configuration:
|
||||||
|
|
||||||
config("all", "oldstd")
|
config("all", "oldstd")
|
||||||
@@ -82,6 +82,43 @@ Configuration parameters
|
|||||||
startup files; newstd may also be established by invoking calc
|
startup files; newstd may also be established by invoking calc
|
||||||
with the flag -n.
|
with the flag -n.
|
||||||
|
|
||||||
|
The following are synonyms for true:
|
||||||
|
|
||||||
|
"on"
|
||||||
|
"true"
|
||||||
|
"t"
|
||||||
|
"yes"
|
||||||
|
"y"
|
||||||
|
"set"
|
||||||
|
"1"
|
||||||
|
any non-zero number
|
||||||
|
|
||||||
|
The following are synonyms for false:
|
||||||
|
|
||||||
|
"off"
|
||||||
|
"false"
|
||||||
|
"f"
|
||||||
|
"no"
|
||||||
|
"n"
|
||||||
|
"unset"
|
||||||
|
"0"
|
||||||
|
the number zero (0)
|
||||||
|
|
||||||
|
Examples of setting some parameters are:
|
||||||
|
|
||||||
|
config("mode", "exp"); exponential output
|
||||||
|
config("display", 50); 50 digits of output
|
||||||
|
epsilon(epsilon() / 8); 3 bits more accuracy
|
||||||
|
config("tilde", 0) disable roundoff tilde printing
|
||||||
|
config("tab", "off") disable leading tab printing
|
||||||
|
|
||||||
|
|
||||||
|
Detailed config descriptions
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("trace", bitflag)
|
||||||
|
|
||||||
When nonzero, the "trace" parameter activates one or more features
|
When nonzero, the "trace" parameter activates one or more features
|
||||||
that may be useful for debugging. These features correspond to
|
that may be useful for debugging. These features correspond to
|
||||||
powers of 2 which contribute additively to config("trace"):
|
powers of 2 which contribute additively to config("trace"):
|
||||||
@@ -101,22 +138,31 @@ Configuration parameters
|
|||||||
|
|
||||||
See also lib_debug, calc_debug and user_debug below for more debug levels.
|
See also lib_debug, calc_debug and user_debug below for more debug levels.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("display", int)
|
||||||
|
|
||||||
The "display" parameter specifies the maximum number of digits after
|
The "display" parameter specifies the maximum number of digits after
|
||||||
the decimal point to be printed in real or exponential mode in
|
the decimal point to be printed in real or exponential mode in
|
||||||
normal unformatted printing (print, strprint, fprint) or in
|
normal unformatted printing (print, strprint, fprint) or in
|
||||||
formatted printing (printf, strprintf, fprintf) when precision is not
|
formatted printing (printf, strprintf, fprintf) when precision is not
|
||||||
specified. The initial value for oldstd is 20, for newstd 10.
|
specified. The initial value for oldstd is 20, for newstd 10.
|
||||||
The parameter may be changed to the value d by either
|
The parameter may be changed to the value d by either
|
||||||
config("display", d) or by display (d). This parameter does not change
|
config("display", d) or by display (d). This parameter does not change
|
||||||
the stored value of a number. Where rounding is necessary to
|
the stored value of a number. Where rounding is necessary to
|
||||||
display up to d decimal places, the type of rounding to be used is
|
display up to d decimal places, the type of rounding to be used is
|
||||||
controlled by config("outround").
|
controlled by config("outround").
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("epsilon", real)
|
||||||
|
epsilon(real)
|
||||||
|
|
||||||
The "epsilon" parameter specifies the default accuracy for the
|
The "epsilon" parameter specifies the default accuracy for the
|
||||||
calculation of functions for which exact values are not possible or
|
calculation of functions for which exact values are not possible or
|
||||||
not desired. For most functions, the
|
not desired. For most functions, the
|
||||||
|
|
||||||
remainder = exact value - calculated value
|
remainder = exact value - calculated value
|
||||||
|
|
||||||
has absolute value less than epsilon, but, except when the sign of
|
has absolute value less than epsilon, but, except when the sign of
|
||||||
the remainder is controlled by an appropriate parameter, the
|
the remainder is controlled by an appropriate parameter, the
|
||||||
@@ -130,32 +176,68 @@ Configuration parameters
|
|||||||
For the transcendental functions and the functions sqrt() and
|
For the transcendental functions and the functions sqrt() and
|
||||||
appr(), the calculated value is always a multiple of epsilon.
|
appr(), the calculated value is always a multiple of epsilon.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("mode", "mode_string")
|
||||||
|
|
||||||
The "mode" parameter is a string specifying the mode for printing of
|
The "mode" parameter is a string specifying the mode for printing of
|
||||||
numbers by the unformatted print functions, and the default
|
numbers by the unformatted print functions, and the default
|
||||||
("%d" specifier) for formatted print functions. The initial mode
|
("%d" specifier) for formatted print functions. The initial mode
|
||||||
is "real". The available modes are:
|
is "real". The available modes are:
|
||||||
|
|
||||||
"frac" decimal fractions
|
config("mode") meaning equivalent
|
||||||
"int" decimal integer
|
string base() call
|
||||||
"real" decimal floating point
|
|
||||||
"exp" decimal exponential
|
"binary" base 2 fractions base(2)
|
||||||
"hex" hex fractions
|
"bin"
|
||||||
"oct" octal fractions
|
|
||||||
"bin" binary fractions
|
"octal" base 8 fractions base(8)
|
||||||
|
"oct"
|
||||||
|
|
||||||
|
"real" base 10 floating point base(10)
|
||||||
|
"float"
|
||||||
|
"default"
|
||||||
|
|
||||||
|
"integer" base 10 integer base(-10)
|
||||||
|
"int"
|
||||||
|
|
||||||
|
"hexadecimal" base 16 fractions base(16)
|
||||||
|
"hex"
|
||||||
|
|
||||||
|
"fraction" base 10 fractions base(1/3)
|
||||||
|
"frac"
|
||||||
|
|
||||||
|
"scientific" base 10 scientific notation base(1e20)
|
||||||
|
"sci"
|
||||||
|
"exp"
|
||||||
|
|
||||||
|
Where multiple strings are given, the first string listed is what
|
||||||
|
config("mode") will return.
|
||||||
|
|
||||||
|
The default "mode" is "real".
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("maxprint", int)
|
||||||
|
|
||||||
The "maxprint" parameter specifies the maximum number of elements to
|
The "maxprint" parameter specifies the maximum number of elements to
|
||||||
be displayed when a matrix or list is printed. The initial value is 16.
|
be displayed when a matrix or list is printed. The initial value is 16.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("mul2", int)
|
||||||
|
config("sq2", int)
|
||||||
|
|
||||||
Mul2 and sq2 specify the sizes of numbers at which calc switches
|
Mul2 and sq2 specify the sizes of numbers at which calc switches
|
||||||
from its first to its second algorithm for multiplying and squaring.
|
from its first to its second algorithm for multiplying and squaring.
|
||||||
The first algorithm is the usual method of cross multiplying, which
|
The first algorithm is the usual method of cross multiplying, which
|
||||||
runs in a time of O(N^2). The second method is a recursive and
|
runs in a time of O(N^2). The second method is a recursive and
|
||||||
complicated method which runs in a time of O(N^1.585). The argument
|
complicated method which runs in a time of O(N^1.585). The argument
|
||||||
for these parameters is the number of binary words at which the
|
for these parameters is the number of binary words at which the
|
||||||
second algorithm begins to be used. The minimum value is 2, and
|
second algorithm begins to be used. The minimum value is 2, and
|
||||||
the maximum value is very large. If 2 is used, then the recursive
|
the maximum value is very large. If 2 is used, then the recursive
|
||||||
algorithm is used all the way down to single digits, which becomes
|
algorithm is used all the way down to single digits, which becomes
|
||||||
slow since the recursion overhead is high. If a number such as
|
slow since the recursion overhead is high. If a number such as
|
||||||
1000000 is used, then the recursive algorithm is never used, causing
|
1000000 is used, then the recursive algorithm is never used, causing
|
||||||
calculations for large numbers to slow down. For a typical example
|
calculations for large numbers to slow down. For a typical example
|
||||||
on a 386, the two algorithms are about equal in speed for a value
|
on a 386, the two algorithms are about equal in speed for a value
|
||||||
@@ -163,6 +245,10 @@ Configuration parameters
|
|||||||
the parameter back to its default value. Usually there is no need
|
the parameter back to its default value. Usually there is no need
|
||||||
to change these parameters.
|
to change these parameters.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("pow2", int)
|
||||||
|
|
||||||
Pow2 specifies the sizes of numbers at which calc switches from
|
Pow2 specifies the sizes of numbers at which calc switches from
|
||||||
its first to its second algorithm for calculating powers modulo
|
its first to its second algorithm for calculating powers modulo
|
||||||
another number. The first algorithm for calculating modular powers
|
another number. The first algorithm for calculating modular powers
|
||||||
@@ -171,24 +257,48 @@ Configuration parameters
|
|||||||
which avoids divisions. The argument for pow2 is the size of the
|
which avoids divisions. The argument for pow2 is the size of the
|
||||||
modulus at which the second algorithm begins to be used.
|
modulus at which the second algorithm begins to be used.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("redc2", int)
|
||||||
|
|
||||||
Redc2 specifies the sizes of numbers at which calc switches from
|
Redc2 specifies the sizes of numbers at which calc switches from
|
||||||
its first to its second algorithm when using the REDC algorithm.
|
its first to its second algorithm when using the REDC algorithm.
|
||||||
The first algorithm performs a multiply and a modular reduction
|
The first algorithm performs a multiply and a modular reduction
|
||||||
together in one loop which runs in O(N^2). The second algorithm
|
together in one loop which runs in O(N^2). The second algorithm
|
||||||
does the REDC calculation using three multiplies, and runs in
|
does the REDC calculation using three multiplies, and runs in
|
||||||
O(N^1.585). The argument for redc2 is the size of the modulus at
|
O(N^1.585). The argument for redc2 is the size of the modulus at
|
||||||
which the second algorithm begins to be used.
|
which the second algorithm begins to be used.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("tilde", boolean)
|
||||||
|
|
||||||
Config("tilde") controls whether or not a leading tilde ('~') is
|
Config("tilde") controls whether or not a leading tilde ('~') is
|
||||||
printed to indicate that a number has not been printed exactly
|
printed to indicate that a number has not been printed exactly
|
||||||
because the number of decimal digits required would exceed the
|
because the number of decimal digits required would exceed the
|
||||||
specified maximum number. The initial "tilde" value is 1.
|
specified maximum number. The initial "tilde" value is 1.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("tab", boolean)
|
||||||
|
|
||||||
Config ("tab") controls the printing of a tab before results
|
Config ("tab") controls the printing of a tab before results
|
||||||
automatically displayed when working interactively. It does not
|
automatically displayed when working interactively. It does not
|
||||||
affect the printing by the functions print, printf, etc. The initial
|
affect the printing by the functions print, printf, etc. The initial
|
||||||
"tab" value is 1.
|
"tab" value is 1.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("quomod", bitflag)
|
||||||
|
config("quo", bitflag)
|
||||||
|
config("mod", bitflag)
|
||||||
|
config("sqrt", bitflag)
|
||||||
|
config("appr", bitflag)
|
||||||
|
config("cfappr", bitflag)
|
||||||
|
config("cfsim", bitflag)
|
||||||
|
config("outround", bitflag)
|
||||||
|
config("round", bitflag)
|
||||||
|
|
||||||
The "quomod", "quo", "mod", "sqrt", "appr", "cfappr", "cfsim", and
|
The "quomod", "quo", "mod", "sqrt", "appr", "cfappr", "cfsim", and
|
||||||
"round" control the way in which any necessary rounding occurs.
|
"round" control the way in which any necessary rounding occurs.
|
||||||
Rounding occurs when for some reason, a calculated or displayed
|
Rounding occurs when for some reason, a calculated or displayed
|
||||||
@@ -234,11 +344,19 @@ Configuration parameters
|
|||||||
by the various kinds of printing to the output: bits 0, 1, 3 and 4
|
by the various kinds of printing to the output: bits 0, 1, 3 and 4
|
||||||
are used in the same way as for the functions round and bround.
|
are used in the same way as for the functions round and bround.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("leadzero", bool)
|
||||||
|
|
||||||
The "leadzero" parameter controls whether or not a 0 is printed
|
The "leadzero" parameter controls whether or not a 0 is printed
|
||||||
before the decimal point in non-zero fractions with absolute value
|
before the decimal point in non-zero fractions with absolute value
|
||||||
less than 1, e.g. whether 1/2 is printed as 0.5 or .5. The
|
less than 1, e.g. whether 1/2 is printed as 0.5 or .5. The
|
||||||
initial value is 0, corresponding to the printing .5.
|
initial value is 0, corresponding to the printing .5.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("fullzero", bool)
|
||||||
|
|
||||||
The "fullzero" parameter controls whether or not in decimal floating-
|
The "fullzero" parameter controls whether or not in decimal floating-
|
||||||
point printing, the digits are padded with zeros to reach the
|
point printing, the digits are padded with zeros to reach the
|
||||||
number of digits specified by config("display") or by a precision
|
number of digits specified by config("display") or by a precision
|
||||||
@@ -246,10 +364,18 @@ Configuration parameters
|
|||||||
parameter is 0, so that, for example, if config("display") >= 2,
|
parameter is 0, so that, for example, if config("display") >= 2,
|
||||||
5/4 will print in "real" mode as 1.25.
|
5/4 will print in "real" mode as 1.25.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("maxscan", int)
|
||||||
|
|
||||||
The maxscan value controls how many scan errors are allowed
|
The maxscan value controls how many scan errors are allowed
|
||||||
before the compiling phase of a computation is aborted. The initial
|
before the compiling phase of a computation is aborted. The initial
|
||||||
value of "maxscan" is 20. Setting maxscan to 0 disables this feature.
|
value of "maxscan" is 20. Setting maxscan to 0 disables this feature.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("prompt", str)
|
||||||
|
|
||||||
The default prompt when in interactive mode is "> ". One may change
|
The default prompt when in interactive mode is "> ". One may change
|
||||||
this prompt to a more cut-and-paste friendly prompt by:
|
this prompt to a more cut-and-paste friendly prompt by:
|
||||||
|
|
||||||
@@ -259,30 +385,47 @@ Configuration parameters
|
|||||||
cut/copy an input line and paste it directly into input. The
|
cut/copy an input line and paste it directly into input. The
|
||||||
leading ';' will be ignored.
|
leading ';' will be ignored.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("more", str)
|
||||||
|
|
||||||
When inside multi-line input, the more prompt is used. One may
|
When inside multi-line input, the more prompt is used. One may
|
||||||
change it by:
|
change it by:
|
||||||
|
|
||||||
config("more", ";; ")
|
config("more", ";; ")
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("blkmaxprint", int)
|
||||||
|
|
||||||
The "blkmaxprint" config value limits the number of octets to print
|
The "blkmaxprint" config value limits the number of octets to print
|
||||||
for a block. A "blkmaxprint" of 0 means to print all octets of a
|
for a block. A "blkmaxprint" of 0 means to print all octets of a
|
||||||
block, regardless of size.
|
block, regardless of size.
|
||||||
|
|
||||||
The default is to print only the first 256 octets.
|
The default is to print only the first 256 octets.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("blkverbose", bool)
|
||||||
|
|
||||||
The "blkverbose" determines if all lines, including duplicates
|
The "blkverbose" determines if all lines, including duplicates
|
||||||
should be printed. If TRUE, then all lines are printed. If false,
|
should be printed. If TRUE, then all lines are printed. If false,
|
||||||
duplicate lines are skipped and only a "*" is printed in a style
|
duplicate lines are skipped and only a "*" is printed in a style
|
||||||
similar to od. This config value has not meaning if "blkfmt" is "str".
|
similar to od. This config value has not meaning if "blkfmt" is "str".
|
||||||
|
|
||||||
The default value for "blkverbose" is FALSE: duplicate lines are
|
The default value for "blkverbose" is FALSE: duplicate lines are
|
||||||
not printed.
|
not printed.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("blkbase", "blkbase_string")
|
||||||
|
|
||||||
The "blkbase" determines the base in which octets of a block
|
The "blkbase" determines the base in which octets of a block
|
||||||
are printed. Possible values are:
|
are printed. Possible values are:
|
||||||
|
|
||||||
"hexadecimal" Octets printed in 2 digit hex
|
"hexadecimal" Octets printed in 2 digit hex
|
||||||
"hex"
|
"hex"
|
||||||
|
"default"
|
||||||
|
|
||||||
"octal" Octets printed in 3 digit octal
|
"octal" Octets printed in 3 digit octal
|
||||||
"oct"
|
"oct"
|
||||||
@@ -296,30 +439,45 @@ Configuration parameters
|
|||||||
"raw" Octets printed as is, i.e. raw binary
|
"raw" Octets printed as is, i.e. raw binary
|
||||||
"none"
|
"none"
|
||||||
|
|
||||||
The default "blkbase" is "hex".
|
Where multiple strings are given, the first string listed is what
|
||||||
|
config("blkbase") will return.
|
||||||
|
|
||||||
|
The default "blkbase" is "hexadecimal".
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("blkfmt", "blkfmt_string")
|
||||||
|
|
||||||
The "blkfmt" determines for format of how block are printed:
|
The "blkfmt" determines for format of how block are printed:
|
||||||
|
|
||||||
"line" print in lines of up to 79 chars + newline
|
"lines" print in lines of up to 79 chars + newline
|
||||||
"lines"
|
"line"
|
||||||
|
|
||||||
"str" print as one long string
|
"strings" print as one long string
|
||||||
"string"
|
"string"
|
||||||
"strings"
|
"str"
|
||||||
|
|
||||||
"od" print in od-like format, with leading offset,
|
"od_style" print in od-like format, with leading offset,
|
||||||
"odstyle" followed by octets in the given base
|
"odstyle" followed by octets in the given base
|
||||||
"od_style"
|
"od"
|
||||||
|
|
||||||
"hd" print in hex dump format, with leading offset,
|
"hd_style" print in hex dump format, with leading offset,
|
||||||
"hdstyle" followed by octets in the given base, followed
|
"hdstyle" followed by octets in the given base, followed
|
||||||
"hd_style" by chars or '.' if no-printable or blank
|
"hd" by chars or '.' if no-printable or blank
|
||||||
|
"default"
|
||||||
|
|
||||||
The default "blkfmt" is "hd".
|
Where multiple strings are given, the first string listed is what
|
||||||
|
config("blkfmt") will return.
|
||||||
|
|
||||||
|
The default "blkfmt" is "hd_style".
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("calc_debug", bitflag)
|
||||||
|
|
||||||
The "calc_debug" is intended for controlling internal calc routines
|
The "calc_debug" is intended for controlling internal calc routines
|
||||||
that test its operation, or collect or display information that
|
that test its operation, or collect or display information that
|
||||||
might be useful for debug purposes. Much of the output from these
|
might be useful for debug purposes. Much of the output from these
|
||||||
will make sense only to calc wizards. Zero value (the default for
|
will make sense only to calc wizards. Zero value (the default for
|
||||||
both oldstd and newstd) of config("lib_calc") corresponds to switching
|
both oldstd and newstd) of config("lib_calc") corresponds to switching
|
||||||
off all these routines. For nonzero value, particular bits
|
off all these routines. For nonzero value, particular bits
|
||||||
@@ -352,6 +510,10 @@ Configuration parameters
|
|||||||
By default, "calc_debug" is 0. The initial value may be overridden
|
By default, "calc_debug" is 0. The initial value may be overridden
|
||||||
by the -D command line option.
|
by the -D command line option.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("lib_debug", bitflag)
|
||||||
|
|
||||||
The "lib_debug" parameter is intended for controlling the possible
|
The "lib_debug" parameter is intended for controlling the possible
|
||||||
display of special information relating to functions, objects, and
|
display of special information relating to functions, objects, and
|
||||||
other structures created by instructions in calc scripts.
|
other structures created by instructions in calc scripts.
|
||||||
@@ -369,6 +531,9 @@ Configuration parameters
|
|||||||
the reading of a file, a message saying what has been done
|
the reading of a file, a message saying what has been done
|
||||||
is displayed.
|
is displayed.
|
||||||
|
|
||||||
|
2 Show func will display more information about a functions
|
||||||
|
arguments as well as more argument sdummary information.
|
||||||
|
|
||||||
The value for config("lib_debug") in both oldstd and newstd is 3,
|
The value for config("lib_debug") in both oldstd and newstd is 3,
|
||||||
but if calc is invoked with the -d flag, its initial value is zero.
|
but if calc is invoked with the -d flag, its initial value is zero.
|
||||||
Thus, if calc is started without the -d flag, until config("lib_debug")
|
Thus, if calc is started without the -d flag, until config("lib_debug")
|
||||||
@@ -378,6 +543,10 @@ Configuration parameters
|
|||||||
By default, "lib_debug" is 3. The -d flag changes this default to 0.
|
By default, "lib_debug" is 3. The -d flag changes this default to 0.
|
||||||
The initial value may be overridden by the -D command line option.
|
The initial value may be overridden by the -D command line option.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("user_debug", int)
|
||||||
|
|
||||||
The "user_debug" is provided for use by users. Calc ignores this value
|
The "user_debug" is provided for use by users. Calc ignores this value
|
||||||
other than to set it to 0 by default (for both "oldstd" and "newstd").
|
other than to set it to 0 by default (for both "oldstd" and "newstd").
|
||||||
No calc code or shipped library should change this value. Users
|
No calc code or shipped library should change this value. Users
|
||||||
@@ -391,26 +560,44 @@ Configuration parameters
|
|||||||
By default, "user_debug" is 0. The initial value may be overridden
|
By default, "user_debug" is 0. The initial value may be overridden
|
||||||
by the -D command line option.
|
by the -D command line option.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
config("verbose_quit", bool)
|
||||||
|
|
||||||
The "verbose_quit" controls the print of the message:
|
The "verbose_quit" controls the print of the message:
|
||||||
|
|
||||||
Quit or abort executed
|
Quit or abort executed
|
||||||
|
|
||||||
when a non-interactive quit or abort without an argument is encounted.
|
when a non-interactive quit or abort without an argument is encountered.
|
||||||
A quit of abort without an argument does not display a message when
|
A quit of abort without an argument does not display a message when
|
||||||
invoked at the interactive level.
|
invoked at the interactive level.
|
||||||
|
|
||||||
The following are synonyms for true:
|
=-=
|
||||||
|
|
||||||
"on" "yes" "y" "true" "t" "1" any non-zero number
|
config("ctrl_d", "ctrl_d_string")
|
||||||
|
|
||||||
The following are synonyms for false:
|
The "ctrl_d" controls the interactive meaning of ^D (Control D):
|
||||||
|
|
||||||
"off" "no" "n" "false" "f" "0" the number zero (0)
|
"virgin_eof" If ^D is the only character that has been typed
|
||||||
|
"virgineof" on a line, then calc will exit. Otherwise ^D
|
||||||
|
"virgin" will act according to the calc binding, which
|
||||||
|
"default" by default is a Emacs-style delete-char.
|
||||||
|
|
||||||
Examples of setting some parameters are:
|
"never_eof" The ^D never exits calc and only acts according
|
||||||
|
"nevereof" calc binding, which by default is a Emacs-style
|
||||||
|
"never" delete-char.
|
||||||
|
|
||||||
config("mode", "exp"); exponential output
|
"empty_eof" The ^D always exits calc if typed on an empty line.
|
||||||
config("display", 50); 50 digits of output
|
"emptyeof" This condition occurs when ^D either the first
|
||||||
epsilon(epsilon() / 8); 3 bits more accuracy
|
"empty" character typed, or when all other characters on
|
||||||
config("tilde", 0) disable roundoff tilde printing
|
the line have been removed (say by deleting them).
|
||||||
config("tab", "off") disable leading tab printing
|
|
||||||
|
Where multiple strings are given, the first string listed is what
|
||||||
|
config("ctrl_d") will return.
|
||||||
|
|
||||||
|
Note that config("ctrl_d") actually controls each and every character
|
||||||
|
that is bound to ``delete_char''. By default, ``delete_char'' is
|
||||||
|
Control D. Any character(s) bound to ``delete_char'' will cause calc
|
||||||
|
to exit (or not exit) as directed by config("ctrl_d").
|
||||||
|
|
||||||
|
The default "ctrl_d" is "virgin_eof".
|
||||||
|
22
help/contrib
22
help/contrib
@@ -36,17 +36,33 @@ gziped (or compressed) tar file).
|
|||||||
|
|
||||||
You should send submissions to:
|
You should send submissions to:
|
||||||
|
|
||||||
calc-tester@postofc.corp.sgi.com
|
calc-tester at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
Thanks for considering submitting code to calc. Calc is a collective
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
|
Thanks for considering submitting code to calc. Calc is a collective
|
||||||
work by a number of people. It would not be what it is today without
|
work by a number of people. It would not be what it is today without
|
||||||
your efforts and submissions!
|
your efforts and submissions!
|
||||||
|
|
||||||
|
Calc bug reports, however, should be sent to:
|
||||||
|
|
||||||
|
calc-bugs at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
|
See the BUGS file or try the help command:
|
||||||
|
|
||||||
|
help bugs
|
||||||
|
|
||||||
|
for details on bug reporting.
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
One may join the calc testing group by sending a request to:
|
One may join the calc testing group by sending a request to:
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
calc-tester-request at postofc dot corp dot sgi dot com
|
||||||
|
|
||||||
|
[[ Replace 'at' with @, 'dot' is with . and remove the spaces ]]
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
Your message body (not the subject) should consist of:
|
||||||
|
|
||||||
|
@@ -2,7 +2,11 @@ Credits
|
|||||||
|
|
||||||
The majority of calc was written by David I. Bell.
|
The majority of calc was written by David I. Bell.
|
||||||
|
|
||||||
Calc archives and calc-tester mailing list maintained by Landon Curt Noll.
|
The Calc primary mirror, calc mailing list and calc bug report
|
||||||
|
processing is performed by Landon Curt Noll.
|
||||||
|
|
||||||
|
Landon Curt Noll maintains the master reference source, performs
|
||||||
|
release control functions as well as other calc maintenance functions.
|
||||||
|
|
||||||
Thanks for suggestions and encouragement from Peter Miller,
|
Thanks for suggestions and encouragement from Peter Miller,
|
||||||
Neil Justusson, and Landon Noll.
|
Neil Justusson, and Landon Noll.
|
||||||
@@ -11,7 +15,7 @@ Credits
|
|||||||
hist.c which is used to do the command line editing.
|
hist.c which is used to do the command line editing.
|
||||||
|
|
||||||
Thanks to Ernest W. Bowen for supplying many improvements in
|
Thanks to Ernest W. Bowen for supplying many improvements in
|
||||||
accuracy and generality for some numeric functions. Much of
|
accuracy and generality for some numeric functions. Much of
|
||||||
this was in terms of actual code which I gratefully accepted.
|
this was in terms of actual code which I gratefully accepted.
|
||||||
Ernest also supplied the original text for many of the help files.
|
Ernest also supplied the original text for many of the help files.
|
||||||
|
|
||||||
|
@@ -28,7 +28,7 @@ DESCRIPTION
|
|||||||
calc -C
|
calc -C
|
||||||
|
|
||||||
In other words, explicit action must be taken in order to
|
In other words, explicit action must be taken in order to
|
||||||
enable the use of custom functions. By default (no -C arg)
|
enable the use of custom functions. By default (no -C arg)
|
||||||
custom functions are compiled in but disabled so that only
|
custom functions are compiled in but disabled so that only
|
||||||
portable calc scripts may be used.
|
portable calc scripts may be used.
|
||||||
|
|
||||||
@@ -36,7 +36,7 @@ DESCRIPTION
|
|||||||
multi-precision calculations in a C-like environment. You should
|
multi-precision calculations in a C-like environment. You should
|
||||||
consider implementing algorithms in the calc language as a first
|
consider implementing algorithms in the calc language as a first
|
||||||
choice. Sometimes an algorithm requires use of special hardware, a
|
choice. Sometimes an algorithm requires use of special hardware, a
|
||||||
non-portable OS or pre-compiled C library. In these cases a custom
|
non-portable OS or pre-compiled C library. In these cases a custom
|
||||||
interface may be needed.
|
interface may be needed.
|
||||||
|
|
||||||
The custom function interface is intended to make is easy for
|
The custom function interface is intended to make is easy for
|
||||||
|
@@ -9,7 +9,7 @@ Function definitions
|
|||||||
by a return statement, and the function definition is ended with a
|
by a return statement, and the function definition is ended with a
|
||||||
right brace.
|
right brace.
|
||||||
|
|
||||||
There are some subtle differences, however. The types of parameters
|
There are some subtle differences, however. The types of parameters
|
||||||
and variables are not defined at compile time, and may vary during
|
and variables are not defined at compile time, and may vary during
|
||||||
execution and be different in different calls to the function. For
|
execution and be different in different calls to the function. For
|
||||||
example, a two-argument function add may be defined by
|
example, a two-argument function add may be defined by
|
||||||
|
2
help/den
2
help/den
@@ -11,7 +11,7 @@ TYPES
|
|||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
For real x, den(x) returns the denominator of x when x is expressed
|
For real x, den(x) returns the denominator of x when x is expressed
|
||||||
in lowest terms with positive denominator. In calc,
|
in lowest terms with positive denominator. In calc,
|
||||||
real values are actually rational values. Each calc real
|
real values are actually rational values. Each calc real
|
||||||
value can be uniquely expressed as:
|
value can be uniquely expressed as:
|
||||||
|
|
||||||
|
@@ -14,7 +14,7 @@ Environment variables
|
|||||||
|
|
||||||
/usr/local/lib/calc
|
/usr/local/lib/calc
|
||||||
|
|
||||||
This value is used by the READ command. It is an error
|
This value is used by the READ command. It is an error
|
||||||
if no such readable file is found.
|
if no such readable file is found.
|
||||||
|
|
||||||
The CALCBINDINGS file searches the CALCPATH as well.
|
The CALCBINDINGS file searches the CALCPATH as well.
|
||||||
@@ -48,8 +48,6 @@ Environment variables
|
|||||||
Typically compiled in value is:
|
Typically compiled in value is:
|
||||||
|
|
||||||
bindings
|
bindings
|
||||||
or:
|
|
||||||
altbind (bindings where ^D means exit)
|
|
||||||
|
|
||||||
The bindings file is searched along the CALCPATH. Unlike
|
The bindings file is searched along the CALCPATH. Unlike
|
||||||
the READ command, a .cal extension is not added.
|
the READ command, a .cal extension is not added.
|
||||||
|
@@ -1 +1 @@
|
|||||||
/^#define E_[^_].*[ ][1-9][0-9]*[ ]\/\* .* \*\//s/#define E_.*[ ]\([1-9][0-9]*\)[ ]*\/\* \(.*\)[ ][ ]*\*\// \1 \2/p
|
/^#define E_[^_].*[ ][1-9][0-9]*[ ]\/\* .* \*\//s/#define E_.*[ ]\([1-9][0-9]*\)[ ]*\/\* \(.*\)[ ][ ]*\*\// \1 \2/p
|
||||||
|
@@ -11,7 +11,7 @@ TYPES
|
|||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
For eval(str), the value of str is to be a string that could be the body
|
For eval(str), the value of str is to be a string that could be the body
|
||||||
of the definition of a function f(). This string may declare local
|
of the definition of a function f(). This string may declare local
|
||||||
variables and include keywords (while, for, ...) other than the
|
variables and include keywords (while, for, ...) other than the
|
||||||
reserved keywords (define, show, help, read, write, show, cd) intended
|
reserved keywords (define, show, help, read, write, show, cd) intended
|
||||||
for interactive use or for reading from a file.
|
for interactive use or for reading from a file.
|
||||||
|
2
help/exp
2
help/exp
@@ -1,5 +1,5 @@
|
|||||||
NAME
|
NAME
|
||||||
exp - exponential function
|
exp - exponential function
|
||||||
|
|
||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
exp(x [,eps])
|
exp(x [,eps])
|
||||||
|
@@ -14,7 +14,7 @@ TYPES
|
|||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
|
|
||||||
If n >= 0 and n has a prime factor less than or equal to limit,
|
If n >= 0 and n has a prime factor less than or equal to limit,
|
||||||
factor(n, limit) returns the smallest such factor. If n >= 0
|
factor(n, limit) returns the smallest such factor. If n >= 0
|
||||||
and the smallest prime factor of n exceeds limit, 1 is returned.
|
and the smallest prime factor of n exceeds limit, 1 is returned.
|
||||||
In particular, if n >= 0 and limit <= 1, factor(n, limit)
|
In particular, if n >= 0 and limit <= 1, factor(n, limit)
|
||||||
always returns 1; factor(n,2) returns 2 if and only if n is even.
|
always returns 1; factor(n,2) returns 2 if and only if n is even.
|
||||||
|
@@ -13,20 +13,20 @@ DESCRIPTION
|
|||||||
This function closes the open file associated with the descriptor fd.
|
This function closes the open file associated with the descriptor fd.
|
||||||
When this is done, the file value associated with the file remains
|
When this is done, the file value associated with the file remains
|
||||||
a file value, but appears 'closed', and cannot be used in further
|
a file value, but appears 'closed', and cannot be used in further
|
||||||
file-related calls (except fclose) without causing errors. This same
|
file-related calls (except fclose) without causing errors. This same
|
||||||
action occurs to all copies of the file value. You do not need to
|
action occurs to all copies of the file value. You do not need to
|
||||||
explicitly close all the copies of a file value.
|
explicitly close all the copies of a file value.
|
||||||
|
|
||||||
Standard input, standard output and standard error are always opened
|
Standard input, standard output and standard error are always opened
|
||||||
and cannot be closed.
|
and cannot be closed.
|
||||||
|
|
||||||
The truth value of an closed file is FALSE.
|
The truth value of a closed file is FALSE.
|
||||||
|
|
||||||
The fclose function returns the numeric value of errno if
|
The fclose function returns the numeric value of errno if
|
||||||
there had been an error using the file, or the null value if
|
there had been an error using the file, or the null value if
|
||||||
there was no error.
|
there was no error.
|
||||||
|
|
||||||
Closing a closed file is permitted. Fclose returns null in
|
Closing a closed file is permitted. Fclose returns null in
|
||||||
this case.
|
this case.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
is set or clear.
|
is set or clear.
|
||||||
|
|
||||||
The end-of-file flag for the stream fd is set if reading at the
|
The end-of-file flag for the stream fd is set if reading at the
|
||||||
end-of-file position is attempted. The flag is cleared by
|
end-of-file position is attempted. The flag is cleared by
|
||||||
positioning operations (fseek, rewind, fsetpos) and by freopen.
|
positioning operations (fseek, rewind, fsetpos) and by freopen.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
@@ -23,14 +23,14 @@ EXAMPLE
|
|||||||
> fflush(fd1)
|
> fflush(fd1)
|
||||||
> fd2 = fopen("/tmp/newfile", "r")
|
> fd2 = fopen("/tmp/newfile", "r")
|
||||||
> feof(fd2)
|
> feof(fd2)
|
||||||
0
|
0
|
||||||
> fgetline(fd2)
|
> fgetline(fd2)
|
||||||
"Chongo was here"
|
"Chongo was here"
|
||||||
> feof(fd2)
|
> feof(fd2)
|
||||||
0
|
0
|
||||||
> fgetline(fd2)
|
> fgetline(fd2)
|
||||||
> feof(fd2)
|
> feof(fd2)
|
||||||
1
|
1
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
none
|
none
|
||||||
|
@@ -20,10 +20,10 @@ DESCRIPTION
|
|||||||
EXAMPLE
|
EXAMPLE
|
||||||
> fd = fopen("/etc/motd", "r")
|
> fd = fopen("/etc/motd", "r")
|
||||||
> ferror(fd)
|
> ferror(fd)
|
||||||
0
|
0
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
@@ -10,7 +10,7 @@ TYPES
|
|||||||
return nil
|
return nil
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This function forces and buffered output to the file associated with fd.
|
This function forces a buffered output to the file associated with fd.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> fd = fopen("/tmp/file", "w")
|
> fd = fopen("/tmp/file", "w")
|
||||||
@@ -18,7 +18,7 @@ EXAMPLE
|
|||||||
> fflush(fd)
|
> fflush(fd)
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
associated with fd.
|
associated with fd.
|
||||||
|
|
||||||
If there is a next character, this function returns a 1
|
If there is a next character, this function returns a 1
|
||||||
character string containing that character. In the case
|
character string containing that character. In the case
|
||||||
of EOF or error, nil is returned.
|
of EOF or error, nil is returned.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
@@ -25,7 +25,7 @@ EXAMPLE
|
|||||||
"c"
|
"c"
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
@@ -16,7 +16,7 @@ DESCRIPTION
|
|||||||
characters are skipped. If the reading reaches end-of-file, the
|
characters are skipped. If the reading reaches end-of-file, the
|
||||||
null value is returned. If non-whitespace is encountered, formation
|
null value is returned. If non-whitespace is encountered, formation
|
||||||
of a string begins, continuing until whitespace of '\0' or end-of-file
|
of a string begins, continuing until whitespace of '\0' or end-of-file
|
||||||
is reached. The returned value is this string (terminated as usual
|
is reached. The returned value is this string (terminated as usual
|
||||||
by a null character). After the operation, the file position will
|
by a null character). After the operation, the file position will
|
||||||
be immediately after the first whitespace character of '\0' or at
|
be immediately after the first whitespace character of '\0' or at
|
||||||
end-of-file.
|
end-of-file.
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
the open file associated with fd. Unlike fgets, the trailing
|
the open file associated with fd. Unlike fgets, the trailing
|
||||||
newline is removed from the return string.
|
newline is removed from the return string.
|
||||||
|
|
||||||
Empty lines return the null string. When the end of file is reached,
|
Empty lines return the null string. When the end of file is reached,
|
||||||
fgetline returns the null value. (Note the distinction between a null
|
fgetline returns the null value. (Note the distinction between a null
|
||||||
string and a null value.)
|
string and a null value.)
|
||||||
|
|
||||||
@@ -41,7 +41,7 @@ EXAMPLE
|
|||||||
123
|
123
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
the open file associated with fd. Unlike fgetline, the trailing
|
the open file associated with fd. Unlike fgetline, the trailing
|
||||||
newline is included in the return string.
|
newline is included in the return string.
|
||||||
|
|
||||||
If a line is read, is returned, otherwise (EOF or ERROR) nil is returned.
|
If a line is read, it is returned, otherwise (EOF or ERROR) nil is returned.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> fd = fopen("/tmp/newfile", "w")
|
> fd = fopen("/tmp/newfile", "w")
|
||||||
@@ -30,7 +30,7 @@ EXAMPLE
|
|||||||
"chongo was here"
|
"chongo was here"
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
@@ -14,7 +14,7 @@ DESCRIPTION
|
|||||||
|
|
||||||
If the stream cannot be read, an error value is returned.
|
If the stream cannot be read, an error value is returned.
|
||||||
|
|
||||||
Otherwise the function retrurns the string of characters from the
|
Otherwise the function returns the string of characters from the
|
||||||
current file position to the first null character ('\0') (the file
|
current file position to the first null character ('\0') (the file
|
||||||
position for further reading then being immediately after the '\0'),
|
position for further reading then being immediately after the '\0'),
|
||||||
or if no null character is encountered, the string of characters to
|
or if no null character is encountered, the string of characters to
|
||||||
|
18
help/file
18
help/file
@@ -6,7 +6,7 @@ Using files
|
|||||||
Some differences do occur, as will be explained here.
|
Some differences do occur, as will be explained here.
|
||||||
|
|
||||||
Names of files are subject to ~ expansion just like the C or
|
Names of files are subject to ~ expansion just like the C or
|
||||||
Korn shell. For example, the file name:
|
Korn shell. For example, the file name:
|
||||||
|
|
||||||
~/.rc.cal
|
~/.rc.cal
|
||||||
|
|
||||||
@@ -19,8 +19,8 @@ Using files
|
|||||||
|
|
||||||
A file can be opened for either reading, writing, or appending.
|
A file can be opened for either reading, writing, or appending.
|
||||||
To do this, the 'fopen' function is used, which accepts a filename
|
To do this, the 'fopen' function is used, which accepts a filename
|
||||||
and an open mode, both as strings. You use 'r' for reading, 'w'
|
and an open mode, both as strings. You use 'r' for reading, 'w'
|
||||||
for writing, and 'a' for appending. For example, to open the file
|
for writing, and 'a' for appending. For example, to open the file
|
||||||
'foo' for reading, the following could be used:
|
'foo' for reading, the following could be used:
|
||||||
|
|
||||||
fd = fopen('foo', 'r');
|
fd = fopen('foo', 'r');
|
||||||
@@ -53,7 +53,7 @@ Using files
|
|||||||
The 'fclose' function is used to close a file which had been opened.
|
The 'fclose' function is used to close a file which had been opened.
|
||||||
When this is done, the file value associated with the file remains
|
When this is done, the file value associated with the file remains
|
||||||
a file value, but appears 'closed', and cannot be used in further
|
a file value, but appears 'closed', and cannot be used in further
|
||||||
file-related calls (except fclose) without causing errors. This same
|
file-related calls (except fclose) without causing errors. This same
|
||||||
action occurs to all copies of the file value. You do not need to
|
action occurs to all copies of the file value. You do not need to
|
||||||
explicitly close all the copies of a file value. The 'fclose'
|
explicitly close all the copies of a file value. The 'fclose'
|
||||||
function returns the numeric value of errno if there had been an
|
function returns the numeric value of errno if there had been an
|
||||||
@@ -67,7 +67,7 @@ Using files
|
|||||||
print "error #" : badfile : ":", errno(badfile);
|
print "error #" : badfile : ":", errno(badfile);
|
||||||
}
|
}
|
||||||
|
|
||||||
File values can be printed. When this is done, the filename of the
|
File values can be printed. When this is done, the filename of the
|
||||||
opened file is printed inside of quote marks. If the file value had
|
opened file is printed inside of quote marks. If the file value had
|
||||||
been closed, then the null string is printed. If a file value is the
|
been closed, then the null string is printed. If a file value is the
|
||||||
result of a top-level expression, then in addition to the filename,
|
result of a top-level expression, then in addition to the filename,
|
||||||
@@ -75,7 +75,7 @@ Using files
|
|||||||
status is also displayed.
|
status is also displayed.
|
||||||
|
|
||||||
File values can be used inside of 'if' tests. When this is done,
|
File values can be used inside of 'if' tests. When this is done,
|
||||||
an opened file is TRUE, and a closed file is FALSE. As an example
|
an opened file is TRUE, and a closed file is FALSE. As an example
|
||||||
of this, the following loop will print the names of all the currently
|
of this, the following loop will print the names of all the currently
|
||||||
opened non-standard files with their indexes, and then close them:
|
opened non-standard files with their indexes, and then close them:
|
||||||
|
|
||||||
@@ -89,9 +89,9 @@ Using files
|
|||||||
The functions to read from files are 'fgetline' and 'fgetc'.
|
The functions to read from files are 'fgetline' and 'fgetc'.
|
||||||
The 'fgetline' function accepts a file value, and returns the next
|
The 'fgetline' function accepts a file value, and returns the next
|
||||||
input line from a file. The line is returned as a string value, and
|
input line from a file. The line is returned as a string value, and
|
||||||
does not contain the end of line character. Empty lines return the
|
does not contain the end of line character. Empty lines return the
|
||||||
null string. When the end of file is reached, fgetline returns the
|
null string. When the end of file is reached, fgetline returns the
|
||||||
null value. (Note the distinction between a null string and a null
|
null value. (Note the distinction between a null string and a null
|
||||||
value.) If the line contained a numeric value, then the 'eval'
|
value.) If the line contained a numeric value, then the 'eval'
|
||||||
function can then be used to convert the string to a numeric value.
|
function can then be used to convert the string to a numeric value.
|
||||||
Care should be used when doing this, however, since eval will
|
Care should be used when doing this, however, since eval will
|
||||||
@@ -103,7 +103,7 @@ Using files
|
|||||||
The 'printf' and 'fprintf' functions are used to print results to a
|
The 'printf' and 'fprintf' functions are used to print results to a
|
||||||
file (which could be stdout or stderr). The 'fprintf' function
|
file (which could be stdout or stderr). The 'fprintf' function
|
||||||
accepts a file variable, whereas the 'printf' function assumes the
|
accepts a file variable, whereas the 'printf' function assumes the
|
||||||
use of 'files(1)' (stdout). They both require a format string, which
|
use of 'files(1)' (stdout). They both require a format string, which
|
||||||
is used in almost the same way as in normal C. The differences come
|
is used in almost the same way as in normal C. The differences come
|
||||||
in the interpretation of values to be printed for various formats.
|
in the interpretation of values to be printed for various formats.
|
||||||
Unlike in C, where an unmatched format type and value will cause
|
Unlike in C, where an unmatched format type and value will cause
|
||||||
|
@@ -10,7 +10,7 @@ TYPES
|
|||||||
return files, int or null
|
return files, int or null
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This function, then given the argument fnum, will use it as an
|
This function, when given the argument fnum, will use it as an
|
||||||
index into an internal table of open file and return a file value.
|
index into an internal table of open file and return a file value.
|
||||||
If that entry in the table is not in use, then the null value is
|
If that entry in the table is not in use, then the null value is
|
||||||
returned instead. When no args are given, the maximum number of
|
returned instead. When no args are given, the maximum number of
|
||||||
@@ -25,7 +25,7 @@ DESCRIPTION
|
|||||||
files are already open by the calculator and cannot be closed.
|
files are already open by the calculator and cannot be closed.
|
||||||
|
|
||||||
When calc starts up, it scans for open file descriptors above
|
When calc starts up, it scans for open file descriptors above
|
||||||
stderr (2) and below MAXFILES (20). Any open descriptor found
|
stderr (2) and below MAXFILES (20). Any open descriptor found
|
||||||
is assumed to be an open file opened in an unknown mode. Calc
|
is assumed to be an open file opened in an unknown mode. Calc
|
||||||
will try to read and write to this file when directed.
|
will try to read and write to this file when directed.
|
||||||
|
|
||||||
|
@@ -13,14 +13,14 @@ TYPES
|
|||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
This function opens the file named filename. A file can be
|
This function opens the file named filename. A file can be
|
||||||
opened for either reading, writing, or appending. The mode
|
opened for either reading, writing, or appending. The mode
|
||||||
is controlled by the mode flag as folllows:
|
is controlled by the mode flag as follows:
|
||||||
|
|
||||||
"r" reading
|
"r" reading
|
||||||
"w" writing
|
"w" writing
|
||||||
"a" appending
|
"a" appending
|
||||||
|
|
||||||
Names of files are subject to ~ expansion just like the C or
|
Names of files are subject to ~ expansion just like the C or
|
||||||
Korn shell. For example, the file name:
|
Korn shell. For example, the file name:
|
||||||
|
|
||||||
~/lib/gleet
|
~/lib/gleet
|
||||||
|
|
||||||
|
@@ -11,7 +11,7 @@ TYPES
|
|||||||
return null value
|
return null value
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
In forall(x,y), y is to the the name of a function; that function
|
In forall(x,y), y is the name of a function; that function
|
||||||
is performed in succession for all elements of x. This is similar
|
is performed in succession for all elements of x. This is similar
|
||||||
to modify(x, y) but x is not changed.
|
to modify(x, y) but x is not changed.
|
||||||
|
|
||||||
|
@@ -22,7 +22,7 @@ EXAMPLE
|
|||||||
"c"
|
"c"
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
fd must be associaed with an open file
|
fd must be associated with an open file
|
||||||
|
|
||||||
LIBRARY
|
LIBRARY
|
||||||
none
|
none
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user