mirror of
https://github.com/lcn2/calc.git
synced 2025-08-16 01:03:29 +03:00
Release calc version 2.11.0t9.3.1
This commit is contained in:
20
BUGS
20
BUGS
@@ -97,7 +97,7 @@ Known bugs:
|
|||||||
had been executed.
|
had been executed.
|
||||||
|
|
||||||
* Dec Alpha Linux compiling with gcc-2.95.1 (or gcc-2.95.2) and
|
* Dec Alpha Linux compiling with gcc-2.95.1 (or gcc-2.95.2) and
|
||||||
-O2 fails the regression test with:
|
-O2 fails the version 2.11.0t8.10 regression test with:
|
||||||
|
|
||||||
make -s check
|
make -s check
|
||||||
000: Beginning regression tests
|
000: Beginning regression tests
|
||||||
@@ -117,6 +117,24 @@ Known bugs:
|
|||||||
One work-a-round is to not compile with -O2 (perhaps just -O).
|
One work-a-round is to not compile with -O2 (perhaps just -O).
|
||||||
Another work-a-round is not use gcc-2.95.1.
|
Another work-a-round is not use gcc-2.95.1.
|
||||||
|
|
||||||
|
* On a Digital UNIX V4.0F (Rev. 1229) on a 500 Mhz 21264, make check
|
||||||
|
dies a horrible death starting in test 600 and 622 gives 100s of
|
||||||
|
messages for calc version 2.11.0t9.2 using the Dec's cc with -O2
|
||||||
|
and without -std0:
|
||||||
|
|
||||||
|
600: Beginning test_bignums
|
||||||
|
601: muldivcheck 1
|
||||||
|
**** abc != acb: 602: muldivcheck 2
|
||||||
|
**** acb != bac: 602: muldivcheck 2
|
||||||
|
...
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
|
**** t5 != a5: 622: algcheck 1
|
||||||
|
**** t6 != a6: 622: algcheck 1
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
|
...
|
||||||
|
|
||||||
|
it finally hangs at test 2000.
|
||||||
|
|
||||||
We are sure some more bugs exist. When you find them, please let
|
We are sure some more bugs exist. When you find them, please let
|
||||||
us know! See the above for details on how to report and were to
|
us know! See the above for details on how to report and were to
|
||||||
EMail your bug reports and hopefully patches to fix them.
|
EMail your bug reports and hopefully patches to fix them.
|
||||||
|
32
CHANGES
32
CHANGES
@@ -84,6 +84,38 @@ Following is the change from calc version 2.11.0t8.9.1 to date:
|
|||||||
|
|
||||||
5 Report on changes to the run state of calc.
|
5 Report on changes to the run state of calc.
|
||||||
|
|
||||||
|
Fixed portability issue in seed.c relating to /dev/urandom and ustat.
|
||||||
|
|
||||||
|
Added a fix from Martin Buck <mb@netwings.ch> to detect when
|
||||||
|
calc aborts early instead of completing the regression test.
|
||||||
|
Now 'make chk' will require the last line of calc output to
|
||||||
|
end in the string ``Ending regression tests''.
|
||||||
|
|
||||||
|
Added a patch from Martin Buck <mb@netwings.ch> to allow use of
|
||||||
|
GNU-readline. Note that GNU-readline is not shipped with calc.
|
||||||
|
His patch only provides the hooks to use it. One must comment out:
|
||||||
|
|
||||||
|
USE_READLINE=
|
||||||
|
READLINE_LIB=
|
||||||
|
READLINE_INCLUDE=
|
||||||
|
|
||||||
|
and comment in:
|
||||||
|
|
||||||
|
USE_READLINE= -DUSE_READLINE
|
||||||
|
READLINE_LIB= -lreadline -lhistory
|
||||||
|
READLINE_INCLUDE= -I/usr/include/readline
|
||||||
|
|
||||||
|
in addition to pre-installing GNU-readline in your system to use
|
||||||
|
this facility.
|
||||||
|
|
||||||
|
Changed the "object already defined" math_error message to a
|
||||||
|
scanerror message.
|
||||||
|
|
||||||
|
Removed the limit on the number of object types.
|
||||||
|
|
||||||
|
Calc tarballs are now named calc-version.tar.gz and untar into
|
||||||
|
a sub-directory called calc-version.
|
||||||
|
|
||||||
|
|
||||||
Following is the change from calc version 2.11.0t8 to 2.11.0t8.9:
|
Following is the change from calc version 2.11.0t8 to 2.11.0t8.9:
|
||||||
|
|
||||||
|
71
Makefile
71
Makefile
@@ -414,9 +414,37 @@ CALCRC= ${LIBDIR}/startup:~/.calcrc
|
|||||||
# ${LIBDIR}/bindings uses ^D for editing
|
# ${LIBDIR}/bindings uses ^D for editing
|
||||||
# ${LIBDIR}/altbind uses ^D for EOF
|
# ${LIBDIR}/altbind uses ^D for EOF
|
||||||
#
|
#
|
||||||
|
# NOTE: This facility is disabled if USE_READLINE is set to -DUSE_READLINE.
|
||||||
|
#
|
||||||
CALCBINDINGS= bindings
|
CALCBINDINGS= bindings
|
||||||
#CALCBINDINGS= altbind
|
#CALCBINDINGS= altbind
|
||||||
|
|
||||||
|
# Determine of the GNU-readline facility will be used instead of the
|
||||||
|
# built-in CALCBINDINGS above.
|
||||||
|
#
|
||||||
|
# USE_READLINE= Do not use GNU-readline, use CALCBINDINGS
|
||||||
|
# USE_READLINE= -DUSE_READLINE Use GNU-readline, do not use CALCBINDINGS
|
||||||
|
#
|
||||||
|
# NOTE: If you select the 'USE_READLINE= -DUSE_READLINE' mode, you must set:
|
||||||
|
#
|
||||||
|
# READLINE_LIB The flags needed to link in the readline
|
||||||
|
# and history libs
|
||||||
|
# READLINE_INCLUDE Where the readline include files reside
|
||||||
|
#
|
||||||
|
# NOTE: The GNU-readline code is not shipped with calc. You must have
|
||||||
|
# the appropriate headers and libs installed on your system in
|
||||||
|
# order to use it.
|
||||||
|
#
|
||||||
|
# If in doubt, set USE_READLINE, READLINE_LIB and READLINE_INCLUDE to nothing.
|
||||||
|
#
|
||||||
|
USE_READLINE=
|
||||||
|
READLINE_LIB=
|
||||||
|
READLINE_INCLUDE=
|
||||||
|
#
|
||||||
|
#USE_READLINE= -DUSE_READLINE
|
||||||
|
#READLINE_LIB= -lreadline -lhistory
|
||||||
|
#READLINE_INCLUDE= -I/usr/include/readline
|
||||||
|
|
||||||
# If $PAGER is not set, use this program to display a help file
|
# If $PAGER is not set, use this program to display a help file
|
||||||
#
|
#
|
||||||
CALCPAGER= more
|
CALCPAGER= more
|
||||||
@@ -913,7 +941,7 @@ UTIL_OBJS= endian.o longbits.o have_newstr.o have_uid_t.o \
|
|||||||
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
||||||
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o calc_errno.o \
|
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o calc_errno.o \
|
||||||
have_ustat.o have_getsid.o have_getpgid.o \
|
have_ustat.o have_getsid.o have_getpgid.o \
|
||||||
have_gettime.o have_getprid.o
|
have_gettime.o have_getprid.o ver_calc.o
|
||||||
|
|
||||||
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
||||||
#
|
#
|
||||||
@@ -926,7 +954,7 @@ UTIL_TMP= ll_tmp fpos_tmp fposv_tmp const_tmp uid_tmp newstr_tmp vs_tmp \
|
|||||||
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
||||||
endian longbits have_newstr have_stdvs have_varvs calc_errno \
|
endian longbits have_newstr have_stdvs have_varvs calc_errno \
|
||||||
have_ustat have_getsid have_getpgid \
|
have_ustat have_getsid have_getpgid \
|
||||||
have_gettime have_getprid
|
have_gettime have_getprid ver_calc
|
||||||
|
|
||||||
# These files are required by the regress.cal regression test.
|
# These files are required by the regress.cal regression test.
|
||||||
#
|
#
|
||||||
@@ -984,7 +1012,7 @@ SAMPLE_PASSDOWN= Q="${Q}" \
|
|||||||
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 ${READLINE_LIB}" \
|
||||||
LCC="${LCC}" \
|
LCC="${LCC}" \
|
||||||
CC="${CC}" \
|
CC="${CC}" \
|
||||||
MAKE_FILE=${MAKE_FILE} \
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
@@ -1032,7 +1060,7 @@ TARGETS= ${CALC_LIBS} custom/.all calc sample/sample \
|
|||||||
all: .hsrc ${TARGETS}
|
all: .hsrc ${TARGETS}
|
||||||
|
|
||||||
calc: .hsrc ${CALC_LIBS} ${CALCOBJS}
|
calc: .hsrc ${CALC_LIBS} ${CALCOBJS}
|
||||||
${CC} ${LDFLAGS} ${CALCOBJS} ${CALC_LIBS} ${LD_DEBUG} -o calc
|
${CC} ${LDFLAGS} ${CALCOBJS} ${CALC_LIBS} ${LD_DEBUG} ${READLINE_LIB} -o calc
|
||||||
|
|
||||||
libcalc.a: ${LIBOBJS} ${MAKE_FILE}
|
libcalc.a: ${LIBOBJS} ${MAKE_FILE}
|
||||||
-rm -f libcalc.a
|
-rm -f libcalc.a
|
||||||
@@ -1059,7 +1087,7 @@ custom.o: custom.c ${MAKE_FILE}
|
|||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
||||||
|
|
||||||
hist.o: hist.c ${MAKE_FILE}
|
hist.o: hist.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${TERMCONTROL} -c hist.c
|
${CC} ${CFLAGS} ${TERMCONTROL} ${USE_READLINE} ${READLINE_INCLUDE} -c hist.c
|
||||||
|
|
||||||
func.o: func.c ${MAKE_FILE}
|
func.o: func.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
||||||
@@ -2505,6 +2533,12 @@ h_list:
|
|||||||
echo $$i; \
|
echo $$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# print the calc version
|
||||||
|
#
|
||||||
|
ver_calc: version.c
|
||||||
|
-rm -f $@
|
||||||
|
${LCC} ${ICFLAGS} -DCALC_VER ${ILDFLAGS} version.c -o $@
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# File distribution list generation. You can ignore this section.
|
# File distribution list generation. You can ignore this section.
|
||||||
@@ -2516,34 +2550,27 @@ h_list:
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}(for i in ${DISTLIST}; do \
|
${Q}(for i in ${DISTLIST}; do \
|
||||||
echo calc/$$i; \
|
echo $$i; \
|
||||||
done; \
|
done; \
|
||||||
(cd help; ${MAKE} distlist \
|
(cd help; ${MAKE} distlist \
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
||||||
(cd lib; ${MAKE} distlist \
|
(cd lib; ${MAKE} distlist \
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}) ) | ${SORT}; \
|
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
||||||
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distlist); \
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distlist); \
|
||||||
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distlist) | ${SORT}
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distlist)) | ${SORT}
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
# The the .h files are placed under calc/gen_h.
|
${Q}(echo .; \
|
||||||
#
|
(cd help; ${MAKE} distdir \
|
||||||
bsdilist: ${DISTLIST} ${BUILD_H_SRC} calc.1
|
|
||||||
${Q}(for i in ${DISTLIST}; do \
|
|
||||||
echo calc/$$i; \
|
|
||||||
done; \
|
|
||||||
for i in ${BUILD_H_SRC}; do \
|
|
||||||
echo calc/gen_h/$$i; \
|
|
||||||
done; \
|
|
||||||
echo calc/calc.1; \
|
|
||||||
(cd help; ${MAKE} bsdilist \
|
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
||||||
(cd lib; ${MAKE} bsdilist \
|
(cd lib; ${MAKE} distdir \
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}) ) | ${SORT}
|
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
||||||
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distdir); \
|
||||||
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distdir)) | ${SORT}
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
|
1
calc.h
1
calc.h
@@ -38,7 +38,6 @@
|
|||||||
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
||||||
#define MAXINDICES 20 /* maximum number of indices for objects */
|
#define MAXINDICES 20 /* maximum number of indices for objects */
|
||||||
#define MAXLABELS 100 /* maximum number of user labels in function */
|
#define MAXLABELS 100 /* maximum number of user labels in function */
|
||||||
#define MAXOBJECTS 128 /* maximum number of object types */
|
|
||||||
#define MAXSTRING 1024 /* maximum size of string constant */
|
#define MAXSTRING 1024 /* maximum size of string constant */
|
||||||
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
||||||
#define MAXFILES 20 /* maximum number of opened files */
|
#define MAXFILES 20 /* maximum number of opened files */
|
||||||
|
3
calc.man
3
calc.man
@@ -559,6 +559,9 @@ by this environment variable.
|
|||||||
.sp
|
.sp
|
||||||
Default value: ${CALCBINDINGS}
|
Default value: ${CALCBINDINGS}
|
||||||
.sp
|
.sp
|
||||||
|
This variable is not used if calc was compiled with GNU-readline support.
|
||||||
|
In that case, the standard readline mechanisms (see readline(3)) are used.
|
||||||
|
.sp
|
||||||
.SH CREDIT
|
.SH CREDIT
|
||||||
\&
|
\&
|
||||||
.br
|
.br
|
||||||
|
@@ -11,6 +11,7 @@ BEGIN {
|
|||||||
havebuf2=0;
|
havebuf2=0;
|
||||||
buf2=0;
|
buf2=0;
|
||||||
error = 0;
|
error = 0;
|
||||||
|
end_seen = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
NF == 0 {
|
NF == 0 {
|
||||||
@@ -29,6 +30,10 @@ NF == 0 {
|
|||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/: Ending regression tests$/ {
|
||||||
|
end_seen = 1;
|
||||||
|
}
|
||||||
|
|
||||||
$1 ~ /^[0-9]+:/ {
|
$1 ~ /^[0-9]+:/ {
|
||||||
if (error > 0) {
|
if (error > 0) {
|
||||||
if (havebuf2) {
|
if (havebuf2) {
|
||||||
@@ -71,7 +76,7 @@ END {
|
|||||||
if (error > 0 && havebuf0) {
|
if (error > 0 && havebuf0) {
|
||||||
print buf0;
|
print buf0;
|
||||||
}
|
}
|
||||||
if (error > 0) {
|
if (error > 0 || !end_seen) {
|
||||||
exit(1);
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
exit(0);
|
exit(0);
|
||||||
|
12
codegen.c
12
codegen.c
@@ -382,7 +382,7 @@ getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaul
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case T_EOF:
|
case T_EOF:
|
||||||
scanerror(T_SEMICOLON, "End-of-file in function body");
|
scanerror(T_NULL, "End-of-file in function body");
|
||||||
return;
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -995,7 +995,11 @@ getobjdeclaration(int symtype)
|
|||||||
/*FALLTHRU*/
|
/*FALLTHRU*/
|
||||||
case T_RIGHTBRACE:
|
case T_RIGHTBRACE:
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
(void) defineobject(name, indices, count);
|
if (defineobject(name, indices, count)) {
|
||||||
|
scanerror(T_NULL,
|
||||||
|
"Object type \"%s\" is already defined", name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
getobjvars(name, symtype);
|
getobjvars(name, symtype);
|
||||||
return;
|
return;
|
||||||
case T_NEWLINE:
|
case T_NEWLINE:
|
||||||
@@ -1350,7 +1354,7 @@ getopassignment(void)
|
|||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
if (isrvalue(type)) {
|
if (isrvalue(type)) {
|
||||||
scanerror(T_NULL, "Illegal assignment in getopassignment");
|
scanerror(T_NULL, "Illegal assignment");
|
||||||
(void) getopassignment();
|
(void) getopassignment();
|
||||||
return (EXPR_RVALUE | EXPR_ASSIGN);
|
return (EXPR_RVALUE | EXPR_ASSIGN);
|
||||||
}
|
}
|
||||||
@@ -1443,7 +1447,7 @@ getassignment (void)
|
|||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
if (isrvalue(type)) {
|
if (isrvalue(type)) {
|
||||||
scanerror(T_SEMICOLON, "Illegal assignment in getassignment");
|
scanerror(T_SEMICOLON, "Illegal assignment");
|
||||||
(void) getassignment();
|
(void) getassignment();
|
||||||
return (EXPR_RVALUE | EXPR_ASSIGN);
|
return (EXPR_RVALUE | EXPR_ASSIGN);
|
||||||
}
|
}
|
||||||
|
@@ -337,15 +337,11 @@ libcustcalc.a: ${CUSTCALC_OBJ} ${MAKE_FILE} ../Makefile
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/custom/$$i; \
|
echo custom/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo custom
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/custom/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
|
@@ -108,7 +108,6 @@ static struct infoname sys_info[] = {
|
|||||||
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
||||||
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
||||||
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
||||||
{"MAXOBJECTS", "max number of object types", NULL, (FULL)MAXOBJECTS},
|
|
||||||
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
||||||
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
||||||
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
||||||
|
@@ -394,15 +394,11 @@ builtin: builtin.top builtin.end ../func.c funclist.sed
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/help/$$i; \
|
echo help/$$i; \
|
||||||
done | ${SORT}
|
done | ${SORT}
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo help
|
||||||
bsdilist: ${DISTLIST} ${BLT_HELP_FILES}
|
|
||||||
${Q}for i in ${DISTLIST} ${BLT_HELP_FILES}; do \
|
|
||||||
echo calc/help/$$i; \
|
|
||||||
done | ${SORT}
|
|
||||||
|
|
||||||
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
||||||
# creats these fils so that the release can be shipped off to BSDI. You can
|
# creats these fils so that the release can be shipped off to BSDI. You can
|
||||||
|
@@ -58,6 +58,10 @@ Environment variables
|
|||||||
a terminal, then calc will still run, but fancy command line
|
a terminal, then calc will still run, but fancy command line
|
||||||
editing is disabled.
|
editing is disabled.
|
||||||
|
|
||||||
|
NOTE: If calc was compiled with GNU-readline support, the
|
||||||
|
CALCBINDINGS facility is ignored and the standard
|
||||||
|
readline mechanisms (see readline(3)) are used.
|
||||||
|
|
||||||
HOME
|
HOME
|
||||||
|
|
||||||
This value is taken to be the home directory of the
|
This value is taken to be the home directory of the
|
||||||
|
69
hist.c
69
hist.c
@@ -5,6 +5,8 @@
|
|||||||
*
|
*
|
||||||
* Adapted from code written by Stephen Rothwell.
|
* Adapted from code written by Stephen Rothwell.
|
||||||
*
|
*
|
||||||
|
* GNU readline support added by Martin Buck <mbuck@debian.org>
|
||||||
|
*
|
||||||
* Interactive readline module. This is called to read lines of input,
|
* Interactive readline module. This is called to read lines of input,
|
||||||
* while using emacs-like editing commands within a command stack.
|
* while using emacs-like editing commands within a command stack.
|
||||||
* The key bindings for the editing commands are (slightly) configurable.
|
* The key bindings for the editing commands are (slightly) configurable.
|
||||||
@@ -48,6 +50,8 @@
|
|||||||
# include <string.h>
|
# include <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(USE_READLINE)
|
||||||
|
|
||||||
extern FILE *curstream(void);
|
extern FILE *curstream(void);
|
||||||
|
|
||||||
#define STDIN 0
|
#define STDIN 0
|
||||||
@@ -1433,8 +1437,68 @@ quit_calc(void)
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else /* USE_READLINE */
|
||||||
|
|
||||||
#ifdef HIST_TEST
|
|
||||||
|
#include <readline.h>
|
||||||
|
#include <history.h>
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The readline/history libs do most of the dirty work for us, so we can
|
||||||
|
* replace hist_init() and hist_term() with dummies when using readline.
|
||||||
|
* For hist_getline() we have to add a newline that readline removed but
|
||||||
|
* calc expects. For hist_saveline(), we have to undo this. hist_getline()
|
||||||
|
* also has to cope with the different memory management schemes of calc and
|
||||||
|
* readline.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
hist_getline(char *prompt, char *buf, int len)
|
||||||
|
{
|
||||||
|
char *line;
|
||||||
|
|
||||||
|
buf[0] = '\0';
|
||||||
|
line = readline(prompt);
|
||||||
|
if (!line)
|
||||||
|
return 0;
|
||||||
|
strncpy(buf, line, len - 1);
|
||||||
|
buf[len - 2] = '\0';
|
||||||
|
len = strlen(buf);
|
||||||
|
buf[len] = '\n';
|
||||||
|
buf[len + 1] = '\0';
|
||||||
|
free(line);
|
||||||
|
return len + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
hist_init(char *filename)
|
||||||
|
{
|
||||||
|
return HIST_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
hist_term(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
hist_saveline(char *line, int len)
|
||||||
|
{
|
||||||
|
if (!len)
|
||||||
|
return;
|
||||||
|
line[len - 1] = '\0';
|
||||||
|
add_history(line);
|
||||||
|
line[len - 1] = '\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* USE_READLINE */
|
||||||
|
|
||||||
|
#if defined(HIST_TEST)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Main routine to test history.
|
* Main routine to test history.
|
||||||
@@ -1475,6 +1539,5 @@ main(int argc, char **argv)
|
|||||||
hist_term();
|
hist_term();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/* END CODE */
|
#endif /* HIST_TEST */
|
||||||
|
10
lib/Makefile
10
lib/Makefile
@@ -73,15 +73,11 @@ all: ${CALC_FILES} ${MAKE_FILE} .all
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/lib/$$i; \
|
echo lib/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo lib
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/lib/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
|
||||||
|
@@ -1,4 +1,8 @@
|
|||||||
# Alternate key bindings for calc line editing functions
|
# Alternate key bindings for calc line editing functions
|
||||||
|
#
|
||||||
|
# NOTE: This facility is ignored if calc was compiled with GNU-readline.
|
||||||
|
# In that case, the standard readline mechanisms (see readline(3))
|
||||||
|
# are used in place of those found below.
|
||||||
|
|
||||||
map base-map
|
map base-map
|
||||||
default insert-char
|
default insert-char
|
||||||
|
@@ -1,4 +1,8 @@
|
|||||||
# Default key bindings for calc line editing functions
|
# Default key bindings for calc line editing functions
|
||||||
|
#
|
||||||
|
# NOTE: This facility is ignored if calc was compiled with GNU-readline.
|
||||||
|
# In that case, the standard readline mechanisms (see readline(3))
|
||||||
|
# are used in place of those found below.
|
||||||
|
|
||||||
map base-map
|
map base-map
|
||||||
default insert-char
|
default insert-char
|
||||||
|
@@ -20,18 +20,17 @@ print '002: Within each section, output should be numbered sequentially';
|
|||||||
global prob; /* libregress.cal problem counter */
|
global prob; /* libregress.cal problem counter */
|
||||||
prob = 0; /* clear problem counter */
|
prob = 0; /* clear problem counter */
|
||||||
|
|
||||||
global junk; /* throw away value */
|
errcount(0),; /* clear error count */
|
||||||
junk = errcount(0); /* clear error count */
|
errmax(-1),; /* prevent errcount from abouting */
|
||||||
junk = errmax(-1); /* prevent errcount from abouting */
|
|
||||||
|
|
||||||
global ecnt; /* expected value of errcount() */
|
global ecnt; /* expected value of errcount() */
|
||||||
ecnt = 0; /* clear expected errcount() value */
|
ecnt = 0; /* clear expected errcount() value */
|
||||||
|
|
||||||
initcfg = config("all", "oldstd"); /* set config to startup default */
|
initcfg = config("all", "oldstd"); /* set config to startup default */
|
||||||
initcfg = config("lib_debug", 0); /* disable lib startup messages */
|
config("lib_debug", 0),; /* disable lib startup messages */
|
||||||
initcfg = config("calc_debug", 0); /* disable internal debugging */
|
config("calc_debug", 0),; /* disable internal debugging */
|
||||||
initcnf = config("verbose_quit", 0); /* disable quit messages */
|
config("verbose_quit", 0),; /* disable quit messages */
|
||||||
initcfg = config("all"); /* save state for later use */
|
startcfg = config("all"); /* save state for later use */
|
||||||
|
|
||||||
print '003: parsed global definitions';
|
print '003: parsed global definitions';
|
||||||
|
|
||||||
@@ -359,7 +358,7 @@ define test_config()
|
|||||||
print '502: callcfg = config("all","oldstd")';
|
print '502: callcfg = config("all","oldstd")';
|
||||||
oldcfg = config("all", "newstd");
|
oldcfg = config("all", "newstd");
|
||||||
print '503: oldcfg = config("all","newstd")';
|
print '503: oldcfg = config("all","newstd")';
|
||||||
vrfy(callcfg == initcfg, '504: callcfg == initcfg');
|
vrfy(callcfg == startcfg, '504: callcfg == startcfg');
|
||||||
newcfg = config("all");
|
newcfg = config("all");
|
||||||
print '505: newcfg = config("all")';
|
print '505: newcfg = config("all")';
|
||||||
vrfy(config("all") == newcfg, '506: config("all") == newcfg');
|
vrfy(config("all") == newcfg, '506: config("all") == newcfg');
|
||||||
@@ -457,7 +456,7 @@ define test_config()
|
|||||||
vrfy(config("all",callcfg) == oldcfg,
|
vrfy(config("all",callcfg) == oldcfg,
|
||||||
'550: config("all",callcfg) == oldcfg');
|
'550: config("all",callcfg) == oldcfg');
|
||||||
vrfy(config("all") == callcfg, '551: config("all") == callcfg');
|
vrfy(config("all") == callcfg, '551: config("all") == callcfg');
|
||||||
vrfy(config("all") == initcfg, '552: config("all") == initcfg');
|
vrfy(config("all") == startcfg, '552: config("all") == startcfg');
|
||||||
|
|
||||||
print '553: Ending test_config';
|
print '553: Ending test_config';
|
||||||
}
|
}
|
||||||
|
34
obj.c
34
obj.c
@@ -96,8 +96,10 @@ static struct objectinfo {
|
|||||||
|
|
||||||
static STRINGHEAD objectnames; /* names of objects */
|
static STRINGHEAD objectnames; /* names of objects */
|
||||||
static STRINGHEAD elements; /* element names for parts of objects */
|
static STRINGHEAD elements; /* element names for parts of objects */
|
||||||
static OBJECTACTIONS *objects[MAXOBJECTS]; /* table of actions for objects */
|
static OBJECTACTIONS **objects; /* table of actions for objects */
|
||||||
|
|
||||||
|
#define OBJALLOC 16
|
||||||
|
static long maxobjcount = 0;
|
||||||
|
|
||||||
static VALUE objpowi(VALUE *vp, NUMBER *q);
|
static VALUE objpowi(VALUE *vp, NUMBER *q);
|
||||||
static BOOL objtest(OBJECT *op);
|
static BOOL objtest(OBJECT *op);
|
||||||
@@ -456,11 +458,12 @@ objpowi(VALUE *vp, NUMBER *q)
|
|||||||
* indices table of indices for elements
|
* indices table of indices for elements
|
||||||
* count number of elements defined for the object
|
* count number of elements defined for the object
|
||||||
*/
|
*/
|
||||||
void
|
int
|
||||||
defineobject(char *name, int indices[], int count)
|
defineobject(char *name, int indices[], int count)
|
||||||
{
|
{
|
||||||
OBJECTACTIONS *oap; /* object definition structure */
|
OBJECTACTIONS *oap; /* object definition structure */
|
||||||
STRINGHEAD *hp;
|
STRINGHEAD *hp;
|
||||||
|
OBJECTACTIONS **newobjects;
|
||||||
int index;
|
int index;
|
||||||
|
|
||||||
hp = &objectnames;
|
hp = &objectnames;
|
||||||
@@ -476,21 +479,32 @@ defineobject(char *name, int indices[], int count)
|
|||||||
if (oap->count == count) {
|
if (oap->count == count) {
|
||||||
for (index = 0; ; index++) {
|
for (index = 0; ; index++) {
|
||||||
if (index >= count)
|
if (index >= count)
|
||||||
return;
|
return 0;
|
||||||
if (oap->elements[index] != indices[index])
|
if (oap->elements[index] != indices[index])
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
math_error("Object type \"%s\" is already defined", name);
|
return 1;
|
||||||
/*NOTREACHED*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hp->h_count >= MAXOBJECTS) {
|
if (hp->h_count >= maxobjcount) {
|
||||||
math_error("Too many object types in use");
|
if (maxobjcount == 0) {
|
||||||
|
newobjects = (OBJECTACTIONS **) malloc(
|
||||||
|
OBJALLOC * sizeof(OBJECTACTIONS *));
|
||||||
|
maxobjcount = OBJALLOC;
|
||||||
|
} else {
|
||||||
|
maxobjcount += OBJALLOC;
|
||||||
|
newobjects = (OBJECTACTIONS **) realloc(objects,
|
||||||
|
maxobjcount * sizeof(OBJECTACTIONS *));
|
||||||
|
}
|
||||||
|
if (newobjects == NULL) {
|
||||||
|
math_error("Allocation failure for new object type");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
|
objects = newobjects;
|
||||||
|
}
|
||||||
|
|
||||||
oap = (OBJECTACTIONS *) malloc(objectactionsize(count));
|
oap = (OBJECTACTIONS *) malloc(objectactionsize(count));
|
||||||
if (oap)
|
|
||||||
name = addstr(hp, name);
|
name = addstr(hp, name);
|
||||||
if ((oap == NULL) || (name == NULL)) {
|
if ((oap == NULL) || (name == NULL)) {
|
||||||
math_error("Cannot allocate object type");
|
math_error("Cannot allocate object type");
|
||||||
@@ -504,7 +518,7 @@ defineobject(char *name, int indices[], int count)
|
|||||||
oap->elements[index] = indices[index];
|
oap->elements[index] = indices[index];
|
||||||
index = findstr(hp, name);
|
index = findstr(hp, name);
|
||||||
objects[index] = oap;
|
objects[index] = oap;
|
||||||
return;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -596,7 +610,7 @@ objalloc(long index)
|
|||||||
VALUE *vp;
|
VALUE *vp;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if ((unsigned) index >= MAXOBJECTS) {
|
if (index < 0 || index > maxobjcount) {
|
||||||
math_error("Allocating bad object index");
|
math_error("Allocating bad object index");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
|
@@ -321,15 +321,11 @@ many_random: many_random.o ../libcalc.a
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/sample/$$i; \
|
echo sample/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo sample
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/sample/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
|
16
seed.c
16
seed.c
@@ -55,14 +55,6 @@
|
|||||||
#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>
|
|
||||||
#endif /* __bsdi */
|
|
||||||
#if defined(__linux)
|
|
||||||
# include <fcntl.h>
|
|
||||||
# define DEV_URANDOM "/dev/urandom"
|
|
||||||
# define DEV_URANDOM_POOL 128
|
|
||||||
#endif /* __linux */
|
|
||||||
#include "qmath.h"
|
#include "qmath.h"
|
||||||
#include "longbits.h"
|
#include "longbits.h"
|
||||||
#include "have_ustat.h"
|
#include "have_ustat.h"
|
||||||
@@ -71,6 +63,14 @@
|
|||||||
#include "have_gettime.h"
|
#include "have_gettime.h"
|
||||||
#include "have_getprid.h"
|
#include "have_getprid.h"
|
||||||
#include "have_urandom.h"
|
#include "have_urandom.h"
|
||||||
|
#if defined(HAVE_USTAT)
|
||||||
|
# include <ustat.h>
|
||||||
|
#endif /* HAVE_USTAT */
|
||||||
|
#if defined(HAVE_URANDOM)
|
||||||
|
# include <fcntl.h>
|
||||||
|
# define DEV_URANDOM "/dev/urandom"
|
||||||
|
# define DEV_URANDOM_POOL 16
|
||||||
|
#endif /* HAVE_URANDOM */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
2
value.h
2
value.h
@@ -446,7 +446,7 @@ extern VALUE objcall(int action, VALUE *v1, VALUE *v2, VALUE *v3);
|
|||||||
extern void objfree(OBJECT *op);
|
extern void objfree(OBJECT *op);
|
||||||
extern void objuncache(void);
|
extern void objuncache(void);
|
||||||
extern int addelement(char *name);
|
extern int addelement(char *name);
|
||||||
extern void defineobject(char *name, int indices[], int count);
|
extern int defineobject(char *name, int indices[], int count);
|
||||||
extern int checkobject(char *name);
|
extern int checkobject(char *name);
|
||||||
extern void showobjfuncs(void);
|
extern void showobjfuncs(void);
|
||||||
extern void showobjtypes(void);
|
extern void showobjtypes(void);
|
||||||
|
21
version.c
21
version.c
@@ -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 "9.2" /* test number or empty string if no patch */
|
#define MINOR_PATCH "9.3.1" /* test number or empty string if no patch */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version constants
|
* calc version constants
|
||||||
@@ -80,3 +80,22 @@ version(void)
|
|||||||
*/
|
*/
|
||||||
return stored_version;
|
return stored_version;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(CALC_VER)
|
||||||
|
|
||||||
|
char *program; /* our name */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* version - print the calc version
|
||||||
|
*/
|
||||||
|
/*ARGSUSED*/
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
program = argv[0];
|
||||||
|
printf("%s\n", version());
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CALC_VER */
|
||||||
|
Reference in New Issue
Block a user