mirror of
https://github.com/lcn2/calc.git
synced 2025-08-19 01:13:27 +03:00
Compare commits
3 Commits
2.11.0t7.1
...
2.11.0t7.4
Author | SHA1 | Date | |
---|---|---|---|
|
2251281027 | ||
|
45a4b8469d | ||
|
9204d2fb8c |
12
BUGS
12
BUGS
@@ -77,15 +77,3 @@ Known problems or mis-features:
|
|||||||
* There is some places in the source with obscure variable names
|
* There is some places in the source with obscure variable names
|
||||||
and not much in the way of comments. We need some major cleanup
|
and not much in the way of comments. We need some major cleanup
|
||||||
and documentation.
|
and documentation.
|
||||||
|
|
||||||
* On a Dec Alpha, using the Dec Alpha cc (not gcc) make check for
|
|
||||||
version 2.11.0t5.1 fails in the regression test:
|
|
||||||
|
|
||||||
From vandermj@molbio.sbphrd.com Tue Oct 5 04:06:52 1999
|
|
||||||
Subject: Re: oops, try calc version 2.10.0t5.1
|
|
||||||
Date: Tue, 05 Oct 1999 07:06:30 -0400
|
|
||||||
|
|
||||||
Regular cc on Dec alpha, 'make check' dies with:
|
|
||||||
|
|
||||||
1804: surd_value(a) == 2+3i
|
|
||||||
"": line 1706: Calling qfreenum with nozero links!!!
|
|
||||||
|
38
CHANGES
38
CHANGES
@@ -103,6 +103,44 @@ Following is the change from calc version 2.11.0t7 to date:
|
|||||||
n == 0 if -c, continue, without -c, stop
|
n == 0 if -c, continue, without -c, stop
|
||||||
n < 0 continue on error, even if -c was given on the command line
|
n < 0 continue on error, even if -c was given on the command line
|
||||||
|
|
||||||
|
Calc compilation now stops at the first scanerror.
|
||||||
|
|
||||||
|
Restored the feature where -p disables the printing of leading tabs
|
||||||
|
as of config("tab",0) had been executed. So using calc in a pipe:
|
||||||
|
|
||||||
|
calc -p 2+17 | whey
|
||||||
|
|
||||||
|
will write '19' instead of '\t17' to the whey command.
|
||||||
|
|
||||||
|
Updated calc man page and help/usage file to reflect recent
|
||||||
|
command line changes.
|
||||||
|
|
||||||
|
Converted start_done into a general calc run state enum called
|
||||||
|
run_state within the calc source.
|
||||||
|
|
||||||
|
Removed README.OLD.
|
||||||
|
|
||||||
|
Added the Makefile variable ${LCC} to invoke the local c compiler.
|
||||||
|
By default, ${CC} also run the ${LCC} compiler. The distinction is
|
||||||
|
useful when using something such as purify. In the case of ${LCC},
|
||||||
|
only the local C compiler is invoked. In the case of ${CC} a purify
|
||||||
|
compile is invoked. Only the source that must be compiled and run
|
||||||
|
on the local machine use ${LCC}; everything else uses ${CC}.
|
||||||
|
|
||||||
|
Fixed memory buffer ovreread problem in eatstring() in token.c.
|
||||||
|
|
||||||
|
Fixed memory leaks related to putenv().
|
||||||
|
|
||||||
|
Fixed memory leaks realted to srandom().
|
||||||
|
|
||||||
|
Fixed compilation warnings and problems on BSDI.
|
||||||
|
|
||||||
|
Removed ${CCMAIN} as a variable from the Makefile. Now files
|
||||||
|
use either ${CFLAGS} for general C source and ${ICFLAGS} for
|
||||||
|
intermediate C source (e.g., special code for building hsrc files).
|
||||||
|
|
||||||
|
Misc calc man page fixes.
|
||||||
|
|
||||||
|
|
||||||
Following is the change from calc version 2.11.0t1 to 2.11.0t6.3:
|
Following is the change from calc version 2.11.0t1 to 2.11.0t6.3:
|
||||||
|
|
||||||
|
133
Makefile
133
Makefile
@@ -352,7 +352,7 @@ CALCPAGER= more
|
|||||||
#CALCPAGER= cat
|
#CALCPAGER= cat
|
||||||
#CALCPAGER= less
|
#CALCPAGER= less
|
||||||
|
|
||||||
# Debug/Optimize options for ${CC}
|
# Debug/Optimize options for ${CC} and ${LCC}
|
||||||
#
|
#
|
||||||
#DEBUG= -O
|
#DEBUG= -O
|
||||||
#DEBUG= -O -g
|
#DEBUG= -O -g
|
||||||
@@ -393,7 +393,7 @@ NO_SHARED=
|
|||||||
#NO_SHARED= -non_shared
|
#NO_SHARED= -non_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} 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
|
||||||
#
|
#
|
||||||
@@ -516,13 +516,12 @@ ALLOW_CUSTOM= -DCUSTOM
|
|||||||
# CFLAGS are all flags given to ${CC} [[often includes CCOPT, CCWARN, CCMISC]]
|
# CFLAGS are all flags given to ${CC} [[often includes CCOPT, CCWARN, CCMISC]]
|
||||||
# ICFLAGS are given to ${CC} for intermediate progs
|
# ICFLAGS are given to ${CC} for intermediate progs
|
||||||
#
|
#
|
||||||
# CCMAIN are flags for ${CC} when files with main() instead of CFLAGS
|
|
||||||
#
|
|
||||||
# LCFLAGS are CC-style flags for ${LINT}
|
# LCFLAGS are CC-style flags for ${LINT}
|
||||||
# LDFLAGS are flags given to ${CC} for linking .o files
|
# LDFLAGS are flags given to ${CC} for linking .o files
|
||||||
# ILDFLAGS are flags given to ${CC} for linking .o files for intermediate progs
|
# ILDFLAGS are flags given to ${CC} for linking .o files for intermediate progs
|
||||||
#
|
#
|
||||||
# CC is how the the C compiler is invoked
|
# LCC how the the C compiler is invoked on locally executed intermediate progs
|
||||||
|
# CC is how the the C compiler is invoked (with an optional Purify)
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -540,13 +539,12 @@ CCMISC=
|
|||||||
CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
ICFLAGS= ${CCWARN} ${CCMISC}
|
ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
LCFLAGS=
|
LCFLAGS=
|
||||||
LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
ILDFLAGS=
|
ILDFLAGS=
|
||||||
#
|
#
|
||||||
CC= ${PURIFY} gcc
|
LCC= gcc
|
||||||
|
CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -562,14 +560,13 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} gcc
|
#LCC= gcc
|
||||||
#CC= ${PURIFY} gcc2
|
#LCC= gcc2
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -582,13 +579,12 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc
|
#LCC= cc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -613,13 +609,12 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc -n32 -xansi
|
#LCC= cc -n32 -xansi
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -638,13 +633,12 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc
|
#LCC= cc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -657,13 +651,12 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc
|
#LCC= cc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -682,13 +675,12 @@ CC= ${PURIFY} gcc
|
|||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc
|
#LCC= cc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -702,15 +694,14 @@ CC= ${PURIFY} gcc
|
|||||||
#CCMISC=
|
#CCMISC=
|
||||||
#
|
#
|
||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC} -Wno-unused
|
||||||
#
|
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
#
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} gcc
|
#LCC= gcc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
@@ -724,15 +715,14 @@ CC= ${PURIFY} gcc
|
|||||||
#CCMISC=
|
#CCMISC=
|
||||||
#
|
#
|
||||||
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
#CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
#ICFLAGS= ${CCWARN} ${CCMISC}
|
#ICFLAGS= ${CCWARN} ${CCMISC} -Wno-unused
|
||||||
#
|
|
||||||
#CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
#
|
||||||
#LCFLAGS=
|
#LCFLAGS=
|
||||||
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
#LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
#ILDFLAGS=
|
#ILDFLAGS=
|
||||||
#
|
#
|
||||||
#CC= ${PURIFY} cc
|
#LCC= cc
|
||||||
|
#CC= ${PURIFY} ${LCC}
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
#-=-=-=-=-=-=-=-=- Be careful if you change something below -=-=-=-=-=-=-=-=-#
|
#-=-=-=-=-=-=-=-=- Be careful if you change something below -=-=-=-=-=-=-=-=-#
|
||||||
@@ -887,6 +877,7 @@ CUSTOM_PASSDOWN= Q="${Q}" \
|
|||||||
LCFLAGS="${LCFLAGS}" \
|
LCFLAGS="${LCFLAGS}" \
|
||||||
LDFLAGS="${LDFLAGS}" \
|
LDFLAGS="${LDFLAGS}" \
|
||||||
ILDFLAGS="${ILDFLAGS}" \
|
ILDFLAGS="${ILDFLAGS}" \
|
||||||
|
LCC="${LCC}" \
|
||||||
CC="${CC}" \
|
CC="${CC}" \
|
||||||
MAKE_FILE=${MAKE_FILE} \
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
SED=${SED} \
|
SED=${SED} \
|
||||||
@@ -909,11 +900,11 @@ SAMPLE_PASSDOWN= Q="${Q}" \
|
|||||||
CCMISC="${CCMISC}" \
|
CCMISC="${CCMISC}" \
|
||||||
CFLAGS="${CFLAGS} ${ALLOW_CUSTOM}" \
|
CFLAGS="${CFLAGS} ${ALLOW_CUSTOM}" \
|
||||||
ICFLAGS="${ICFLAGS}" \
|
ICFLAGS="${ICFLAGS}" \
|
||||||
CCMAIN="${CCMAIN}" \
|
|
||||||
LCFLAGS="${LCFLAGS}" \
|
LCFLAGS="${LCFLAGS}" \
|
||||||
LDFLAGS="${LDFLAGS}" \
|
LDFLAGS="${LDFLAGS}" \
|
||||||
ILDFLAGS="${ILDFLAGS}" \
|
ILDFLAGS="${ILDFLAGS}" \
|
||||||
CALC_LIBS="../libcalc.a ../custom/libcustcalc.a" \
|
CALC_LIBS="../libcalc.a ../custom/libcustcalc.a" \
|
||||||
|
LCC="${LCC}" \
|
||||||
CC="${CC}" \
|
CC="${CC}" \
|
||||||
MAKE_FILE=${MAKE_FILE} \
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
SED=${SED} \
|
SED=${SED} \
|
||||||
@@ -931,7 +922,7 @@ 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 README.OLD HOWTO.INSTALL ${UTIL_MISC_SRC}
|
calc.man lint.sed HOWTO.INSTALL ${UTIL_MISC_SRC}
|
||||||
|
|
||||||
# complete list of .o files
|
# complete list of .o files
|
||||||
#
|
#
|
||||||
@@ -981,7 +972,7 @@ calc.1: calc.man ${MAKE_FILE}
|
|||||||
##
|
##
|
||||||
|
|
||||||
calc.o: calc.c ${MAKE_FILE}
|
calc.o: calc.c ${MAKE_FILE}
|
||||||
${CC} ${CCMAIN} ${CCOPT} ${ALLOW_CUSTOM} -c calc.c
|
${CC} ${CFLAGS} ${CCOPT} ${ALLOW_CUSTOM} -c calc.c
|
||||||
|
|
||||||
custom.o: custom.c ${MAKE_FILE}
|
custom.o: custom.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
||||||
@@ -1379,8 +1370,8 @@ longlong.h: longlong.c have_stdlib.h have_string.h ${MAKE_FILE}
|
|||||||
${Q}echo '' >> longlong.h
|
${Q}echo '' >> longlong.h
|
||||||
${Q}echo '/* do we have/want to use a long long type? */' >> longlong.h
|
${Q}echo '/* do we have/want to use a long long type? */' >> longlong.h
|
||||||
-${Q}rm -f longlong.o longlong
|
-${Q}rm -f longlong.o longlong
|
||||||
-${Q}${CC} ${CCMAIN} longlong.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} longlong.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} longlong.o -o longlong 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} longlong.o -o longlong 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./longlong ${LONGLONG_BITS} > ll_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./longlong ${LONGLONG_BITS} > ll_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s ll_tmp ]; then \
|
-${Q}if [ -s ll_tmp ]; then \
|
||||||
@@ -1418,8 +1409,8 @@ have_fpos.h: have_fpos.c ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_fpos.h
|
${Q}echo '' >> have_fpos.h
|
||||||
${Q}echo '/* do we have fgetpos & fsetpos functions? */' >> have_fpos.h
|
${Q}echo '/* do we have fgetpos & fsetpos functions? */' >> have_fpos.h
|
||||||
-${Q}rm -f have_fpos.o have_fpos
|
-${Q}rm -f have_fpos.o have_fpos
|
||||||
-${Q}${CC} ${HAVE_FPOS} ${CCMAIN} have_fpos.c -c 2>/dev/null; true
|
-${Q}${LCC} ${HAVE_FPOS} ${ICFLAGS} have_fpos.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_fpos.o -o have_fpos 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_fpos.o -o have_fpos 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_fpos > fpos_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_fpos > fpos_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s fpos_tmp ]; then \
|
-${Q}if [ -s fpos_tmp ]; then \
|
||||||
@@ -1459,8 +1450,8 @@ fposval.h: fposval.c have_fpos.h have_offscl.h have_posscl.h \
|
|||||||
${Q}echo '' >> fposval.h
|
${Q}echo '' >> fposval.h
|
||||||
${Q}echo '/* what are our file position & size types? */' >> fposval.h
|
${Q}echo '/* what are our file position & size types? */' >> fposval.h
|
||||||
-${Q}rm -f fposval.o fposval
|
-${Q}rm -f fposval.o fposval
|
||||||
-${Q}${CC} ${CCMAIN} fposval.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} fposval.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} fposval.o -o fposval 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} fposval.o -o fposval 2>/dev/null; true
|
||||||
${Q}${SHELL} -c "./fposval fposv_tmp >> fposval.h 2>/dev/null" \
|
${Q}${SHELL} -c "./fposval fposv_tmp >> fposval.h 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
${Q}echo '' >> fposval.h
|
${Q}echo '' >> fposval.h
|
||||||
@@ -1492,8 +1483,8 @@ have_const.h: have_const.c ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_const.h
|
${Q}echo '' >> have_const.h
|
||||||
${Q}echo '/* do we have or want const? */' >> have_const.h
|
${Q}echo '/* do we have or want const? */' >> have_const.h
|
||||||
-${Q}rm -f have_const.o have_const
|
-${Q}rm -f have_const.o have_const
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_CONST} have_const.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_CONST} have_const.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_const.o -o have_const 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_const.o -o have_const 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_const > const_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_const > const_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s const_tmp ]; then \
|
-${Q}if [ -s const_tmp ]; then \
|
||||||
@@ -1531,8 +1522,8 @@ have_offscl.h: have_offscl.c ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_offscl.h
|
${Q}echo '' >> have_offscl.h
|
||||||
${Q}echo '' >> have_offscl.h
|
${Q}echo '' >> have_offscl.h
|
||||||
-${Q}rm -f have_offscl.o have_offscl
|
-${Q}rm -f have_offscl.o have_offscl
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_OFFSCL} have_offscl.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_OFFSCL} have_offscl.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_offscl.o -o have_offscl 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_offscl.o -o have_offscl 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_offscl > offscl_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_offscl > offscl_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s offscl_tmp ]; then \
|
-${Q}if [ -s offscl_tmp ]; then \
|
||||||
@@ -1569,8 +1560,8 @@ have_posscl.h: have_posscl.c have_fpos.h ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_posscl.h
|
${Q}echo '' >> have_posscl.h
|
||||||
${Q}echo '' >> have_posscl.h
|
${Q}echo '' >> have_posscl.h
|
||||||
-${Q}rm -f have_posscl.o have_posscl
|
-${Q}rm -f have_posscl.o have_posscl
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_POSSCL} have_posscl.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_POSSCL} have_posscl.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_posscl.o -o have_posscl 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_posscl.o -o have_posscl 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_posscl > posscl_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_posscl > posscl_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s posscl_tmp ]; then \
|
-${Q}if [ -s posscl_tmp ]; then \
|
||||||
@@ -1621,8 +1612,8 @@ align32.h: align32.c longbits.h have_unistd.h ${MAKE_FILE}
|
|||||||
fi
|
fi
|
||||||
-${Q}if [ X = X${ALIGN32} ]; then \
|
-${Q}if [ X = X${ALIGN32} ]; then \
|
||||||
rm -f align32.o align32; \
|
rm -f align32.o align32; \
|
||||||
${CC} ${CCMAIN} ${ALIGN32} align32.c -c 2>/dev/null; \
|
${LCC} ${ICFLAGS} ${ALIGN32} align32.c -c 2>/dev/null; \
|
||||||
${CC} ${ILDFLAGS} align32.o -o align32 2>/dev/null; \
|
${LCC} ${ILDFLAGS} align32.o -o align32 2>/dev/null; \
|
||||||
${SHELL} -c "./align32 >align32_tmp 2>/dev/null" >/dev/null 2>&1; \
|
${SHELL} -c "./align32 >align32_tmp 2>/dev/null" >/dev/null 2>&1; \
|
||||||
if [ -s align32_tmp ]; then \
|
if [ -s align32_tmp ]; then \
|
||||||
cat align32_tmp >> align32.h; \
|
cat align32_tmp >> align32.h; \
|
||||||
@@ -1662,8 +1653,8 @@ have_uid_t.h: have_uid_t.c have_unistd.h ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_uid_t.h
|
${Q}echo '' >> have_uid_t.h
|
||||||
${Q}echo '/* do we have or want uid_t? */' >> have_uid_t.h
|
${Q}echo '/* do we have or want uid_t? */' >> have_uid_t.h
|
||||||
-${Q}rm -f have_uid_t.o have_uid_t
|
-${Q}rm -f have_uid_t.o have_uid_t
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_UID_T} have_uid_t.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_UID_T} have_uid_t.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_uid_t.o -o have_uid_t 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_uid_t.o -o have_uid_t 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_uid_t > uid_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_uid_t > uid_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s uid_tmp ]; then \
|
-${Q}if [ -s uid_tmp ]; then \
|
||||||
@@ -1701,8 +1692,8 @@ have_newstr.h: have_newstr.c ${MAKE_FILE}
|
|||||||
${Q}echo '/* do we have or want memcpy(), memset() & strchr()? */' \
|
${Q}echo '/* do we have or want memcpy(), memset() & strchr()? */' \
|
||||||
>> have_newstr.h
|
>> have_newstr.h
|
||||||
-${Q}rm -f have_newstr.o have_newstr
|
-${Q}rm -f have_newstr.o have_newstr
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_NEWSTR} have_newstr.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_NEWSTR} have_newstr.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_newstr.o -o have_newstr 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_newstr.o -o have_newstr 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_newstr > newstr_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_newstr > newstr_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s newstr_tmp ]; then \
|
-${Q}if [ -s newstr_tmp ]; then \
|
||||||
@@ -1739,8 +1730,8 @@ have_memmv.h: have_memmv.c ${MAKE_FILE}
|
|||||||
${Q}echo '' >> have_memmv.h
|
${Q}echo '' >> have_memmv.h
|
||||||
${Q}echo '/* do we have or want memmove()? */' >> have_memmv.h
|
${Q}echo '/* do we have or want memmove()? */' >> have_memmv.h
|
||||||
-${Q}rm -f have_memmv.o have_memmv
|
-${Q}rm -f have_memmv.o have_memmv
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_MEMMOVE} have_memmv.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_MEMMOVE} have_memmv.c -c 2>/dev/null; true
|
||||||
-${Q}${CC} ${ILDFLAGS} have_memmv.o -o have_memmv 2>/dev/null; true
|
-${Q}${LCC} ${ILDFLAGS} have_memmv.o -o have_memmv 2>/dev/null; true
|
||||||
-${Q}${SHELL} -c "./have_memmv > newstr_tmp 2>/dev/null" \
|
-${Q}${SHELL} -c "./have_memmv > newstr_tmp 2>/dev/null" \
|
||||||
>/dev/null 2>&1; true
|
>/dev/null 2>&1; true
|
||||||
-${Q}if [ -s newstr_tmp ]; then \
|
-${Q}if [ -s newstr_tmp ]; then \
|
||||||
@@ -1776,8 +1767,9 @@ args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
|||||||
${Q}echo '' >> args.h
|
${Q}echo '' >> args.h
|
||||||
${Q}echo '' >> args.h
|
${Q}echo '' >> args.h
|
||||||
-${Q}rm -f have_stdvs.o have_stdvs
|
-${Q}rm -f have_stdvs.o have_stdvs
|
||||||
-${Q}${CC} ${CCMAIN} ${HAVE_VSPRINTF} have_stdvs.c -c 2>/dev/null; true
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_VSPRINTF} have_stdvs.c -c \
|
||||||
-${Q}${CC} ${ILDFLAGS} have_stdvs.o -o have_stdvs 2>/dev/null; true
|
2>/dev/null; true
|
||||||
|
-${Q}${LCC} ${ILDFLAGS} have_stdvs.o -o have_stdvs 2>/dev/null; true
|
||||||
-${Q}if ./have_stdvs >>args.h 2>/dev/null; then \
|
-${Q}if ./have_stdvs >>args.h 2>/dev/null; then \
|
||||||
touch have_args; \
|
touch have_args; \
|
||||||
else \
|
else \
|
||||||
@@ -1785,8 +1777,9 @@ args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
|||||||
fi
|
fi
|
||||||
-${Q}if [ ! -f have_args ] && [ X"${HAVE_VSPRINTF}" = X ]; then \
|
-${Q}if [ ! -f have_args ] && [ X"${HAVE_VSPRINTF}" = X ]; then \
|
||||||
rm -f have_stdvs.o have_stdvs have_varvs.o have_varvs; \
|
rm -f have_stdvs.o have_stdvs have_varvs.o have_varvs; \
|
||||||
${CC} ${CCMAIN} -DDONT_HAVE_VSPRINTF have_varvs.c -c 2>/dev/null; \
|
${LCC} ${ICFLAGS} -DDONT_HAVE_VSPRINTF have_varvs.c -c \
|
||||||
${CC} ${ILDFLAGS} have_varvs.o -o have_varvs 2>/dev/null; \
|
2>/dev/null; \
|
||||||
|
${LCC} ${ILDFLAGS} have_varvs.o -o have_varvs 2>/dev/null; \
|
||||||
if ./have_varvs >>args.h 2>/dev/null; then \
|
if ./have_varvs >>args.h 2>/dev/null; then \
|
||||||
touch have_args; \
|
touch have_args; \
|
||||||
else \
|
else \
|
||||||
@@ -1865,17 +1858,17 @@ calc_errno.h: calc_errno.c ${MAKE_FILE}
|
|||||||
echo 'extern int sys_nerr; ' \
|
echo 'extern int sys_nerr; ' \
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
'/* number of system errors */' >> calc_errno.h; \
|
||||||
else \
|
else \
|
||||||
${CC} ${CCMAIN} -DTRY_ERRNO_NO_DECL \
|
${LCC} ${ICFLAGS} -DTRY_ERRNO_NO_DECL \
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
||||||
if [ -x ./calc_errno ]; then \
|
if [ -x ./calc_errno ]; then \
|
||||||
./calc_errno >> calc_errno.h; \
|
./calc_errno >> calc_errno.h; \
|
||||||
else \
|
else \
|
||||||
${CC} ${CCMAIN} -DTRY_ERRNO_STD_DECL \
|
${LCC} ${ICFLAGS} -DTRY_ERRNO_STD_DECL \
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
||||||
if [ -x ./calc_errno ]; then \
|
if [ -x ./calc_errno ]; then \
|
||||||
./calc_errno >> calc_errno.h; \
|
./calc_errno >> calc_errno.h; \
|
||||||
else \
|
else \
|
||||||
${CC} ${CCMAIN} -DTRY_ERRNO_OLD_DECL \
|
${LCC} ${ICFLAGS} -DTRY_ERRNO_OLD_DECL \
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
||||||
if [ -x ./calc_errno ]; then \
|
if [ -x ./calc_errno ]; then \
|
||||||
./calc_errno >> calc_errno.h; \
|
./calc_errno >> calc_errno.h; \
|
||||||
@@ -1971,16 +1964,16 @@ calcerr.c: calcerr.tbl calcerr_c.sed calcerr_c.awk ${MAKE_FILE}
|
|||||||
##
|
##
|
||||||
|
|
||||||
endian.o: endian.c have_unistd.h
|
endian.o: endian.c have_unistd.h
|
||||||
${CC} ${CCMAIN} endian.c -c
|
${LCC} ${ICFLAGS} endian.c -c
|
||||||
|
|
||||||
endian: endian.o
|
endian: endian.o
|
||||||
${CC} ${ILDFLAGS} endian.o -o endian
|
${LCC} ${ICFLAGS} endian.o -o endian
|
||||||
|
|
||||||
longbits.o: longbits.c longlong.h have_unistd.h
|
longbits.o: longbits.c longlong.h have_unistd.h
|
||||||
${CC} ${CCMAIN} longbits.c -c
|
${LCC} ${ICFLAGS} longbits.c -c
|
||||||
|
|
||||||
longbits: longbits.o
|
longbits: longbits.o
|
||||||
${CC} ${ILDFLAGS} longbits.o -o longbits
|
${LCC} ${ICFLAGS} longbits.o -o longbits
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -2332,10 +2325,10 @@ env:
|
|||||||
@echo "CCMISC=${CCMISC}"; echo ""
|
@echo "CCMISC=${CCMISC}"; echo ""
|
||||||
@echo "CFLAGS=${CFLAGS}"; echo ""
|
@echo "CFLAGS=${CFLAGS}"; echo ""
|
||||||
@echo "ICFLAGS=${ICFLAGS}"; echo ""
|
@echo "ICFLAGS=${ICFLAGS}"; echo ""
|
||||||
@echo "CCMAIN=${CCMAIN}"; echo ""
|
|
||||||
@echo "LCFLAGS=${LCFLAGS}"; echo ""
|
@echo "LCFLAGS=${LCFLAGS}"; echo ""
|
||||||
@echo "LDFLAGS=${LDFLAGS}"; echo ""
|
@echo "LDFLAGS=${LDFLAGS}"; echo ""
|
||||||
@echo "ILDFLAGS=${ILDFLAGS}"; echo ""
|
@echo "ILDFLAGS=${ILDFLAGS}"; echo ""
|
||||||
|
@echo "LCC=${LCC}"; echo ""
|
||||||
@echo "CC=${CC}"; echo ""
|
@echo "CC=${CC}"; echo ""
|
||||||
@echo "SHELL=${SHELL}"; echo ""
|
@echo "SHELL=${SHELL}"; echo ""
|
||||||
@echo "MAKE=${MAKE}"; echo ""
|
@echo "MAKE=${MAKE}"; echo ""
|
||||||
|
73
README.OLD
73
README.OLD
@@ -1,73 +0,0 @@
|
|||||||
# Copyright (c) 1997 David I. Bell
|
|
||||||
# Permission is granted to use, distribute, or modify this source,
|
|
||||||
# provided that this copyright notice remains intact.
|
|
||||||
#
|
|
||||||
# Arbitrary precision calculator.
|
|
||||||
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
NOTE: This is an old historic README. We recommend that
|
|
||||||
you read README and HOWTO.INSTALL for more info.
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
I am allowing this calculator to be freely distributed for your enjoyment.
|
|
||||||
Like all multi-precision programs, you should not depend absolutely on
|
|
||||||
its results, since bugs in such programs can be insidious and only rarely
|
|
||||||
show up.
|
|
||||||
|
|
||||||
-dbell-
|
|
||||||
|
|
||||||
p.s. By Landon Curt Noll:
|
|
||||||
|
|
||||||
Building calc in 3 easy steps:
|
|
||||||
|
|
||||||
1) Look at the makefile, and adjust it to suit your needs.
|
|
||||||
|
|
||||||
Here are some Makefile hints:
|
|
||||||
|
|
||||||
In the past, some people have had to adjust the VARARG or
|
|
||||||
TERMCONTROL because the Makefile cannot always guess
|
|
||||||
correctly for certain systems. You may need to play with
|
|
||||||
these values if you experience problems.
|
|
||||||
|
|
||||||
The default compiler used is 'cc'. The default compiler flag
|
|
||||||
is '-O'. If you have gcc, or gcc v2 (or better) you should use
|
|
||||||
that instead. Some compilers allow for optimization beyond
|
|
||||||
just -O (gcc v2 has -O2, mips cc has -O3). You should select
|
|
||||||
the best flag for speed optimization. Calc can be cpu intensive
|
|
||||||
so selecting a quality compiler and good optimization level can
|
|
||||||
really pay off.
|
|
||||||
|
|
||||||
2) build calc:
|
|
||||||
|
|
||||||
make all
|
|
||||||
|
|
||||||
3) test calc:
|
|
||||||
|
|
||||||
make check
|
|
||||||
|
|
||||||
==>>>If you run into problems, follow the instructions in the BUGS file<<<==
|
|
||||||
|
|
||||||
=-=
|
|
||||||
|
|
||||||
For further reading:
|
|
||||||
|
|
||||||
LIBRARY
|
|
||||||
explains how programs can use libcalc.a to take advantage
|
|
||||||
of the calc multi-precision routines.
|
|
||||||
|
|
||||||
help/todo
|
|
||||||
current wish list for calc
|
|
||||||
|
|
||||||
CHANGES
|
|
||||||
recent changes to calc
|
|
||||||
|
|
||||||
BUGS
|
|
||||||
known bugs, mis-features and how to report problems
|
|
||||||
|
|
||||||
help/full
|
|
||||||
full set of calc documentation
|
|
||||||
|
|
||||||
=-=
|
|
||||||
|
|
||||||
David I. Bell dbell@auug.org.au
|
|
||||||
chongo <Landon Curt Noll> /\../\
|
|
96
calc.c
96
calc.c
@@ -11,7 +11,6 @@
|
|||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <setjmp.h>
|
|
||||||
|
|
||||||
#define CALC_C
|
#define CALC_C
|
||||||
#include "calc.h"
|
#include "calc.h"
|
||||||
@@ -37,40 +36,13 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* external definitions and functions
|
|
||||||
*/
|
|
||||||
extern int abortlevel; /* current level of aborts */
|
|
||||||
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
|
||||||
extern jmp_buf jmpbuf; /* for errors */
|
|
||||||
extern int isatty(int tty); /* TRUE if fd is a tty */
|
|
||||||
|
|
||||||
extern int p_flag; /* TRUE => pipe mode */
|
|
||||||
extern int q_flag; /* TRUE => don't execute rc files */
|
|
||||||
extern int u_flag; /* TRUE => unbuffer stdin and stdout */
|
|
||||||
extern int d_flag; /* TRUE => disable heading, lib_debug == 0 */
|
|
||||||
extern int stoponerror; /* >0 => stop, <0 => continue, ==0 => use -c */
|
|
||||||
|
|
||||||
extern char *pager; /* $PAGER or default */
|
|
||||||
extern int stdin_tty; /* TRUE if stdin is a tty */
|
|
||||||
extern int interactive; /* TRUE if interactive session (no cmd args) */
|
|
||||||
extern char *program; /* our name */
|
|
||||||
extern char cmdbuf[]; /* command line expression */
|
|
||||||
|
|
||||||
extern char *version(void); /* return version string */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* static definitions and functions
|
* static definitions and functions
|
||||||
*/
|
*/
|
||||||
static char *usage = "usage: %s [-C] [-e] [-h] [-i] [-m mode] [-n] [-p]\n"
|
static char *usage = "usage: %s [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]\n"
|
||||||
"\t[-q] [-u] [-c] [-d] [[--] calc_cmd ...]\n";
|
"\t[-n] [-p] [-q] [-u] [-v] [[--] calc_cmd ...]\n";
|
||||||
static void intint(int arg); /* interrupt routine */
|
static void intint(int arg); /* interrupt routine */
|
||||||
|
|
||||||
static int havecommands;
|
|
||||||
static int c_flag; /* To permit continuation after error */
|
|
||||||
static int i_flag; /* To go interactive if permitted */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Top level calculator routine.
|
* Top level calculator routine.
|
||||||
@@ -163,8 +135,7 @@ main(int argc, char **argv)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
interactive = (optind >= argc);
|
havecommands = (optind < argc);
|
||||||
havecommands = !interactive;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* look at the length of any trailing command args
|
* look at the length of any trailing command args
|
||||||
@@ -258,69 +229,73 @@ main(int argc, char **argv)
|
|||||||
post_init = TRUE;
|
post_init = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* (re)establish the interrupt handler
|
||||||
|
*/
|
||||||
(void) signal(SIGINT, intint);
|
(void) signal(SIGINT, intint);
|
||||||
|
|
||||||
if (start_done == 0) {
|
/*
|
||||||
|
* execute calc code based on the run state
|
||||||
|
*/
|
||||||
|
if (run_state == RUN_PRE_BEGIN) {
|
||||||
if (!q_flag && allow_read) {
|
if (!q_flag && allow_read) {
|
||||||
start_done = 1;
|
run_state = RUN_PRE_RCFILES;
|
||||||
runrcfiles();
|
runrcfiles();
|
||||||
}
|
}
|
||||||
start_done = 2;
|
run_state = RUN_POST_RCFILES;
|
||||||
}
|
}
|
||||||
if (start_done == 1) {
|
if (run_state == RUN_PRE_RCFILES) {
|
||||||
fprintf(stderr, "Execution error in rcfiles\n");
|
fprintf(stderr, "Execution error in rcfiles\n");
|
||||||
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
start_done = 2;
|
run_state = RUN_POST_RCFILES;
|
||||||
} else {
|
} else {
|
||||||
if ((havecommands && !i_flag) || !stdin_tty)
|
if ((havecommands && !i_flag) || !stdin_tty)
|
||||||
start_done = 7;
|
run_state = RUN_STOP_ON_ERROR;
|
||||||
else if (havecommands)
|
else if (havecommands)
|
||||||
start_done = 4;
|
run_state = RUN_POST_CMD_ARGS;
|
||||||
else
|
else
|
||||||
start_done = 2;
|
run_state = RUN_POST_RCFILES;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (start_done == 2) {
|
if (run_state == RUN_POST_RCFILES) {
|
||||||
if (havecommands) {
|
if (havecommands) {
|
||||||
start_done = 3;
|
run_state = RUN_PRE_CMD_ARGS;
|
||||||
(void) openstring(cmdbuf);
|
(void) openstring(cmdbuf);
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
}
|
}
|
||||||
start_done = 4;
|
run_state = RUN_POST_CMD_ARGS;
|
||||||
}
|
}
|
||||||
if (start_done == 3) {
|
if (run_state == RUN_PRE_CMD_ARGS) {
|
||||||
fprintf(stderr, "Execution error in commands\n");
|
fprintf(stderr, "Execution error in commands\n");
|
||||||
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
start_done = 4;
|
run_state = RUN_POST_CMD_ARGS;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
closeinput();
|
closeinput();
|
||||||
if (!stdin_tty || !i_flag)
|
if (!stdin_tty || !i_flag)
|
||||||
start_done = 7;
|
run_state = RUN_STOP_ON_ERROR;
|
||||||
else
|
else
|
||||||
start_done = 4;
|
run_state = RUN_POST_CMD_ARGS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (start_done == 4) {
|
if (run_state == RUN_POST_CMD_ARGS) {
|
||||||
if (stdin_tty && ((havecommands && !i_flag) || p_flag))
|
if (stdin_tty && ((havecommands && !i_flag) || p_flag))
|
||||||
start_done = 6;
|
run_state = RUN_NOT_TOP_LEVEL;
|
||||||
else
|
else
|
||||||
openterminal();
|
openterminal();
|
||||||
}
|
} else if (run_state == RUN_TOP_LEVEL) {
|
||||||
else if (start_done == 5) {
|
if (!stdin_tty && (!c_flag || stoponerror) &&
|
||||||
if (!stdin_tty && (!c_flag || stoponerror) && stoponerror >= 0) {
|
stoponerror >= 0) {
|
||||||
start_done = 7;
|
run_state = RUN_STOP_ON_ERROR;
|
||||||
}
|
} else if ((c_flag && !stoponerror) || stoponerror < 0)
|
||||||
else if ((c_flag && !stoponerror) || stoponerror < 0)
|
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
else
|
else
|
||||||
reinitialize();
|
reinitialize();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (start_done < 6) {
|
if (run_state < RUN_NOT_TOP_LEVEL) {
|
||||||
start_done = 5;
|
run_state = RUN_TOP_LEVEL;
|
||||||
getcommands(TRUE);
|
getcommands(TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -328,7 +303,8 @@ main(int argc, char **argv)
|
|||||||
* all done
|
* all done
|
||||||
*/
|
*/
|
||||||
libcalc_call_me_last();
|
libcalc_call_me_last();
|
||||||
return (start_done - 6) ? 1 : 0;
|
return (run_state == RUN_STOP_ON_ERROR ||
|
||||||
|
run_state == RUN_UNKNOWN) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
44
calc.h
44
calc.h
@@ -10,6 +10,7 @@
|
|||||||
#if !defined(__CALC_H__)
|
#if !defined(__CALC_H__)
|
||||||
#define __CALC_H__
|
#define __CALC_H__
|
||||||
|
|
||||||
|
#include <setjmp.h>
|
||||||
|
|
||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
|
||||||
@@ -126,7 +127,6 @@ extern long linenumber(void);
|
|||||||
extern void runrcfiles(void);
|
extern void runrcfiles(void);
|
||||||
extern void closeinput(void);
|
extern void closeinput(void);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Other routines.
|
* Other routines.
|
||||||
*/
|
*/
|
||||||
@@ -140,21 +140,39 @@ extern void libcalc_call_me_first(void);
|
|||||||
extern void libcalc_call_me_last(void);
|
extern void libcalc_call_me_last(void);
|
||||||
extern void showerrors(void);
|
extern void showerrors(void);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialization
|
* Initialization
|
||||||
*/
|
*/
|
||||||
extern void initialize(void);
|
extern void initialize(void);
|
||||||
extern void reinitialize(void);
|
extern void reinitialize(void);
|
||||||
|
extern int isatty(int tty); /* TRUE if fd is a tty */
|
||||||
|
extern char *version(void); /* return version string */
|
||||||
|
extern int post_init; /* TRUE => setjmp for math_error is ready */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Global data definitions.
|
* global flags and definitions
|
||||||
*/
|
*/
|
||||||
|
extern int abortlevel; /* current level of aborts */
|
||||||
|
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
|
extern jmp_buf jmpbuf; /* for errors */
|
||||||
|
|
||||||
|
extern int p_flag; /* TRUE => pipe mode */
|
||||||
|
extern int q_flag; /* TRUE => don't execute rc files */
|
||||||
|
extern int u_flag; /* TRUE => unbuffer stdin and stdout */
|
||||||
|
extern int d_flag; /* TRUE => disable heading, lib_debug == 0 */
|
||||||
|
extern int c_flag; /* TRUE => continue after error if permitted */
|
||||||
|
extern int i_flag; /* TRUE => try to go interactive after error */
|
||||||
|
extern int stoponerror; /* >0 => stop, <0 => continue, ==0 => use -c */
|
||||||
|
|
||||||
|
extern char *pager; /* $PAGER or default */
|
||||||
|
extern int stdin_tty; /* TRUE if stdin is a tty */
|
||||||
|
extern int havecommands; /* TRUE if have cmd args) */
|
||||||
|
extern char *program; /* our name */
|
||||||
|
extern char cmdbuf[]; /* command line expression */
|
||||||
|
|
||||||
extern int abortlevel; /* current level of aborts */
|
extern int abortlevel; /* current level of aborts */
|
||||||
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
extern VALUE *stack; /* execution stack */
|
extern VALUE *stack; /* execution stack */
|
||||||
extern int start_done; /* TRUE => start up processing finished */
|
|
||||||
extern int dumpnames; /* TRUE => dump names rather than indices */
|
extern int dumpnames; /* TRUE => dump names rather than indices */
|
||||||
|
|
||||||
extern char *calcpath; /* $CALCPATH or default */
|
extern char *calcpath; /* $CALCPATH or default */
|
||||||
@@ -172,7 +190,21 @@ 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 */
|
||||||
|
|
||||||
extern int post_init; /* TRUE => setjmp for math_error is ready */
|
/*
|
||||||
|
* calc startup and run state
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
RUN_UNKNOWN = -1, /* unknown or unset start state */
|
||||||
|
RUN_PRE_BEGIN = 0, /* pre-startup state, calc execution started */
|
||||||
|
RUN_PRE_RCFILES = 1, /* rc files about to or are being evaluated */
|
||||||
|
RUN_POST_RCFILES = 2, /* rc files have been evaluated */
|
||||||
|
RUN_PRE_CMD_ARGS = 3, /* cmd_args about to or are being evaluated */
|
||||||
|
RUN_POST_CMD_ARGS = 4, /* cmd_args have been evaluated */
|
||||||
|
RUN_TOP_LEVEL = 5, /* running at the top interactive level */
|
||||||
|
RUN_NOT_TOP_LEVEL = 6, /* running not at the top interactive level */
|
||||||
|
RUN_STOP_ON_ERROR = 7 /* we need to stop due to errors */
|
||||||
|
} run;
|
||||||
|
extern run run_state;
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
535
calc.man
535
calc.man
@@ -1,190 +1,356 @@
|
|||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 1994 David I. Bell and Landon Curt Noll
|
.\" Copyright (c) 1993 David I. Bell and Landon Curt Noll
|
||||||
|
.\" Original man page dated 15nov93
|
||||||
|
.\" Copyright (c) 1999 David I. Bell and Landon Curt Noll
|
||||||
.\" Permission is granted to use, distribute, or modify this source,
|
.\" Permission is granted to use, distribute, or modify this source,
|
||||||
.\" provided that this copyright notice remains intact.
|
.\" provided that this copyright notice remains intact.
|
||||||
.\"
|
.\"
|
||||||
.\" calculator by David I. Bell
|
.\" calculator by David I. Bell
|
||||||
.\" man page by Landon Noll
|
.\" man page by Landon Noll
|
||||||
.TH calc 1 "^..^" "15nov93"
|
.TH calc 1 "^..^" "15Oct1999"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
calc \- arbitrary precision calculator
|
calc \- arbitrary precision calculator
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
\fIcalc\fP
|
\fIcalc\fP
|
||||||
[\fI\-h\fP]
|
.RB [ \-c ]
|
||||||
[\fI\-m mode\fP]
|
.RB [ \-C ]
|
||||||
[\fI\-p\fP]
|
.RB [ \-d ]
|
||||||
[\fI\-q\fP]
|
.RB [ \-e ]
|
||||||
[\fI\-u\fP]
|
.RB [ \-h ]
|
||||||
[\fI\-v\fP]
|
.RB [ \-i ]
|
||||||
[\fIcalc_cmd \&.\|.\|.\fp]
|
.RB [ \-m\ \&mode ]
|
||||||
|
.br
|
||||||
|
.in +5n
|
||||||
|
.RB [ \-n ]
|
||||||
|
.RB [ \-p ]
|
||||||
|
.RB [ \-q ]
|
||||||
|
.RB [ \-u ]
|
||||||
|
.RB [ \-v ]
|
||||||
|
.RB [ calc_cmd\ \&.\|.\|. ]
|
||||||
|
.in -5n
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
\&
|
\&
|
||||||
.br
|
.br
|
||||||
CALC COMMAND LINE
|
CALC COMMAND LINE
|
||||||
.PP
|
.PP
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI\-h\fP
|
.B \-c
|
||||||
Print a help message.
|
Continue reading command lines even after an execution
|
||||||
This option implies \fI \-q\fP.
|
error has caused the abandonment of a line.
|
||||||
This is equivalent to the calc command \fIhelp help\fP.
|
.sp 1
|
||||||
The help facility is disabled unless the \fImode\fP is 5 or 7.
|
For example:
|
||||||
See \fI\-m\fP below.
|
.sp 1
|
||||||
.sp
|
.in +5n
|
||||||
.TP
|
|
||||||
\fI\-m mode\fP
|
|
||||||
This flag sets the permission mode of calc.
|
|
||||||
It controls the ability for \fIcalc\fP to open files
|
|
||||||
and execute programs.
|
|
||||||
\fIMode\fP may be a number from 0 to 7.
|
|
||||||
.sp
|
|
||||||
The \fImode\fP value is interpreted in a way similar
|
|
||||||
to that of the \fRchmod(1)\fP octal mode:
|
|
||||||
.sp
|
|
||||||
.in +0.5i
|
|
||||||
.nf
|
.nf
|
||||||
0 do not open any file, do not execute progs
|
calc read many_errors.cal
|
||||||
1 do not open any file
|
|
||||||
2 do not open files for reading, do not execute progs
|
|
||||||
3 do not open files for reading
|
|
||||||
4 do not open files for writing, do not execute progs
|
|
||||||
5 do not open files for writing
|
|
||||||
6 do not execute any program
|
|
||||||
7 allow everything (default mode)
|
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
If one wished to run calc from a privledged user, one might
|
will cause
|
||||||
want to use \fI\-m 0\fP in an effort to make calc more secure.
|
.B calc
|
||||||
.sp
|
to abort on the first error, whereas:
|
||||||
\fIMode\fP bits for reading and writing apply only on an open.
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -c read many_errors.cal
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will
|
||||||
|
cause
|
||||||
|
.B calc
|
||||||
|
to try to process each line being read
|
||||||
|
despite the errors that it encounters.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-C
|
||||||
|
Permit the execution of custom builtin functions. Without
|
||||||
|
this flag, calling the custom() builtin function will
|
||||||
|
simply generate an error.
|
||||||
|
.sp 1
|
||||||
|
Use if this flag may cause
|
||||||
|
.B calc
|
||||||
|
to execute functions that
|
||||||
|
are non-standard and that are not portable. Custom builtin
|
||||||
|
functions are disabled by default for this reason.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-d
|
||||||
|
Disable the printing of the opening title. The printing
|
||||||
|
of library debug and informational messages is also disabled
|
||||||
|
as if \fBconfig("lib_debug", 0)\fP had been executed.
|
||||||
|
.sp 1
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
calc 'read qtime; qtime(2)'
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will output something like:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
qtime(utc_hr_offset) defined
|
||||||
|
It's nearly ten past six.
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
whereas:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -d 'read qtime; qtime(2)'
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will just say:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
It's nearly ten past six.
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-e
|
||||||
|
Ignore any environment variables on startup.
|
||||||
|
The getenv() builtin will still return values, however.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-h
|
||||||
|
Print a help message. This option implies
|
||||||
|
.BR \-q .
|
||||||
|
This
|
||||||
|
is equivalent to the
|
||||||
|
.B calc
|
||||||
|
command help help.
|
||||||
|
The help facility is disabled unless the mode is 5 or 7.
|
||||||
|
See
|
||||||
|
.BR \-m .
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-i
|
||||||
|
Become interactive if possible.
|
||||||
|
Be default, if
|
||||||
|
.I calc_cmd
|
||||||
|
args are given,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
This flag args are given,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
This flag will cause
|
||||||
|
.B calc
|
||||||
|
to drop into interactive mode after the
|
||||||
|
commands are executed.
|
||||||
|
.sp 1
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc 2+5
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will print the value 7 and exit whereas:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -i 2+5
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will print the value 7 and prompt the user for more
|
||||||
|
.B calc
|
||||||
|
commands.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.BR \-m " mode"
|
||||||
|
This flag sets the permission mode of
|
||||||
|
.BR calc .
|
||||||
|
It controls the ability for
|
||||||
|
.B calc
|
||||||
|
to open files and execute programs.
|
||||||
|
Mode may be a number from 0 to 7.
|
||||||
|
.sp 1
|
||||||
|
The mode value is interpreted in a way similar to that
|
||||||
|
of the
|
||||||
|
.BR chmod (1)
|
||||||
|
octal mode:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
0 do not open any file, do not execute progs
|
||||||
|
1 do not open any file
|
||||||
|
2 do not open files for reading, do not execute progs
|
||||||
|
3 do not open files for reading
|
||||||
|
4 do not open files for writing, do not execute progs
|
||||||
|
5 do not open files for writing
|
||||||
|
6 do not execute any program
|
||||||
|
7 allow everything (default mode)
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
If one wished to run
|
||||||
|
.B calc
|
||||||
|
from a privileged user, one might want to use
|
||||||
|
.B \-m
|
||||||
|
0 in an effort to make
|
||||||
|
.B calc
|
||||||
|
somewhat more secure.
|
||||||
|
.sp 1
|
||||||
|
Mode bits for reading and writing apply only on an
|
||||||
|
open.
|
||||||
Files already open are not effected.
|
Files already open are not effected.
|
||||||
Thus if one wanted to use the \fI\-m 0\fP in an effort to make
|
Thus if one wanted to use the
|
||||||
\fIcalc\fP more secure, but still wanted to read and write a specific
|
.B \-m
|
||||||
file, one might want to do:
|
0 in an effort to make
|
||||||
.sp
|
.B calc
|
||||||
.in +0.5i
|
somewhat more secure, but still wanted to read and write a specific
|
||||||
|
file, one might want to do in
|
||||||
|
.BR sh (1),
|
||||||
|
.BR ksh (1),
|
||||||
|
.BR bash (1)-like
|
||||||
|
shells:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRcalc \-m 0 3<a.file\fP
|
calc -m 0 3<a.file
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
Files presented to \fIcalc\fP in this way are opened in an unknown mode.
|
Files presented to
|
||||||
\fICalc\fP will attempt to read or write them if directed.
|
.B calc
|
||||||
.sp
|
in this way are opened in an
|
||||||
If the \fImode\fP disables opening of files for reading, then
|
unknown mode.
|
||||||
the startup library scripts are disabled as of \fI\-q\fP was given.
|
.B Calc
|
||||||
The reading of key bindings is also disabled when the \fImode\fP
|
will attempt to read or write them if directed.
|
||||||
disables opening of files for reading.
|
.sp 1
|
||||||
|
If the mode disables opening of files for reading, then
|
||||||
|
the startup library scripts are disabled as of
|
||||||
|
.B \-q
|
||||||
|
was given.
|
||||||
|
The reading of key bindings is also disabled
|
||||||
|
when the mode disables opening of files for reading.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-p\fP
|
.B \-n
|
||||||
Pipe processing is enabled by use of \-p. For example:
|
Use the new configuration defaults instead of the old
|
||||||
.sp
|
default classic defaults.
|
||||||
.in +0.5i
|
This flag as the same effect
|
||||||
|
as executing \fBconfig("all", "newcfg")\fP at startup time.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-p
|
||||||
|
Pipe processing is enabled by use of
|
||||||
|
.BR \-p .
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRecho "print 2^21701\-1, 2^23209\-1" | calc \-p | fizzbin\fP
|
calc -p '2^21701-1' | fizzbin
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
In pipe mode, \fIcalc\fP does not prompt, does not print leading tabs
|
In pipe mode,
|
||||||
and does not print the initial header.
|
.B calc
|
||||||
|
does not prompt, does not print leading
|
||||||
|
tabs and does not print the initial header.
|
||||||
|
The
|
||||||
|
.B \-p
|
||||||
|
flag overrides
|
||||||
|
.BR \-i .
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-q\fP
|
.B \-q
|
||||||
Disable the use of the \fI$CALCRC\fP startup scripts.
|
Disable the use of the $CALCRC startup scripts.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-u\fP
|
.B \-u
|
||||||
Disable buffering of stdin and stdout.
|
Disable buffering of stdin and stdout.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-v\fP
|
.B \-v
|
||||||
Print the version and exit.
|
Print the
|
||||||
|
.B calc
|
||||||
|
version number and exit.
|
||||||
.PP
|
.PP
|
||||||
Without \fIcalc_cmd\fPs, \fIcalc\fP operates interactively.
|
Without
|
||||||
If one or more \fIcalc_cmd\fPs are given on the command line,
|
.IR calc_cmd ,
|
||||||
\fIcalc\fP will execute them and exit.
|
.B calc
|
||||||
The printing of leading tabs on output is disabled
|
operates interactively.
|
||||||
as if \fIconfig("tab",0)\fP had been executed.
|
If one or more
|
||||||
|
.I calc_cmd
|
||||||
|
are given on the command line,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
If
|
||||||
|
.B \-i
|
||||||
|
is given,
|
||||||
|
.B calc
|
||||||
|
will attempt to become interactive
|
||||||
|
even of one or more
|
||||||
|
.I calc_cmd
|
||||||
|
are given on the command line.
|
||||||
.PP
|
.PP
|
||||||
Normally on startup, \fIcalc\fP attempts to execute a collection
|
Normally on startup,
|
||||||
of library scripts.
|
.B calc
|
||||||
The environment variable \fI$CALCRC\fP (if non-existent then
|
attempts to execute a collection of
|
||||||
a compiled in value) contains a \fI:\fP separated list of
|
library scripts.
|
||||||
startup library scripts.
|
The environment variable $CALCRC (if non-existent
|
||||||
No error conditions are produced if these startup library scripts
|
then a compiled in value) contains a : separated list of startup
|
||||||
are not found.
|
library scripts.
|
||||||
|
No error conditions are produced if these startup
|
||||||
|
library scripts are not found.
|
||||||
.PP
|
.PP
|
||||||
If the \fImode\fP disables opening of files for reading, then
|
If the mode disables opening of files for reading, then the startup
|
||||||
the startup library scripts are disabled as of \fI\-q\fP was given
|
library scripts are disabled as of
|
||||||
and \fI$CALCRC\fP as well as the default compiled in value are ignored.
|
.B \-q
|
||||||
|
was given and $CALCRC as well
|
||||||
|
as the default compiled in value are ignored.
|
||||||
.PP
|
.PP
|
||||||
Filenames are subject to ``~'' expansion (see below).
|
Filenames are subject to ``~'' expansion (see below).
|
||||||
The environment variable \fI$CALCPATH\fP (if non-existent then
|
The
|
||||||
a compiled in value) contains a \fI:\fP separated list of search
|
environment variable $CALCPATH (if non-existent then a compiled in
|
||||||
directories.
|
value) contains a : separated list of search directories.
|
||||||
If a file does not begin with \fI/\fP, \fI~\fP or \fI./\fP,
|
If a
|
||||||
then it is searched for under each directory listed in the \fI$CALCPATH\fP.
|
file does not begin with /, ~ or ./, then it is searched for under
|
||||||
It is an error if no such readable file is found.
|
each directory listed in the $CALCPATH.
|
||||||
|
It is an error if no such
|
||||||
|
readable file is found.
|
||||||
.PP
|
.PP
|
||||||
Calc treats all open files, other than stdin, stdout and stderr
|
.B Calc
|
||||||
as files available for reading and writing.
|
treats all open files, other than stdin, stdout and
|
||||||
One may present calc with an already open file in the following way:
|
stderr as files available for reading and writing.
|
||||||
.sp
|
One may
|
||||||
.in +0.5i
|
present
|
||||||
|
.B calc
|
||||||
|
with an already open file using
|
||||||
|
.BR sh (1),
|
||||||
|
.BR ksh (1),
|
||||||
|
.BR bash (1)-like
|
||||||
|
shells is to:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
calc 3<open_file 4<open_file2
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRcalc 3<open_file 4<open_file2\fP
|
|
||||||
.fi
|
|
||||||
.in -0.5i
|
|
||||||
.PP
|
|
||||||
For more information use the following calc commands:
|
|
||||||
.PP
|
|
||||||
.in 1.0i
|
|
||||||
help usage
|
|
||||||
.br
|
|
||||||
help help
|
help help
|
||||||
.br
|
help overview
|
||||||
|
help usage
|
||||||
help environment
|
help environment
|
||||||
.in -1.0i
|
help config
|
||||||
.PP
|
.fi
|
||||||
OVERVIEW
|
.in -5n
|
||||||
.PP
|
.sp 1
|
||||||
\fICalc\fP is arbitrary precision arithmetic system that uses
|
|
||||||
a C-like language.
|
|
||||||
\fICalc\fP is useful as a calculator, an algorithm prototyped
|
|
||||||
and as a mathematical research tool.
|
|
||||||
More importantly, \fIcalc\fP provides one with a machine
|
|
||||||
independent means of computation.
|
|
||||||
.PP
|
|
||||||
\fICalc\fP comes with a rich set of builtin mathematical
|
|
||||||
and programmatic functions.
|
|
||||||
.PP
|
|
||||||
\fICalc\fP is distributed with library of scripts.
|
|
||||||
Written in the same C-like language, library scripts may be
|
|
||||||
read in and executed during a \fIcalc\fP session.
|
|
||||||
These library scripts are also provided because they are
|
|
||||||
useful and to serve as examples of the \fIcalc\fP language.
|
|
||||||
One may further extend \fIcalc\fP thru the
|
|
||||||
use of user defined scripts.
|
|
||||||
.PP
|
|
||||||
Internally calc represents numeric values as fractions reduced to their
|
|
||||||
lowest terms.
|
|
||||||
The numerators and denominators of these factions may grow to
|
|
||||||
arbitrarily large values.
|
|
||||||
Numeric values read in are automatically converted into rationals.
|
|
||||||
The user need not be aware of this internal representation.
|
|
||||||
.PP
|
|
||||||
For more information use the following calc commands:
|
|
||||||
.PP
|
|
||||||
.in 1.0i
|
|
||||||
help intro
|
|
||||||
.br
|
|
||||||
help builtin
|
|
||||||
.br
|
|
||||||
help stdlib
|
|
||||||
.br
|
|
||||||
help define
|
|
||||||
.br
|
|
||||||
show builtins
|
|
||||||
.br
|
|
||||||
show functions
|
|
||||||
.in -1.0i
|
|
||||||
.PP
|
.PP
|
||||||
DATA TYPES
|
DATA TYPES
|
||||||
.PP
|
.PP
|
||||||
@@ -199,7 +365,9 @@ multiplication, division, negation, squaring, modulus,
|
|||||||
rounding, exponentiation, equality, comparison, printing
|
rounding, exponentiation, equality, comparison, printing
|
||||||
and so on.
|
and so on.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc commands:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help types
|
help types
|
||||||
@@ -220,7 +388,9 @@ procedure.
|
|||||||
Values may be grouped together in a matrix, or into a
|
Values may be grouped together in a matrix, or into a
|
||||||
a list that permits stack and queue style operations.
|
a list that permits stack and queue style operations.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc commands:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help variable
|
help variable
|
||||||
@@ -256,7 +426,9 @@ For example:
|
|||||||
~chongo/lib/fft_multiply.cal
|
~chongo/lib/fft_multiply.cal
|
||||||
.in -1.0i
|
.in -1.0i
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc command:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
command:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help file
|
help file
|
||||||
@@ -275,7 +447,9 @@ These include commands such as function definition, help,
|
|||||||
reading in library scripts, dump files to a file, error notification,
|
reading in library scripts, dump files to a file, error notification,
|
||||||
configuration control and status.
|
configuration control and status.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc command:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
command:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help command
|
help command
|
||||||
@@ -295,7 +469,8 @@ help config
|
|||||||
.PD 0
|
.PD 0
|
||||||
.TP 20
|
.TP 20
|
||||||
${LIBDIR}/*.cal
|
${LIBDIR}/*.cal
|
||||||
library scripts shipped with calc
|
library scripts shipped with
|
||||||
|
.B calc
|
||||||
.br
|
.br
|
||||||
.sp
|
.sp
|
||||||
.TP 20
|
.TP 20
|
||||||
@@ -323,7 +498,9 @@ Default value: ${CALCPATH}
|
|||||||
.TP 5
|
.TP 5
|
||||||
CALCRC
|
CALCRC
|
||||||
On startup (unless \-h or \-q was given on the command
|
On startup (unless \-h or \-q was given on the command
|
||||||
line), calc searches for files along this :-separated
|
line),
|
||||||
|
.B calc
|
||||||
|
searches for files along this :-separated
|
||||||
environment variable.
|
environment variable.
|
||||||
.br
|
.br
|
||||||
.sp
|
.sp
|
||||||
@@ -333,7 +510,9 @@ Default value: ${CALCRC}
|
|||||||
.TP 5
|
.TP 5
|
||||||
CALCBINDINGS
|
CALCBINDINGS
|
||||||
On startup (unless \fI\-h\fP or \fI\-q\fP was given on the command
|
On startup (unless \fI\-h\fP or \fI\-q\fP was given on the command
|
||||||
line, or \fI\-m\fP disallows opening files for reading), calc reads
|
line, or \fI\-m\fP disallows opening files for reading),
|
||||||
|
.B calc
|
||||||
|
reads
|
||||||
key bindings from the filename specified
|
key bindings from the filename specified
|
||||||
by this environment variable.
|
by this environment variable.
|
||||||
.br
|
.br
|
||||||
@@ -343,9 +522,12 @@ Default value: ${CALCBINDINGS}
|
|||||||
.SH CREDIT
|
.SH CREDIT
|
||||||
\&
|
\&
|
||||||
.br
|
.br
|
||||||
The majority of calc was written by David I. Bell.
|
The majority of
|
||||||
|
.B calc
|
||||||
|
was written by David I. Bell.
|
||||||
.sp
|
.sp
|
||||||
Calc archives and calc-tester mailing list maintained by Landon Curt Noll.
|
.B Calc
|
||||||
|
archives and calc-tester mailing list maintained by Landon Curt Noll.
|
||||||
.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.
|
||||||
@@ -378,30 +560,27 @@ Copyright (c) 19xx Ernest Bowen and Landon Curt Noll
|
|||||||
Permission is granted to use, distribute, or modify this source,
|
Permission is granted to use, distribute, or modify this source,
|
||||||
provided that this copyright notice remains intact.
|
provided that this copyright notice remains intact.
|
||||||
.sp
|
.sp
|
||||||
Send calc comments, suggestions, bug fixes, enhancements
|
Send comments, suggestions, bug fixes, enhancements
|
||||||
and interesting calc scripts that you would like you see included
|
and interesting
|
||||||
|
.B calc
|
||||||
|
scripts that you would like you see included
|
||||||
in future distributions to:
|
in future distributions to:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
dbell@auug.org.au
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
.br
|
|
||||||
chongo@toad.com
|
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
Landon Noll maintains the official calc ftp archive at:
|
Landon Noll maintains the the
|
||||||
|
.B calc
|
||||||
|
web site is located at:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
ftp://ftp.uu.net/pub/calc
|
http://reality.sgi.com/chongo/calc
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
Alpha test versions, complete with bugs, untested code and
|
One may join the
|
||||||
experimental features may be fetched (if you are brave) under:
|
.B calc
|
||||||
.sp
|
testing group by sending a request to:
|
||||||
.in +0.5i
|
|
||||||
http://reality.sgi.com/chongo/calc/
|
|
||||||
.in -0.5i
|
|
||||||
.sp
|
|
||||||
One may join the calc testing group by sending a request to:
|
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
@@ -410,14 +589,14 @@ calc-tester-request@postofc.corp.sgi.com
|
|||||||
Your message body (not the subject) should consist of:
|
Your message body (not the subject) should consist of:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
|
.nf
|
||||||
subscribe calc-tester address
|
subscribe calc-tester address
|
||||||
.br
|
|
||||||
end
|
end
|
||||||
.br
|
|
||||||
name your_full_name
|
name your_full_name
|
||||||
|
.fi
|
||||||
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
where "address" is your EMail address and "your_full_name"
|
where "address" is your EMail address and "your_full_name"
|
||||||
is your full name.
|
is your full name.
|
||||||
.in -0.5i
|
|
||||||
.sp
|
.sp
|
||||||
Enjoy!
|
Share and Enjoy! :\-)
|
||||||
|
158
func.c
158
func.c
@@ -72,6 +72,7 @@ static int strscan(char *s, int count, VALUE **vals);
|
|||||||
static int filescan(FILEID id, int count, VALUE **vals);
|
static int filescan(FILEID id, int count, VALUE **vals);
|
||||||
static VALUE f_eval(VALUE *vp);
|
static VALUE f_eval(VALUE *vp);
|
||||||
static VALUE f_fsize(VALUE *vp);
|
static VALUE f_fsize(VALUE *vp);
|
||||||
|
static int malloced_putenv(char *str);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -87,6 +88,19 @@ extern int idungetc(FILEID id, int ch);
|
|||||||
extern int stoponerror;
|
extern int stoponerror;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* malloced environment storage
|
||||||
|
*/
|
||||||
|
#define ENV_POOL_CHUNK 10 /* env_pool elements to allocate at a time */
|
||||||
|
struct env_pool {
|
||||||
|
char *getenv; /* what getenv() would return, NULL => unused */
|
||||||
|
char *putenv; /* pointer given to putenv() */
|
||||||
|
};
|
||||||
|
static int env_pool_cnt = 0; /* number of env_pool elements in use */
|
||||||
|
static int env_pool_max = 0; /* number of env_pool elements allocated */
|
||||||
|
static struct env_pool *e_pool = NULL; /* env_pool elements */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* if HZ & CLK_TCK are not defined, pick typical values, hope for the best
|
* if HZ & CLK_TCK are not defined, pick typical values, hope for the best
|
||||||
*/
|
*/
|
||||||
@@ -5977,8 +5991,7 @@ f_putenv(int count, VALUE **vals)
|
|||||||
|
|
||||||
/* return putenv result */
|
/* return putenv result */
|
||||||
result.v_type = V_NUM;
|
result.v_type = V_NUM;
|
||||||
result.v_num = itoq((long) putenv(putenv_str));
|
result.v_num = itoq((long) malloced_putenv(putenv_str));
|
||||||
free(putenv_str);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -7522,4 +7535,145 @@ showerrors(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* malloced_putenv - Keep track of malloced environment variable storage
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* str a malloced string which will be given to putenv
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* putenv() return value
|
||||||
|
*
|
||||||
|
* NOTE: The caller MUST pass a string that the caller has previously malloced.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
malloced_putenv(char *str)
|
||||||
|
{
|
||||||
|
char *value; /* location of the value part of the str argument */
|
||||||
|
char *old_val; /* previously stored (or inherited) env value */
|
||||||
|
int found_cnt; /* number of active env_pool entries found */
|
||||||
|
struct env_pool *new; /* new e_pool */
|
||||||
|
int i;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* firewall
|
||||||
|
*/
|
||||||
|
if (str == NULL) {
|
||||||
|
math_error("malloced_putenv given a NULL pointer!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
if (str[0] == '=') {
|
||||||
|
math_error("malloced_putenv = is first character in string!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* determine the place where getenv would return
|
||||||
|
*/
|
||||||
|
value = strchr(str, '=');
|
||||||
|
if (value == NULL) {
|
||||||
|
math_error("malloced_putenv = not found in string!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
++value;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* lookup for an existing environment value
|
||||||
|
*/
|
||||||
|
*(value-1) = '\0';
|
||||||
|
old_val = getenv(str);
|
||||||
|
*(value-1) = '=';
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we have the value in our environment, look for a
|
||||||
|
* previously malloced string and free it
|
||||||
|
*/
|
||||||
|
if (old_val != NULL && env_pool_cnt > 0) {
|
||||||
|
for (i=0, found_cnt=0;
|
||||||
|
i < env_pool_max && found_cnt < env_pool_cnt;
|
||||||
|
++i) {
|
||||||
|
|
||||||
|
/* skip an unused entry */
|
||||||
|
if (e_pool[i].getenv == NULL) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
++found_cnt;
|
||||||
|
|
||||||
|
/* look for the 1st match */
|
||||||
|
if (e_pool[i].getenv == value) {
|
||||||
|
|
||||||
|
/* found match, free the storage */
|
||||||
|
if (e_pool[i].putenv != NULL) {
|
||||||
|
free(e_pool[i].putenv);
|
||||||
|
}
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
--env_pool_cnt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ensure that we have room in the e_pool
|
||||||
|
*/
|
||||||
|
if (env_pool_max == 0) {
|
||||||
|
|
||||||
|
/* allocate an initial pool (with one extra guard value) */
|
||||||
|
new = (struct env_pool *)malloc((ENV_POOL_CHUNK+1) *
|
||||||
|
sizeof(struct env_pool));
|
||||||
|
if (new == NULL) {
|
||||||
|
math_error("malloced_putenv malloc failed");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
e_pool = new;
|
||||||
|
env_pool_max = ENV_POOL_CHUNK;
|
||||||
|
for (i=0; i <= ENV_POOL_CHUNK; ++i) {
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (env_pool_cnt >= env_pool_max) {
|
||||||
|
|
||||||
|
/* expand the current pool (with one extra guard value) */
|
||||||
|
new = (struct env_pool *)realloc(e_pool,
|
||||||
|
(env_pool_max+ENV_POOL_CHUNK+1) *
|
||||||
|
sizeof(struct env_pool));
|
||||||
|
if (new == NULL) {
|
||||||
|
math_error("malloced_putenv realloc failed");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
e_pool = new;
|
||||||
|
for (i=env_pool_max; i <= env_pool_max + ENV_POOL_CHUNK; ++i) {
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
}
|
||||||
|
env_pool_max += ENV_POOL_CHUNK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* store our data into the first e_pool entry
|
||||||
|
*/
|
||||||
|
for (i=0; i < env_pool_max; ++i) {
|
||||||
|
|
||||||
|
/* skip used entries */
|
||||||
|
if (e_pool[i].getenv != NULL) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* store in this free entry and stop looping */
|
||||||
|
e_pool[i].getenv = value;
|
||||||
|
e_pool[i].putenv = str;
|
||||||
|
++env_pool_cnt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i >= env_pool_max) {
|
||||||
|
math_error("malloced_putenv missed unused entry!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* finally, do the putenv action
|
||||||
|
*/
|
||||||
|
return putenv(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* FUNCLIST */
|
#endif /* FUNCLIST */
|
||||||
|
76
help/usage
76
help/usage
@@ -2,7 +2,22 @@ Calc command line
|
|||||||
|
|
||||||
Calc has the following command line:
|
Calc has the following command line:
|
||||||
|
|
||||||
calc [-C] [-e] [-h] [-i] [-m mode] [-n] [-p] [-q] [-u] [calc_cmd ...]
|
calc [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]
|
||||||
|
[-n] [-p] [-q] [-u] [-v] [calc_cmd ...]
|
||||||
|
|
||||||
|
-c Continue reading command lines even after an execution
|
||||||
|
error has caused the abandonment of a line.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc read many_errors.cal
|
||||||
|
|
||||||
|
will cause calc to abort on the first error, whereas:
|
||||||
|
|
||||||
|
calc -c read many_errors.cal
|
||||||
|
|
||||||
|
will cause calc to try to process each line being read
|
||||||
|
despite the errors that it encounters.
|
||||||
|
|
||||||
-C Permit the execution of custom builtin functions. Without
|
-C Permit the execution of custom builtin functions. Without
|
||||||
this flag, calling the custom() builtin function will
|
this flag, calling the custom() builtin function will
|
||||||
@@ -12,6 +27,27 @@ Calc command line
|
|||||||
are non-standard and that are not portable. Custom builtin
|
are non-standard and that are not portable. Custom builtin
|
||||||
functions are disabled by default for this reason.
|
functions are disabled by default for this reason.
|
||||||
|
|
||||||
|
-d Disable the printing of the opening title. The printing
|
||||||
|
of library debug and informational messages is also disabled
|
||||||
|
as if config("lib_debug",0) had been executed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will output something like:
|
||||||
|
|
||||||
|
qtime(utc_hr_offset) defined
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
whereas:
|
||||||
|
|
||||||
|
calc -d 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will just say:
|
||||||
|
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
-e Ignore any environment variables on startup. The
|
-e Ignore any environment variables on startup. The
|
||||||
getenv() builtin will still return values, however.
|
getenv() builtin will still return values, however.
|
||||||
|
|
||||||
@@ -19,7 +55,21 @@ Calc command line
|
|||||||
is equivalent to the calc command help help. The help
|
is equivalent to the calc command help help. The help
|
||||||
facility is disabled unless the mode is 5 or 7. See -m.
|
facility is disabled unless the mode is 5 or 7. See -m.
|
||||||
|
|
||||||
-i Do not about if the error count exceeds maxerr().
|
-i Become interactive if possible. Be default, if calc_cmd
|
||||||
|
args are given, calc will execute them and exit. This flag
|
||||||
|
will cause calc to drop into interactive mode after the
|
||||||
|
commands are executed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc 2+5
|
||||||
|
|
||||||
|
will print the value 7 and exit whereas:
|
||||||
|
|
||||||
|
calc -i 2+5
|
||||||
|
|
||||||
|
will print the value 7 and prompt the user for more
|
||||||
|
calc commands.
|
||||||
|
|
||||||
-m mode
|
-m mode
|
||||||
This flag sets the permission mode of calc. It
|
This flag sets the permission mode of calc. It
|
||||||
@@ -38,7 +88,7 @@ Calc command line
|
|||||||
6 do not execute any program
|
6 do not execute any program
|
||||||
7 allow everything (default mode)
|
7 allow everything (default mode)
|
||||||
|
|
||||||
If one wished to run calc from a privledged user, one
|
If one wished to run calc from a privileged user, one
|
||||||
might want to use -m 0 in an effort to make calc more
|
might want to use -m 0 in an effort to make calc more
|
||||||
secure.
|
secure.
|
||||||
|
|
||||||
@@ -46,7 +96,7 @@ Calc command line
|
|||||||
open. Files already open are not effected. Thus if one
|
open. Files already open are not effected. Thus if one
|
||||||
wanted to use the -m 0 in an effort to make calc more
|
wanted to use the -m 0 in an effort to make calc more
|
||||||
secure, but still wanted to read and write a specific
|
secure, but still wanted to read and write a specific
|
||||||
file, one might want to do:
|
file, one might want to do in sh, ksh, bash-like shells:
|
||||||
|
|
||||||
calc -m 0 3<a.file
|
calc -m 0 3<a.file
|
||||||
|
|
||||||
@@ -59,25 +109,28 @@ Calc command line
|
|||||||
given. The reading of key bindings is also disabled
|
given. The reading of key bindings is also disabled
|
||||||
when the mode disables opening of files for reading.
|
when the mode disables opening of files for reading.
|
||||||
|
|
||||||
-n Use the new configutation defaults instead of the old
|
-n Use the new configuration defaults instead of the old
|
||||||
default classic defaults. This flag as the same effect
|
default classic defaults. This flag as the same effect
|
||||||
as executing config("all", "newcfg") at startup time.
|
as executing config("all", "newcfg") at startup time.
|
||||||
|
|
||||||
-p Pipe processing is enabled by use of -p. For example:
|
-p Pipe processing is enabled by use of -p. For example:
|
||||||
|
|
||||||
echo "print 2^21701-1, 2^23209-1" | calc -p | fizzbin
|
calc -p '2^21701-1' | fizzbin
|
||||||
|
|
||||||
In pipe mode, calc does not prompt, does not print
|
In pipe mode, calc does not prompt, does not print leading
|
||||||
leading tabs and does not print the initial header.
|
tabs and does not print the initial header. The -p flag
|
||||||
|
overrides -i.
|
||||||
|
|
||||||
-q Disable the use of the $CALCRC startup scripts.
|
-q Disable the use of the $CALCRC startup scripts.
|
||||||
|
|
||||||
-u Disable buffering of stdin and stdout.
|
-u Disable buffering of stdin and stdout.
|
||||||
|
|
||||||
|
-v Print calc version number and exit.
|
||||||
|
|
||||||
Without `calc_cmd', calc operates interactively. If one or more
|
Without `calc_cmd', calc operates interactively. If one or more
|
||||||
`calc_cmd' are given on the command line, calc will execute them and
|
`calc_cmd' are given on the command line, calc will execute them and
|
||||||
exit. The printing of leading tabs on output is disabled as if
|
exit. If -i is given, calc will attempt to become interactive
|
||||||
config("tab",0) had been executed.
|
even of one or more `calc_cmd' are given on the command line.
|
||||||
|
|
||||||
Normally on startup, calc attempts to execute a collection of
|
Normally on startup, calc attempts to execute a collection of
|
||||||
library scripts. The environment variable $CALCRC (if non-existent
|
library scripts. The environment variable $CALCRC (if non-existent
|
||||||
@@ -98,7 +151,8 @@ Calc command line
|
|||||||
|
|
||||||
Calc treats all open files, other than stdin, stdout and
|
Calc treats all open files, other than stdin, stdout and
|
||||||
stderr as files available for reading and writing. One may
|
stderr as files available for reading and writing. One may
|
||||||
present calc with an already open file in the following way:
|
present calc with an already open file using sh, ksh or bash-like
|
||||||
|
shells is to:
|
||||||
|
|
||||||
calc 3<open_file 4<open_file2
|
calc 3<open_file 4<open_file2
|
||||||
|
|
||||||
|
6
input.c
6
input.c
@@ -311,7 +311,7 @@ f_open(char *name, char *mode)
|
|||||||
*/
|
*/
|
||||||
if (!allow_read && !allow_write) {
|
if (!allow_read && !allow_write) {
|
||||||
/* no reads and no writes means no opens! */
|
/* no reads and no writes means no opens! */
|
||||||
if (start_done) {
|
if (run_state > RUN_PRE_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for read or write disallowed by -m\n");
|
"open for read or write disallowed by -m\n");
|
||||||
@@ -319,7 +319,7 @@ f_open(char *name, char *mode)
|
|||||||
return NULL;
|
return NULL;
|
||||||
} else if (!allow_read && strchr(mode, 'r') != NULL) {
|
} else if (!allow_read && strchr(mode, 'r') != NULL) {
|
||||||
/* reading new files disallowed */
|
/* reading new files disallowed */
|
||||||
if (start_done) {
|
if (run_state > RUN_PRE_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for read disallowed by -m\n");
|
"open for read disallowed by -m\n");
|
||||||
@@ -330,7 +330,7 @@ f_open(char *name, char *mode)
|
|||||||
strchr(mode, 'a') != NULL ||
|
strchr(mode, 'a') != NULL ||
|
||||||
strchr(mode, '+') != NULL)) {
|
strchr(mode, '+') != NULL)) {
|
||||||
/* writing new files disallowed */
|
/* writing new files disallowed */
|
||||||
if (start_done) {
|
if (run_state > RUN_PRE_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for write disallowed by -m\n");
|
"open for write disallowed by -m\n");
|
||||||
|
@@ -4223,7 +4223,7 @@ define test_random()
|
|||||||
|
|
||||||
/* test range interface some more */
|
/* test range interface some more */
|
||||||
tmp = srandom(state1);
|
tmp = srandom(state1);
|
||||||
print '5369: tmp = srandom(0)';
|
print '5369: tmp = srandom(state1)';
|
||||||
vrfy(random(-46,46) == -0x7, '5370: random(-46,46) == -0x7');
|
vrfy(random(-46,46) == -0x7, '5370: random(-46,46) == -0x7');
|
||||||
vrfy(random(21701,23209) == 23061,
|
vrfy(random(21701,23209) == 23061,
|
||||||
'5371: random(21701,23209) == 23061');
|
'5371: random(21701,23209) == 23061');
|
||||||
|
21
lib_calc.c
21
lib_calc.c
@@ -63,8 +63,8 @@ int new_std = FALSE; /* TRUE (-n) => use newstd configuration */
|
|||||||
int abortlevel; /* current level of aborts */
|
int abortlevel; /* current level of aborts */
|
||||||
BOOL inputwait; /* TRUE if in a terminal input wait */
|
BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
jmp_buf jmpbuf; /* for errors */
|
jmp_buf jmpbuf; /* for errors */
|
||||||
int start_done = FALSE; /* TRUE => start up processing finished */
|
run run_state = RUN_UNKNOWN; /* calc startup and run state */
|
||||||
char *program = "calc"; /* our name */
|
char *program = "calc"; /* our name */
|
||||||
char cmdbuf[MAXCMD+1+1+1]; /* command line expression + "\n\0" + guard */
|
char cmdbuf[MAXCMD+1+1+1]; /* command line expression + "\n\0" + guard */
|
||||||
|
|
||||||
|
|
||||||
@@ -83,8 +83,8 @@ int p_flag = FALSE; /* TRUE => pipe mode */
|
|||||||
int q_flag = FALSE; /* TRUE => don't execute rc files */
|
int q_flag = FALSE; /* TRUE => don't execute rc files */
|
||||||
int u_flag = FALSE; /* TRUE => unbuffer stdin and stdout */
|
int u_flag = FALSE; /* TRUE => unbuffer stdin and stdout */
|
||||||
int d_flag = FALSE; /* TRUE => disable heading, lib_debug == 0 */
|
int d_flag = FALSE; /* TRUE => disable heading, lib_debug == 0 */
|
||||||
|
int c_flag = FALSE; /* TRUE => continue on error if permitted */
|
||||||
int stoponerror = FALSE; /* >0 => stop, <0 => continue on error */
|
int i_flag = FALSE; /* TRUE => go interactive if permitted */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* global values
|
* global values
|
||||||
@@ -96,8 +96,9 @@ char *home; /* $HOME or default */
|
|||||||
char *pager; /* $PAGER or default */
|
char *pager; /* $PAGER or default */
|
||||||
char *shell; /* $SHELL or default */
|
char *shell; /* $SHELL or default */
|
||||||
int stdin_tty = FALSE; /* TRUE if stdin is a tty */
|
int stdin_tty = FALSE; /* TRUE if stdin is a tty */
|
||||||
int interactive = FALSE; /* TRUE if interactive session (no cmd args) */
|
int havecommands = FALSE; /* TRUE if have one or more cmd args */
|
||||||
int post_init = FALSE; /* TRUE setjmp for math_error is readready */
|
int stoponerror = FALSE; /* >0 => stop, <0 => continue on error */
|
||||||
|
int post_init = FALSE; /* TRUE setjmp for math_error is ready */
|
||||||
|
|
||||||
int no_env = FALSE; /* TRUE (-e) => ignore env vars on startup */
|
int no_env = FALSE; /* TRUE (-e) => ignore env vars on startup */
|
||||||
int errmax = ERRMAX; /* if >= 0, maximum value for errcount */
|
int errmax = ERRMAX; /* if >= 0, maximum value for errcount */
|
||||||
@@ -164,6 +165,13 @@ libcalc_call_me_first(void)
|
|||||||
conf->lib_debug = 0;
|
conf->lib_debug = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* -p turns off tab
|
||||||
|
*/
|
||||||
|
if (p_flag) {
|
||||||
|
conf->tab_ok = 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialize
|
* initialize
|
||||||
*/
|
*/
|
||||||
@@ -172,6 +180,7 @@ libcalc_call_me_first(void)
|
|||||||
/*
|
/*
|
||||||
* ready to rock & roll ..
|
* ready to rock & roll ..
|
||||||
*/
|
*/
|
||||||
|
run_state = RUN_PRE_BEGIN;
|
||||||
init_done = 1;
|
init_done = 1;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@@ -208,11 +208,6 @@ CALC_LIBS= ../libcalc.a ../custom/libcustcalc.a
|
|||||||
|
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
# Normally, the upper level makefile will set these values. We provide
|
|
||||||
# a default here just in case you want to build from this directory.
|
|
||||||
#
|
|
||||||
# Select your compiler type by commenting out one of the cc sets below:
|
|
||||||
#
|
|
||||||
# CCOPT are flags given to ${CC} for optimization
|
# CCOPT are flags given to ${CC} for optimization
|
||||||
# CCWARN are flags given to ${CC} for warning message control
|
# CCWARN are flags given to ${CC} for warning message control
|
||||||
# CCMISC are misc flags given to ${CC}
|
# CCMISC are misc flags given to ${CC}
|
||||||
@@ -220,32 +215,36 @@ CALC_LIBS= ../libcalc.a ../custom/libcustcalc.a
|
|||||||
# CFLAGS are all flags given to ${CC} [[often includes CCOPT, CCWARN, CCMISC]]
|
# CFLAGS are all flags given to ${CC} [[often includes CCOPT, CCWARN, CCMISC]]
|
||||||
# ICFLAGS are given to ${CC} for intermediate progs
|
# ICFLAGS are given to ${CC} for intermediate progs
|
||||||
#
|
#
|
||||||
# CCMAIN are flags for ${CC} when files with main() instead of CFLAGS
|
|
||||||
#
|
|
||||||
# LCFLAGS are CC-style flags for ${LINT}
|
# LCFLAGS are CC-style flags for ${LINT}
|
||||||
# LDFLAGS are flags given to ${CC} for linking .o files
|
# LDFLAGS are flags given to ${CC} for linking .o files
|
||||||
# ILDFLAGS are flags given to ${CC} for linking .o files for intermediate progs
|
# ILDFLAGS are flags given to ${CC} for linking .o files for intermediate progs
|
||||||
#
|
#
|
||||||
# CC is how the the C compiler is invoked
|
# LCC how the the C compiler is invoked on locally executed intermediate progs
|
||||||
|
# CC is how the the C compiler is invoked (with an optional Purify)
|
||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
# common cc set
|
# default set
|
||||||
#
|
#
|
||||||
CCWARN=
|
# Normally these values are passed in from the upper level Makefile.
|
||||||
|
# Change these as needed if you intend to build directly in this directory.
|
||||||
|
#
|
||||||
|
# for better performance, set the following above:
|
||||||
|
# DEBUG= -O2
|
||||||
|
#
|
||||||
|
CCWARN= -Wall -Wno-implicit -Wno-comment
|
||||||
CCOPT= ${DEBUG} ${NO_SHARED}
|
CCOPT= ${DEBUG} ${NO_SHARED}
|
||||||
CCMISC=
|
CCMISC=
|
||||||
#
|
#
|
||||||
CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC} ${ALLOW_CUSTOM}
|
CFLAGS= ${CCWARN} ${CCOPT} ${CCMISC}
|
||||||
ICFLAGS= ${CCWARN} ${CCMISC}
|
ICFLAGS= ${CCWARN} ${CCMISC}
|
||||||
#
|
#
|
||||||
CCMAIN= ${ICFLAGS}
|
|
||||||
#
|
|
||||||
LCFLAGS=
|
LCFLAGS=
|
||||||
LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
LDFLAGS= ${NO_SHARED} ${LD_NO_SHARED}
|
||||||
ILDFLAGS=
|
ILDFLAGS=
|
||||||
#
|
#
|
||||||
CC= ${PURIFY} cc
|
LCC= gcc
|
||||||
|
CC= ${PURIFY} ${LCC}
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
#-=-=-=-=-=-=-=-=- Be careful if you change something below -=-=-=-=-=-=-=-=-#
|
#-=-=-=-=-=-=-=-=- Be careful if you change something below -=-=-=-=-=-=-=-=-#
|
||||||
@@ -286,13 +285,13 @@ SORT= sort
|
|||||||
all: ${TARGETS} .all
|
all: ${TARGETS} .all
|
||||||
|
|
||||||
test_random.o: test_random.c
|
test_random.o: test_random.c
|
||||||
${CC} ${CCMAIN} ${CCOPT} ${ALLOW_CUSTOM} test_random.c -c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} test_random.c -c
|
||||||
|
|
||||||
test_random: test_random.o ../libcalc.a
|
test_random: test_random.o ../libcalc.a
|
||||||
${CC} ${LDFLAGS} test_random.o ${CALC_LIBS} ${LD_DEBUG} -o test_random
|
${CC} ${LDFLAGS} test_random.o ${CALC_LIBS} ${LD_DEBUG} -o test_random
|
||||||
|
|
||||||
many_random.o: many_random.c
|
many_random.o: many_random.c
|
||||||
${CC} ${CCMAIN} ${CCOPT} ${ALLOW_CUSTOM} many_random.c -c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} many_random.c -c
|
||||||
|
|
||||||
many_random: many_random.o ../libcalc.a
|
many_random: many_random.o ../libcalc.a
|
||||||
${CC} ${LDFLAGS} many_random.o ${CALC_LIBS} ${LD_DEBUG} -o many_random
|
${CC} ${LDFLAGS} many_random.o ${CALC_LIBS} ${LD_DEBUG} -o many_random
|
||||||
|
14
seed.c
14
seed.c
@@ -52,7 +52,9 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
#include <setjmp.h>
|
#include <setjmp.h>
|
||||||
|
#if !defined(__bsdi)
|
||||||
#include <ustat.h>
|
#include <ustat.h>
|
||||||
|
#endif /* __bsdi */
|
||||||
#if defined(__linux)
|
#if defined(__linux)
|
||||||
# include <fcntl.h>
|
# include <fcntl.h>
|
||||||
# define DEV_URANDOM "/dev/urandom"
|
# define DEV_URANDOM "/dev/urandom"
|
||||||
@@ -214,8 +216,6 @@ pseudo_seed(void)
|
|||||||
char urandom_pool[DEV_URANDOM_POOL]; /* /dev/urandom data pool */
|
char urandom_pool[DEV_URANDOM_POOL]; /* /dev/urandom data pool */
|
||||||
#endif /* __linux */
|
#endif /* __linux */
|
||||||
struct timeval tp; /* time of day */
|
struct timeval tp; /* time of day */
|
||||||
pid_t getsid; /* session ID */
|
|
||||||
pid_t getpgid; /* process group ID */
|
|
||||||
pid_t getpid; /* process ID */
|
pid_t getpid; /* process ID */
|
||||||
pid_t getppid; /* parent process ID */
|
pid_t getppid; /* parent process ID */
|
||||||
uid_t getuid; /* real user ID */
|
uid_t getuid; /* real user ID */
|
||||||
@@ -229,6 +229,7 @@ pseudo_seed(void)
|
|||||||
struct stat fstat_stdin; /* stat of stdin */
|
struct stat fstat_stdin; /* stat of stdin */
|
||||||
struct stat fstat_stdout; /* stat of stdout */
|
struct stat fstat_stdout; /* stat of stdout */
|
||||||
struct stat fstat_stderr; /* stat of stderr */
|
struct stat fstat_stderr; /* stat of stderr */
|
||||||
|
#if !defined(__bsdi)
|
||||||
struct ustat ustat_dot; /* usage stat of "." */
|
struct ustat ustat_dot; /* usage stat of "." */
|
||||||
struct ustat ustat_dotdot; /* usage stat of ".." */
|
struct ustat ustat_dotdot; /* usage stat of ".." */
|
||||||
struct ustat ustat_tmp; /* usage stat of "/tmp" */
|
struct ustat ustat_tmp; /* usage stat of "/tmp" */
|
||||||
@@ -236,6 +237,9 @@ pseudo_seed(void)
|
|||||||
struct ustat ustat_stdin; /* usage stat of stdin */
|
struct ustat ustat_stdin; /* usage stat of stdin */
|
||||||
struct ustat ustat_stdout; /* usage stat of stdout */
|
struct ustat ustat_stdout; /* usage stat of stdout */
|
||||||
struct ustat ustat_stderr; /* usage stat of stderr */
|
struct ustat ustat_stderr; /* usage stat of stderr */
|
||||||
|
pid_t getsid; /* session ID */
|
||||||
|
pid_t getpgid; /* process group ID */
|
||||||
|
#endif /* __bsdi */
|
||||||
struct rusage rusage; /* resource utilization */
|
struct rusage rusage; /* resource utilization */
|
||||||
struct rusage rusage_chld; /* resource utilization of children */
|
struct rusage rusage_chld; /* resource utilization of children */
|
||||||
struct timeval tp2; /* time of day again */
|
struct timeval tp2; /* time of day again */
|
||||||
@@ -271,8 +275,6 @@ pseudo_seed(void)
|
|||||||
}
|
}
|
||||||
#endif /* __linux */
|
#endif /* __linux */
|
||||||
(void) gettimeofday(&sdata.tp, NULL);
|
(void) gettimeofday(&sdata.tp, NULL);
|
||||||
sdata.getsid = getsid((pid_t)0);
|
|
||||||
sdata.getpgid = getpgid((pid_t)0);
|
|
||||||
sdata.getpid = getpid();
|
sdata.getpid = getpid();
|
||||||
sdata.getppid = getppid();
|
sdata.getppid = getppid();
|
||||||
sdata.getuid = getuid();
|
sdata.getuid = getuid();
|
||||||
@@ -286,6 +288,7 @@ pseudo_seed(void)
|
|||||||
(void) fstat(0, &sdata.fstat_stdin);
|
(void) fstat(0, &sdata.fstat_stdin);
|
||||||
(void) fstat(1, &sdata.fstat_stdout);
|
(void) fstat(1, &sdata.fstat_stdout);
|
||||||
(void) fstat(2, &sdata.fstat_stderr);
|
(void) fstat(2, &sdata.fstat_stderr);
|
||||||
|
#if !defined(__bsdi)
|
||||||
(void) ustat(sdata.stat_dotdot.st_dev, &sdata.ustat_dotdot);
|
(void) ustat(sdata.stat_dotdot.st_dev, &sdata.ustat_dotdot);
|
||||||
(void) ustat(sdata.stat_dot.st_dev, &sdata.ustat_dot);
|
(void) ustat(sdata.stat_dot.st_dev, &sdata.ustat_dot);
|
||||||
(void) ustat(sdata.stat_tmp.st_dev, &sdata.ustat_tmp);
|
(void) ustat(sdata.stat_tmp.st_dev, &sdata.ustat_tmp);
|
||||||
@@ -293,6 +296,9 @@ pseudo_seed(void)
|
|||||||
(void) ustat(sdata.fstat_stdin.st_dev, &sdata.ustat_stdin);
|
(void) ustat(sdata.fstat_stdin.st_dev, &sdata.ustat_stdin);
|
||||||
(void) ustat(sdata.fstat_stdout.st_dev, &sdata.ustat_stdout);
|
(void) ustat(sdata.fstat_stdout.st_dev, &sdata.ustat_stdout);
|
||||||
(void) ustat(sdata.fstat_stderr.st_dev, &sdata.ustat_stderr);
|
(void) ustat(sdata.fstat_stderr.st_dev, &sdata.ustat_stderr);
|
||||||
|
sdata.getsid = getsid((pid_t)0);
|
||||||
|
sdata.getpgid = getpgid((pid_t)0);
|
||||||
|
#endif /* __bsdi */
|
||||||
(void) getrusage(RUSAGE_SELF, &sdata.rusage);
|
(void) getrusage(RUSAGE_SELF, &sdata.rusage);
|
||||||
(void) getrusage(RUSAGE_CHILDREN, &sdata.rusage_chld);
|
(void) getrusage(RUSAGE_CHILDREN, &sdata.rusage_chld);
|
||||||
(void) gettimeofday(&sdata.tp2, NULL);
|
(void) gettimeofday(&sdata.tp2, NULL);
|
||||||
|
2
string.c
2
string.c
@@ -1142,7 +1142,7 @@ initstrings(void)
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* addstring is called only from token.c
|
* addstring is called only from token.c
|
||||||
* When called, len is length if string including '\0'
|
* When called, len is length of string including '\0'
|
||||||
*/
|
*/
|
||||||
long
|
long
|
||||||
addstring(char *str, long len)
|
addstring(char *str, long len)
|
||||||
|
5
token.c
5
token.c
@@ -458,6 +458,7 @@ eatstring(int quotechar)
|
|||||||
}
|
}
|
||||||
memcpy(str + totlen, buf, len);
|
memcpy(str + totlen, buf, len);
|
||||||
totlen += len;
|
totlen += len;
|
||||||
|
len = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
curtoken.t_strindex = addstring(str, totlen + len);
|
curtoken.t_strindex = addstring(str, totlen + len);
|
||||||
@@ -643,6 +644,10 @@ scanerror(int skip, char *fmt, ...)
|
|||||||
va_end(ap);
|
va_end(ap);
|
||||||
fprintf(stderr, "%s\n", buf);
|
fprintf(stderr, "%s\n", buf);
|
||||||
|
|
||||||
|
/* bail out if continuation not permitted */
|
||||||
|
if ((!c_flag && !stoponerror) || stoponerror > 0)
|
||||||
|
longjmp(jmpbuf, 1);
|
||||||
|
|
||||||
/* bail out if too many errors */
|
/* bail out if too many errors */
|
||||||
if (conf->maxscancount > 0 && errorcount > conf->maxscancount) {
|
if (conf->maxscancount > 0 && errorcount > conf->maxscancount) {
|
||||||
fputs("Too many scan errors, compilation aborted.\n", stderr);
|
fputs("Too many scan errors, compilation aborted.\n", stderr);
|
||||||
|
@@ -12,7 +12,7 @@
|
|||||||
#define MAJOR_VER 2 /* major version */
|
#define MAJOR_VER 2 /* major version */
|
||||||
#define MINOR_VER 11 /* minor version */
|
#define MINOR_VER 11 /* minor version */
|
||||||
#define MAJOR_PATCH 0 /* patch level or 0 if no patch */
|
#define MAJOR_PATCH 0 /* patch level or 0 if no patch */
|
||||||
#define MINOR_PATCH "7.1" /* test number or empty string if no patch */
|
#define MINOR_PATCH "7.4" /* test number or empty string if no patch */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version constants
|
* calc version constants
|
||||||
|
106
zrandom.c
106
zrandom.c
@@ -1571,6 +1571,12 @@ static RANDOM random_pregen[BLUM_PREGEN] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* forward static declarations
|
||||||
|
*/
|
||||||
|
static void zfree_random(ZVALUE z);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* zsrandom1 - seed the Blum generator 1 arg style
|
* zsrandom1 - seed the Blum generator 1 arg style
|
||||||
*
|
*
|
||||||
@@ -1647,7 +1653,7 @@ zsrandom1(CONST ZVALUE seed, BOOL need_ret)
|
|||||||
do {
|
do {
|
||||||
/* free temp storage */
|
/* free temp storage */
|
||||||
if (last_r.v != NULL) {
|
if (last_r.v != NULL) {
|
||||||
zfree(last_r);
|
zfree_random(last_r);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -1657,10 +1663,10 @@ zsrandom1(CONST ZVALUE seed, BOOL need_ret)
|
|||||||
last_r = r;
|
last_r = r;
|
||||||
zsquaremod(last_r, blum.n, &r);
|
zsquaremod(last_r, blum.n, &r);
|
||||||
} while (zrel(r, last_r) > 0);
|
} while (zrel(r, last_r) > 0);
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
blum.r = r;
|
blum.r = r;
|
||||||
/* free temp storage */
|
/* free temp storage */
|
||||||
zfree(last_r);
|
zfree_random(last_r);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* reserved seed
|
* reserved seed
|
||||||
@@ -1741,7 +1747,7 @@ zsrandom2(CONST ZVALUE seed, CONST ZVALUE newn)
|
|||||||
math_error("srandom small newn must be [1,20]");
|
math_error("srandom small newn must be [1,20]");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
zfree(blum.n);
|
zfree_random(blum.n);
|
||||||
zcopy(random_pregen[set-1].n, &blum.n);
|
zcopy(random_pregen[set-1].n, &blum.n);
|
||||||
blum.loglogn = random_pregen[set-1].loglogn;
|
blum.loglogn = random_pregen[set-1].loglogn;
|
||||||
blum.mask = random_pregen[set-1].mask;
|
blum.mask = random_pregen[set-1].mask;
|
||||||
@@ -1750,7 +1756,7 @@ zsrandom2(CONST ZVALUE seed, CONST ZVALUE newn)
|
|||||||
* reset initial seed as well if seed is 0
|
* reset initial seed as well if seed is 0
|
||||||
*/
|
*/
|
||||||
if (ziszero(seed)) {
|
if (ziszero(seed)) {
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
zcopy(random_pregen[set-1].r, &blum.r);
|
zcopy(random_pregen[set-1].r, &blum.r);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -1785,7 +1791,7 @@ zsrandom2(CONST ZVALUE seed, CONST ZVALUE newn)
|
|||||||
* of two primes.
|
* of two primes.
|
||||||
*/
|
*/
|
||||||
/* load modulus */
|
/* load modulus */
|
||||||
zfree(blum.n);
|
zfree_random(blum.n);
|
||||||
zcopy(newn, &blum.n);
|
zcopy(newn, &blum.n);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -1894,11 +1900,11 @@ zsrandom4(CONST ZVALUE seed, CONST ZVALUE ip, CONST ZVALUE iq, long trials)
|
|||||||
/*
|
/*
|
||||||
* form the Blum modulus
|
* form the Blum modulus
|
||||||
*/
|
*/
|
||||||
zfree(blum.n);
|
zfree_random(blum.n);
|
||||||
zmul(p, q, &blum.n);
|
zmul(p, q, &blum.n);
|
||||||
/* free temp storage */
|
/* free temp storage */
|
||||||
zfree(p);
|
zfree_random(p);
|
||||||
zfree(q);
|
zfree_random(q);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* form the loglogn and mask
|
* form the loglogn and mask
|
||||||
@@ -2045,7 +2051,7 @@ zrandomskip(long cnt)
|
|||||||
|
|
||||||
/* turn the Blum-Blum-Shub crank */
|
/* turn the Blum-Blum-Shub crank */
|
||||||
zsquaremod(blum.r, blum.n, &new_r);
|
zsquaremod(blum.r, blum.n, &new_r);
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
blum.r = new_r;
|
blum.r = new_r;
|
||||||
cnt -= blum.loglogn;
|
cnt -= blum.loglogn;
|
||||||
}
|
}
|
||||||
@@ -2057,7 +2063,7 @@ zrandomskip(long cnt)
|
|||||||
|
|
||||||
/* turn the Blum-Blum-Shub crank */
|
/* turn the Blum-Blum-Shub crank */
|
||||||
zsquaremod(blum.r, blum.n, &new_r);
|
zsquaremod(blum.r, blum.n, &new_r);
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
blum.r = new_r;
|
blum.r = new_r;
|
||||||
|
|
||||||
/* fill the buffer with the unused bits */
|
/* fill the buffer with the unused bits */
|
||||||
@@ -2197,7 +2203,7 @@ zrandom(long cnt, ZVALUE *res)
|
|||||||
* turn the Blum-Blum-Shub crank
|
* turn the Blum-Blum-Shub crank
|
||||||
*/
|
*/
|
||||||
zsquaremod(blum.r, blum.n, &new_r);
|
zsquaremod(blum.r, blum.n, &new_r);
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
blum.r = new_r;
|
blum.r = new_r;
|
||||||
/* peal off the bottom loglogn bits */
|
/* peal off the bottom loglogn bits */
|
||||||
blum.buffer = (blum.r.v[0] & mask);
|
blum.buffer = (blum.r.v[0] & mask);
|
||||||
@@ -2228,7 +2234,7 @@ zrandom(long cnt, ZVALUE *res)
|
|||||||
*/
|
*/
|
||||||
/* turn the Blum-Blum-Shub crank */
|
/* turn the Blum-Blum-Shub crank */
|
||||||
zsquaremod(blum.r, blum.n, &new_r);
|
zsquaremod(blum.r, blum.n, &new_r);
|
||||||
zfree(blum.r);
|
zfree_random(blum.r);
|
||||||
blum.r = new_r;
|
blum.r = new_r;
|
||||||
/* peal off the bottom loglogn bits */
|
/* peal off the bottom loglogn bits */
|
||||||
blum.buffer = (blum.r.v[0] & mask);
|
blum.buffer = (blum.r.v[0] & mask);
|
||||||
@@ -2282,13 +2288,13 @@ zrandomrange(CONST ZVALUE low, CONST ZVALUE high, ZVALUE *res)
|
|||||||
*/
|
*/
|
||||||
zsub(high, low, &range);
|
zsub(high, low, &range);
|
||||||
if (zisone(range)) {
|
if (zisone(range)) {
|
||||||
zfree(range);
|
zfree_random(range);
|
||||||
*res = low;
|
*res = low;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
zsub(range, _one_, &rangem1);
|
zsub(range, _one_, &rangem1);
|
||||||
bitlen = 1+zhighbit(rangem1);
|
bitlen = 1+zhighbit(rangem1);
|
||||||
zfree(rangem1);
|
zfree_random(rangem1);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* generate a random value between [0, diff)
|
* generate a random value between [0, diff)
|
||||||
@@ -2302,7 +2308,7 @@ zrandomrange(CONST ZVALUE low, CONST ZVALUE high, ZVALUE *res)
|
|||||||
rval.v = NULL;
|
rval.v = NULL;
|
||||||
do {
|
do {
|
||||||
if (rval.v != NULL) {
|
if (rval.v != NULL) {
|
||||||
zfree(rval);
|
zfree_random(rval);
|
||||||
}
|
}
|
||||||
zrandom(bitlen, &rval);
|
zrandom(bitlen, &rval);
|
||||||
} while (zrel(rval, range) >= 0);
|
} while (zrel(rval, range) >= 0);
|
||||||
@@ -2312,8 +2318,8 @@ zrandomrange(CONST ZVALUE low, CONST ZVALUE high, ZVALUE *res)
|
|||||||
* which is the range [low, high)
|
* which is the range [low, high)
|
||||||
*/
|
*/
|
||||||
zadd(rval, low, res);
|
zadd(rval, low, res);
|
||||||
zfree(rval);
|
zfree_random(rval);
|
||||||
zfree(range);
|
zfree_random(range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -2341,8 +2347,8 @@ irandom(long s)
|
|||||||
itoz(s, &z1);
|
itoz(s, &z1);
|
||||||
zrandomrange(_zero_, z1, &z2);
|
zrandomrange(_zero_, z1, &z2);
|
||||||
res = ztoi(z2);
|
res = ztoi(z2);
|
||||||
zfree(z1);
|
zfree_random(z1);
|
||||||
zfree(z2);
|
zfree_random(z2);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2377,12 +2383,20 @@ randomcopy(CONST RANDOM *state)
|
|||||||
if (state->r.v == NULL) {
|
if (state->r.v == NULL) {
|
||||||
ret->r.v = NULL;
|
ret->r.v = NULL;
|
||||||
} else {
|
} else {
|
||||||
zcopy(state->r, &ret->r);
|
if (state->r.v == h_rdefvec) {
|
||||||
|
ret->r.v = state->r.v;
|
||||||
|
} else {
|
||||||
|
zcopy(state->r, &ret->r);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (state->n.v == NULL) {
|
if (state->n.v == NULL) {
|
||||||
ret->n.v = NULL;
|
ret->n.v = NULL;
|
||||||
} else {
|
} else {
|
||||||
zcopy(state->n, &ret->n);
|
if (state->n.v == h_ndefvec) {
|
||||||
|
ret->n.v = state->n.v;
|
||||||
|
} else {
|
||||||
|
zcopy(state->n, &ret->n);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -2414,12 +2428,8 @@ randomfree(RANDOM *state)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* free the values */
|
/* free the values */
|
||||||
if (state->n.v != h_ndefvec) {
|
zfree_random(state->n);
|
||||||
zfree(state->n);
|
zfree_random(state->r);
|
||||||
}
|
|
||||||
if (state->r.v != h_rdefvec) {
|
|
||||||
zfree(state->r);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* free it if it is not pre-defined */
|
/* free it if it is not pre-defined */
|
||||||
state->seeded = 0;
|
state->seeded = 0;
|
||||||
@@ -2505,9 +2515,43 @@ randomprint(CONST RANDOM *state, int flags)
|
|||||||
void
|
void
|
||||||
random_libcalc_cleanup(void)
|
random_libcalc_cleanup(void)
|
||||||
{
|
{
|
||||||
/* free if we are seeded now */
|
/* free our state - let zfree_random protect the default state */
|
||||||
if (blum.seeded) {
|
randomfree(&blum);
|
||||||
randomfree(&blum);
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* zfree_random - perform a zfree if we are not trying to free static data
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* z the ZVALUE to zfree(z) if not pointing to static data
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
zfree_random(ZVALUE z)
|
||||||
|
{
|
||||||
|
if (z.v != h_ndefvec && z.v != h_rdefvec && z.v != h_rdefvec_2 &&
|
||||||
|
z.v != h_nvec01 && z.v != h_rvec01 &&
|
||||||
|
z.v != h_nvec02 && z.v != h_rvec02 &&
|
||||||
|
z.v != h_nvec03 && z.v != h_rvec03 &&
|
||||||
|
z.v != h_nvec04 && z.v != h_rvec04 &&
|
||||||
|
z.v != h_nvec05 && z.v != h_rvec05 &&
|
||||||
|
z.v != h_nvec06 && z.v != h_rvec06 &&
|
||||||
|
z.v != h_nvec07 && z.v != h_rvec07 &&
|
||||||
|
z.v != h_nvec08 && z.v != h_rvec08 &&
|
||||||
|
z.v != h_nvec09 && z.v != h_rvec09 &&
|
||||||
|
z.v != h_nvec10 && z.v != h_rvec10 &&
|
||||||
|
z.v != h_nvec11 && z.v != h_rvec11 &&
|
||||||
|
z.v != h_nvec12 && z.v != h_rvec12 &&
|
||||||
|
z.v != h_nvec13 && z.v != h_rvec13 &&
|
||||||
|
z.v != h_nvec14 && z.v != h_rvec14 &&
|
||||||
|
z.v != h_nvec15 && z.v != h_rvec15 &&
|
||||||
|
z.v != h_nvec16 && z.v != h_rvec16 &&
|
||||||
|
z.v != h_nvec17 && z.v != h_rvec17 &&
|
||||||
|
z.v != h_nvec18 && z.v != h_rvec18 &&
|
||||||
|
z.v != h_nvec19 && z.v != h_rvec19 &&
|
||||||
|
z.v != h_nvec20 && z.v != h_rvec20) {
|
||||||
|
zfree(z);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user