mirror of
https://github.com/lcn2/calc.git
synced 2025-08-19 01:13:27 +03:00
Compare commits
9 Commits
2.11.0t8.5
...
2.11.0t9.1
Author | SHA1 | Date | |
---|---|---|---|
|
1b42111665 | ||
|
ea6b3904be | ||
|
f3fceff1b6 | ||
|
69d4a17187 | ||
|
a99a3400e7 | ||
|
9b6c308b42 | ||
|
8927373965 | ||
|
478d68fca9 | ||
|
e6e2556893 |
79
BUGS
79
BUGS
@@ -68,46 +68,6 @@ importantly, fixes (in the form of a context diff patch) to:
|
|||||||
|
|
||||||
Known bugs:
|
Known bugs:
|
||||||
|
|
||||||
* calc -i ignores quit binding or EOF input in some cases. For example:
|
|
||||||
|
|
||||||
echo 'define f(x) { ' > myfile
|
|
||||||
calc -i read myfile
|
|
||||||
"./myfile", line 2: End-of-file in function body
|
|
||||||
Error in commands
|
|
||||||
>
|
|
||||||
|
|
||||||
At this point, calc will re-prompt if you give it an EOF, or
|
|
||||||
type ^D while using lib/altbind or while ^D is bound to quit.
|
|
||||||
|
|
||||||
* When compiled on Solaris with the Solaris cc using -Xc option
|
|
||||||
(which forces BASEB=16) and without -DFORCE_STDC, calc fails
|
|
||||||
regression test #8218 because hash(a,s), where a = isqrt(2e1000)
|
|
||||||
and s = "xyz", returns 1418255679 instead of 2378490456.
|
|
||||||
|
|
||||||
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
|
|
||||||
EMail your bug reports and hopefully patches to fix them.
|
|
||||||
|
|
||||||
=-=
|
|
||||||
|
|
||||||
Calc Mis-features:
|
|
||||||
|
|
||||||
* The following shell command (written in sh,ksh,bash-like form) works:
|
|
||||||
|
|
||||||
calc '/*
|
|
||||||
* comment
|
|
||||||
*/
|
|
||||||
print 2+3;'
|
|
||||||
|
|
||||||
However this (also written in sh,ksh,bash-like form) does not work:
|
|
||||||
|
|
||||||
echo '/*
|
|
||||||
* comment
|
|
||||||
*/
|
|
||||||
print 2+3;' | calc
|
|
||||||
|
|
||||||
The 2nd example will result in an 'Unterminated comment' error.
|
|
||||||
|
|
||||||
* Calc does not support the #! exec method. For example of the
|
* Calc does not support the #! exec method. For example of the
|
||||||
following is placed in an executable file (assume the path to
|
following is placed in an executable file (assume the path to
|
||||||
calc is correct) called /tmp/xyzzy:
|
calc is correct) called /tmp/xyzzy:
|
||||||
@@ -121,3 +81,42 @@ Calc Mis-features:
|
|||||||
Will result in '"tmp" is undefined' and '"xyzzy" is undefined'
|
Will result in '"tmp" is undefined' and '"xyzzy" is undefined'
|
||||||
error messages because calc considers $0 as an expression to
|
error messages because calc considers $0 as an expression to
|
||||||
evaluate.
|
evaluate.
|
||||||
|
|
||||||
|
* The following file:
|
||||||
|
|
||||||
|
/* this is bugdemo.cal */
|
||||||
|
x = eval(prompt(">>> "));
|
||||||
|
print x;
|
||||||
|
|
||||||
|
when executed as:
|
||||||
|
|
||||||
|
calc read bugdemo.cal
|
||||||
|
|
||||||
|
will obtain a prompt from the terminal, print the value but leave
|
||||||
|
the terminal in a 'bad' state, as if stty -icanon -echo -echoe
|
||||||
|
had been executed.
|
||||||
|
|
||||||
|
* Dec Alpha Linux compiling with gcc-2.95.1 and -O2 fails the
|
||||||
|
regression test with:
|
||||||
|
|
||||||
|
make -s check
|
||||||
|
000: Beginning regression tests
|
||||||
|
001: Some of these tests may take a while ...
|
||||||
|
002: Within each section, output should be numbered sequentially
|
||||||
|
003: parsed global definitions
|
||||||
|
004: parsed vrfy()
|
||||||
|
005: parsed prob(str)
|
||||||
|
006: parsed getglobalvar()
|
||||||
|
007: parsed test_booleans()
|
||||||
|
008: parsed test_variables()
|
||||||
|
make: *** [check] Segmentation fault (core dumped)
|
||||||
|
|
||||||
|
Other programs have reported problems when compiling -O2 with
|
||||||
|
gcc-2.95.1 on the Alpha and Mips.
|
||||||
|
|
||||||
|
One work-a-round is to not compile with -O2 (perhaps just -O).
|
||||||
|
Another work-a-round is not use gcc-2.95.1.
|
||||||
|
|
||||||
|
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
|
||||||
|
EMail your bug reports and hopefully patches to fix them.
|
||||||
|
93
CHANGES
93
CHANGES
@@ -1,4 +1,71 @@
|
|||||||
Following is the change from calc version 2.11.0t8 to date:
|
Following is the change from calc version 2.11.0t8.9.1 to date:
|
||||||
|
|
||||||
|
The config("verbose_quit") will control the printing of the message:
|
||||||
|
|
||||||
|
Quit or abort executed
|
||||||
|
|
||||||
|
when a non-interactive ABORT, QUIT or EXIT is encounted. By default,
|
||||||
|
config("verbose_quit") is TRUE and the message is printed. If one does:
|
||||||
|
|
||||||
|
config("verbose_quit", 0)
|
||||||
|
|
||||||
|
the message is disabled.
|
||||||
|
|
||||||
|
Added 8400 regression test set and test8400.cal to test the new
|
||||||
|
quit and config("verbose_quit") functionality.
|
||||||
|
|
||||||
|
Fixed the BigEndian BASEB==16 regression bugs by correctly swapping
|
||||||
|
16 bit HALFs in a 64 bit value (such as a 64 bit file pointer).
|
||||||
|
|
||||||
|
Added calclevel() builtin to calculation level at which it is called.
|
||||||
|
|
||||||
|
Added help/calclevel and help/inputlevel help files.
|
||||||
|
|
||||||
|
Removed regression tests 951 and 5984 so that the regress test will
|
||||||
|
run in non-interactively / without a TTY such as under Debian's
|
||||||
|
build daemon.
|
||||||
|
|
||||||
|
The eval(str) builtin will return an error-value rather than cause
|
||||||
|
an execution error str has a scan-error.
|
||||||
|
|
||||||
|
Declaration are permitted to end with EOF as well as a newline or ';'.
|
||||||
|
|
||||||
|
When prompt() occurs in reading a file, it will take inout from
|
||||||
|
the terminal rather than taking it from a file. For example,
|
||||||
|
this script, when read, now works:
|
||||||
|
|
||||||
|
/* This demonstrates the use of prompt() and some other things */
|
||||||
|
config("verbose_quit", 0);
|
||||||
|
define getnumber() {
|
||||||
|
local x;
|
||||||
|
for (;;) {
|
||||||
|
x = eval(prompt(">>> "));
|
||||||
|
if (isnum(x))
|
||||||
|
return x;
|
||||||
|
print "Not a number! Try again";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
print "This will display the sqrt of each number you enter";
|
||||||
|
print "Enter quit to stop";
|
||||||
|
for (;;) {
|
||||||
|
print sqrt(getnumber());
|
||||||
|
}
|
||||||
|
print "Good bye";
|
||||||
|
|
||||||
|
Comments entered at inputisterminal level may be spread over several
|
||||||
|
lines. For example:
|
||||||
|
|
||||||
|
/*
|
||||||
|
* These commands work given the file: comment.cal
|
||||||
|
*
|
||||||
|
* cat comment.cal | calc
|
||||||
|
* calc < comment.cal
|
||||||
|
*/
|
||||||
|
print "Hello";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Following is the change from calc version 2.11.0t8 to 2.11.0t8.9:
|
||||||
|
|
||||||
Moved 'wishlist' enhancements from the help/todo file to a new
|
Moved 'wishlist' enhancements from the help/todo file to a new
|
||||||
help/wishlist file. Ordered, by priority, help/todo items into
|
help/wishlist file. Ordered, by priority, help/todo items into
|
||||||
@@ -129,6 +196,30 @@ Following is the change from calc version 2.11.0t8 to date:
|
|||||||
print "funcB(size, mass, ...) defined";
|
print "funcB(size, mass, ...) defined";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Fixed the help/custom_cal, help/new_custom, and help/copy files so
|
||||||
|
that they contain the correct contents instead of the 'usage' file.
|
||||||
|
|
||||||
|
Fixed problem with loss of bindings when calc -i args runs into
|
||||||
|
an error while processing 'args' and drops into interactive mode
|
||||||
|
without the terminal bindings being set.
|
||||||
|
|
||||||
|
Added patch from Ernest Bowen to extablish the abort command as
|
||||||
|
well as to clarify the roles of quit and exit. See the help/command
|
||||||
|
file for details.
|
||||||
|
|
||||||
|
Updated to some extend, the help/statement and help/command help
|
||||||
|
files with new information about SHOW, QUIT, EXIT and ABORT.
|
||||||
|
|
||||||
|
Added show sizes to pzasusb8.cal.
|
||||||
|
|
||||||
|
Updated calc man page and help/usage file to reflect recent
|
||||||
|
command line changes.
|
||||||
|
|
||||||
|
Fixed a bug, reported by Michael Somos <somos@grail.cba.csuohio.edu>,
|
||||||
|
which prevented calc -m from being used.
|
||||||
|
|
||||||
|
Fixed misc compiler warnings.
|
||||||
|
|
||||||
|
|
||||||
Following is the change from calc version 2.11.0t7 to 2.11.0t7.5:
|
Following is the change from calc version 2.11.0t7 to 2.11.0t7.5:
|
||||||
|
|
||||||
|
1
README
1
README
@@ -42,6 +42,7 @@ For overview of calc overview:
|
|||||||
> help define
|
> help define
|
||||||
> help statement
|
> help statement
|
||||||
> help variable
|
> help variable
|
||||||
|
> help usage
|
||||||
|
|
||||||
For list of builtin functions:
|
For list of builtin functions:
|
||||||
|
|
||||||
|
2
calc.c
2
calc.c
@@ -87,7 +87,7 @@ main(int argc, char **argv)
|
|||||||
i_flag = TRUE;
|
i_flag = TRUE;
|
||||||
break;
|
break;
|
||||||
case 'm':
|
case 'm':
|
||||||
if (optarg[1] == '\0' || *optarg<'0' || *optarg>'7') {
|
if (optarg[1] != '\0' || *optarg<'0' || *optarg>'7') {
|
||||||
/*
|
/*
|
||||||
* we are too early in processing to
|
* we are too early in processing to
|
||||||
* call libcalc_call_me_last()
|
* call libcalc_call_me_last()
|
||||||
|
2
calc.h
2
calc.h
@@ -123,6 +123,7 @@ extern void resetinput(void);
|
|||||||
extern void setprompt(char *);
|
extern void setprompt(char *);
|
||||||
extern BOOL inputisterminal(void);
|
extern BOOL inputisterminal(void);
|
||||||
extern int inputlevel(void);
|
extern int inputlevel(void);
|
||||||
|
extern long calclevel(void);
|
||||||
extern char *inputname(void);
|
extern char *inputname(void);
|
||||||
extern long linenumber(void);
|
extern long linenumber(void);
|
||||||
extern void runrcfiles(void);
|
extern void runrcfiles(void);
|
||||||
@@ -164,6 +165,7 @@ extern int d_flag; /* TRUE => disable heading, lib_debug == 0 */
|
|||||||
extern int c_flag; /* TRUE => continue after error if permitted */
|
extern int c_flag; /* TRUE => continue after error if permitted */
|
||||||
extern int i_flag; /* TRUE => try to go interactive after error */
|
extern int i_flag; /* TRUE => try to go interactive after error */
|
||||||
extern int stoponerror; /* >0 => stop, <0 => continue, ==0 => use -c */
|
extern int stoponerror; /* >0 => stop, <0 => continue, ==0 => use -c */
|
||||||
|
extern BOOL abort_now; /* TRUE => try to go interactive */
|
||||||
|
|
||||||
extern char *pager; /* $PAGER or default */
|
extern char *pager; /* $PAGER or default */
|
||||||
extern int stdin_tty; /* TRUE if stdin is a tty */
|
extern int stdin_tty; /* TRUE if stdin is a tty */
|
||||||
|
9
calc.man
9
calc.man
@@ -62,6 +62,13 @@ cause
|
|||||||
.B calc
|
.B calc
|
||||||
to try to process each line being read
|
to try to process each line being read
|
||||||
despite the errors that it encounters.
|
despite the errors that it encounters.
|
||||||
|
.sp 1
|
||||||
|
By default, calc startup scripts ($CALCRC) are silently
|
||||||
|
ignored if not found.
|
||||||
|
This flag will report missing
|
||||||
|
startup scripts unless
|
||||||
|
.B \-d
|
||||||
|
is also given.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
.B \-C
|
.B \-C
|
||||||
@@ -112,6 +119,8 @@ It's nearly ten past six.
|
|||||||
.fi
|
.fi
|
||||||
.in -5n
|
.in -5n
|
||||||
.sp 1
|
.sp 1
|
||||||
|
This flag disables the reporting of missing calc
|
||||||
|
startup scripts ($CALCRC).
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
.B \-e
|
.B \-e
|
||||||
|
22
codegen.c
22
codegen.c
@@ -86,6 +86,7 @@ getcommands(BOOL toplevel)
|
|||||||
/* firewall */
|
/* firewall */
|
||||||
name[0] = '\0';
|
name[0] = '\0';
|
||||||
name[MAXCMD+1] = '\0';
|
name[MAXCMD+1] = '\0';
|
||||||
|
abort_now = FALSE;
|
||||||
|
|
||||||
/* getcommands */
|
/* getcommands */
|
||||||
if (!toplevel)
|
if (!toplevel)
|
||||||
@@ -164,6 +165,13 @@ getcommands(BOOL toplevel)
|
|||||||
if (evaluate(FALSE))
|
if (evaluate(FALSE))
|
||||||
updateoldvalue(curfunc);
|
updateoldvalue(curfunc);
|
||||||
freefunc(curfunc);
|
freefunc(curfunc);
|
||||||
|
if (abort_now) {
|
||||||
|
if (!stdin_tty)
|
||||||
|
run_state = RUN_EXIT;
|
||||||
|
else if (run_state < RUN_PRE_TOP_LEVEL)
|
||||||
|
run_state = RUN_PRE_TOP_LEVEL;
|
||||||
|
longjmp(jmpbuf, 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -401,6 +409,7 @@ getdeclarations(int symtype)
|
|||||||
case T_NEWLINE:
|
case T_NEWLINE:
|
||||||
case T_SEMICOLON:
|
case T_SEMICOLON:
|
||||||
case T_RIGHTBRACE:
|
case T_RIGHTBRACE:
|
||||||
|
case T_EOF:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -862,8 +871,19 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case T_ABORT:
|
||||||
|
switch (gettoken()) {
|
||||||
|
case T_STRING:
|
||||||
|
addopone(OP_ABORT, tokenstring());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
addopone(OP_ABORT, -1);
|
||||||
|
rescantoken();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case T_SYMBOL:
|
case T_SYMBOL:
|
||||||
if (nextchar() == ':') { /****HACK HACK ****/
|
if (nextchar() == ':') { /****HACK HACK****/
|
||||||
definelabel(tokensymbol());
|
definelabel(tokensymbol());
|
||||||
if (gettoken() == T_RIGHTBRACE) {
|
if (gettoken() == T_RIGHTBRACE) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
|
29
config.c
29
config.c
@@ -55,6 +55,7 @@ NAMETYPE configs[] = {
|
|||||||
{"lib_debug", CONFIG_LIB_DEBUG},
|
{"lib_debug", CONFIG_LIB_DEBUG},
|
||||||
{"calc_debug", CONFIG_CALC_DEBUG},
|
{"calc_debug", CONFIG_CALC_DEBUG},
|
||||||
{"user_debug", CONFIG_USER_DEBUG},
|
{"user_debug", CONFIG_USER_DEBUG},
|
||||||
|
{"verbose_quit",CONFIG_VERBOSE_QUIT},
|
||||||
{NULL, 0}
|
{NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -95,7 +96,8 @@ CONFIG oldstd = { /* backward compatible standard configuration */
|
|||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
3, /* calc library debug level */
|
3, /* calc library debug level */
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
0 /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
CONFIG newstd = { /* new non-backward compatible configuration */
|
CONFIG newstd = { /* new non-backward compatible configuration */
|
||||||
MODE_INITIAL, /* current output mode */
|
MODE_INITIAL, /* current output mode */
|
||||||
@@ -130,7 +132,8 @@ CONFIG newstd = { /* new non-backward compatible configuration */
|
|||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
3, /* calc library debug level */
|
3, /* calc library debug level */
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
0 /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
||||||
|
|
||||||
@@ -848,6 +851,21 @@ setconfig(int type, VALUE *vp)
|
|||||||
conf->user_debug = temp;
|
conf->user_debug = temp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_VERBOSE_QUIT:
|
||||||
|
if (vp->v_type == V_NUM) {
|
||||||
|
q = vp->v_num;
|
||||||
|
conf->verbose_quit = !qiszero(q);
|
||||||
|
} else if (vp->v_type == V_STR) {
|
||||||
|
temp = truthtype(vp->v_str->s_str);
|
||||||
|
if (temp < 0) {
|
||||||
|
math_error("Illegal truth value"
|
||||||
|
"for verbose_quit");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
conf->verbose_quit = (int)temp;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Setting illegal config parameter");
|
math_error("Setting illegal config parameter");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -1119,6 +1137,10 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
i = cfg->user_debug;
|
i = cfg->user_debug;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_VERBOSE_QUIT:
|
||||||
|
i = cfg->verbose_quit;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Getting illegal CONFIG element");
|
math_error("Getting illegal CONFIG element");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -1194,5 +1216,6 @@ config_cmp(CONFIG *cfg1, CONFIG *cfg2)
|
|||||||
cfg1->blkfmt != cfg2->blkfmt ||
|
cfg1->blkfmt != cfg2->blkfmt ||
|
||||||
cfg1->lib_debug != cfg2->lib_debug ||
|
cfg1->lib_debug != cfg2->lib_debug ||
|
||||||
cfg1->calc_debug != cfg2->calc_debug ||
|
cfg1->calc_debug != cfg2->calc_debug ||
|
||||||
cfg1->user_debug != cfg2->user_debug;
|
cfg1->user_debug != cfg2->user_debug ||
|
||||||
|
cfg1->verbose_quit != cfg2->verbose_quit;
|
||||||
}
|
}
|
||||||
|
12
config.h
12
config.h
@@ -80,6 +80,7 @@
|
|||||||
#define CONFIG_LIB_DEBUG 30
|
#define CONFIG_LIB_DEBUG 30
|
||||||
#define CONFIG_CALC_DEBUG 31
|
#define CONFIG_CALC_DEBUG 31
|
||||||
#define CONFIG_USER_DEBUG 32
|
#define CONFIG_USER_DEBUG 32
|
||||||
|
#define CONFIG_VERBOSE_QUIT 33
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -114,8 +115,8 @@ struct config {
|
|||||||
LEN sq2; /* size of number to use square algorithm 2 */
|
LEN sq2; /* size of number to use square algorithm 2 */
|
||||||
LEN pow2; /* size of modulus to use REDC for powers */
|
LEN pow2; /* size of modulus to use REDC for powers */
|
||||||
LEN redc2; /* size of modulus to use REDC algorithm 2 */
|
LEN redc2; /* size of modulus to use REDC algorithm 2 */
|
||||||
int tilde_ok; /* ok to print a tilde on aproximations */
|
BOOL tilde_ok; /* ok to print a tilde on aproximations */
|
||||||
int tab_ok; /* ok to print tab before numeric values */
|
BOOL tab_ok; /* ok to print tab before numeric values */
|
||||||
long quomod; /* quomod() default rounding mode */
|
long quomod; /* quomod() default rounding mode */
|
||||||
long quo; /* quotent // default rounding mode */
|
long quo; /* quotent // default rounding mode */
|
||||||
long mod; /* mod % default rounding mode */
|
long mod; /* mod % default rounding mode */
|
||||||
@@ -125,18 +126,19 @@ struct config {
|
|||||||
long cfsim; /* cfsim() default rounding mode */
|
long cfsim; /* cfsim() default rounding mode */
|
||||||
long outround; /* output default rounding mode */
|
long outround; /* output default rounding mode */
|
||||||
long round; /* round()/bround() default rounding mode */
|
long round; /* round()/bround() default rounding mode */
|
||||||
int leadzero; /* ok to print leading 0 before decimal pt */
|
BOOL leadzero; /* ok to print leading 0 before decimal pt */
|
||||||
int fullzero; /* ok to print trailing 0's */
|
BOOL fullzero; /* ok to print trailing 0's */
|
||||||
long maxscancount; /* max scan errors before abort */
|
long maxscancount; /* max scan errors before abort */
|
||||||
char *prompt1; /* normal prompt */
|
char *prompt1; /* normal prompt */
|
||||||
char *prompt2; /* prompt when inside multi-line input */
|
char *prompt2; /* prompt when inside multi-line input */
|
||||||
int blkmaxprint; /* octets of a block to print, 0 => all */
|
int blkmaxprint; /* octets of a block to print, 0 => all */
|
||||||
int blkverbose; /* TRUE => print all lines if a block */
|
BOOL blkverbose; /* TRUE => print all lines if a block */
|
||||||
int blkbase; /* block output base */
|
int blkbase; /* block output base */
|
||||||
int blkfmt; /* block output style */
|
int blkfmt; /* block output style */
|
||||||
int lib_debug; /* library debug, see LIB_DEBUG_XXX below */
|
int lib_debug; /* library debug, see LIB_DEBUG_XXX below */
|
||||||
int calc_debug; /* internal debug, see CALC_DEBUG_XXX below */
|
int calc_debug; /* internal debug, see CALC_DEBUG_XXX below */
|
||||||
int user_debug; /* user defined debug value: 0 default */
|
int user_debug; /* user defined debug value: 0 default */
|
||||||
|
BOOL verbose_quit; /* TRUE => print Quit or abort executed msg */
|
||||||
};
|
};
|
||||||
typedef struct config CONFIG;
|
typedef struct config CONFIG;
|
||||||
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 1997 Landon Curt Noll
|
# Copyright (c) 1999 Landon Curt Noll
|
||||||
#
|
#
|
||||||
# Permission to use, copy, modify, and distribute this software and
|
# Permission to use, copy, modify, and distribute this software and
|
||||||
# its documentation for any purpose and without fee is hereby granted,
|
# its documentation for any purpose and without fee is hereby granted,
|
||||||
@@ -44,8 +44,19 @@ calc library standards and guidelines.
|
|||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
|
argv.cal
|
||||||
|
|
||||||
|
argv(var, ...)
|
||||||
|
|
||||||
|
print information about various args
|
||||||
|
|
||||||
halflen.cal
|
halflen.cal
|
||||||
|
|
||||||
halflen(num)
|
halflen(num)
|
||||||
|
|
||||||
Calculate the length of a numeric value in HALF's.
|
Calculate the length of a numeric value in HALF's.
|
||||||
|
|
||||||
|
pzasusb8.cal
|
||||||
|
|
||||||
|
Run custom("pzasusb8") on a standard set of data, print Endian
|
||||||
|
related information and print value size information.
|
||||||
|
@@ -38,17 +38,17 @@ Step 1: Do some background work
|
|||||||
you look at some examples of custom functions. Check out
|
you look at some examples of custom functions. Check out
|
||||||
the following source files:
|
the following source files:
|
||||||
|
|
||||||
../custom.c
|
custom.c
|
||||||
custom.h
|
custom/custom.h
|
||||||
custtbl.c
|
custom/custtbl.c
|
||||||
c_*.[ch]
|
custom/c_*.[ch]
|
||||||
../help/custom
|
help/custom (or run: calc help custom)
|
||||||
|
|
||||||
You would be well advised to look at a more recent calc source
|
You would be well advised to look at a more recent calc source
|
||||||
such as one available in from the calc alpha test archive.
|
such as one available in from the calc version archive.
|
||||||
See the following for more details:
|
See the following for more details:
|
||||||
|
|
||||||
../help/archive
|
help/archive (or run: calc help archive)
|
||||||
|
|
||||||
|
|
||||||
Step 2: Name your custom function
|
Step 2: Name your custom function
|
||||||
@@ -604,3 +604,16 @@ Step 11: Install
|
|||||||
|
|
||||||
Although calc does not run setuid, you may need to be root to install
|
Although calc does not run setuid, you may need to be root to install
|
||||||
the directories into which calc installs may be write protected.
|
the directories into which calc installs may be write protected.
|
||||||
|
|
||||||
|
|
||||||
|
Step 12: Contribute
|
||||||
|
|
||||||
|
Your custom function may be of interest to some people and/or
|
||||||
|
serve as an example of what one can do with custom functions.
|
||||||
|
|
||||||
|
Read the file:
|
||||||
|
|
||||||
|
help/contrib (or run: calc help contrib)
|
||||||
|
|
||||||
|
and consider submitting your custom function for possible
|
||||||
|
inclusion in later versions of calc.
|
||||||
|
@@ -27,3 +27,5 @@ print "BIG_ENDIAN: ", custom("sysinfo", "BIG_ENDIAN");
|
|||||||
print "LITTLE_ENDIAN: ", custom("sysinfo", "LITTLE_ENDIAN");
|
print "LITTLE_ENDIAN: ", custom("sysinfo", "LITTLE_ENDIAN");
|
||||||
print "LONG_BITS: ", custom("sysinfo", "LONG_BITS");
|
print "LONG_BITS: ", custom("sysinfo", "LONG_BITS");
|
||||||
print "LONGLONG_BITS: ", custom("sysinfo", "LONGLONG_BITS");
|
print "LONGLONG_BITS: ", custom("sysinfo", "LONGLONG_BITS");
|
||||||
|
print "Calc sizes:";
|
||||||
|
show sizes;
|
||||||
|
26
func.c
26
func.c
@@ -155,6 +155,7 @@ f_eval(VALUE *vp)
|
|||||||
VALUE result;
|
VALUE result;
|
||||||
char *str;
|
char *str;
|
||||||
long num;
|
long num;
|
||||||
|
int temp;
|
||||||
|
|
||||||
if (vp->v_type != V_STR)
|
if (vp->v_type != V_STR)
|
||||||
return error_value(E_EVAL2);
|
return error_value(E_EVAL2);
|
||||||
@@ -168,7 +169,10 @@ f_eval(VALUE *vp)
|
|||||||
}
|
}
|
||||||
oldfunc = curfunc;
|
oldfunc = curfunc;
|
||||||
enterfilescope();
|
enterfilescope();
|
||||||
|
temp = stoponerror;
|
||||||
|
stoponerror = -1;
|
||||||
if (evaluate(TRUE)) {
|
if (evaluate(TRUE)) {
|
||||||
|
stoponerror = temp;
|
||||||
closeinput();
|
closeinput();
|
||||||
exitfilescope();
|
exitfilescope();
|
||||||
freevalue(stack--);
|
freevalue(stack--);
|
||||||
@@ -181,6 +185,7 @@ f_eval(VALUE *vp)
|
|||||||
free(newfunc);
|
free(newfunc);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
stoponerror = temp;
|
||||||
closeinput();
|
closeinput();
|
||||||
exitfilescope();
|
exitfilescope();
|
||||||
newfunc = curfunc;
|
newfunc = curfunc;
|
||||||
@@ -203,11 +208,11 @@ f_prompt(VALUE *vp)
|
|||||||
unsigned int len;
|
unsigned int len;
|
||||||
|
|
||||||
result.v_type = V_STR;
|
result.v_type = V_STR;
|
||||||
if (inputisterminal()) {
|
openterminal();
|
||||||
printvalue(vp, PRINT_SHORT);
|
printvalue(vp, PRINT_SHORT);
|
||||||
math_flush();
|
math_flush();
|
||||||
}
|
|
||||||
cp = nextline();
|
cp = nextline();
|
||||||
|
closeinput();
|
||||||
if (cp == NULL) {
|
if (cp == NULL) {
|
||||||
math_error("End of file while prompting");
|
math_error("End of file while prompting");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -5893,6 +5898,17 @@ f_inputlevel (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
f_calclevel (void)
|
||||||
|
{
|
||||||
|
VALUE result;
|
||||||
|
|
||||||
|
result.v_type = V_NUM;
|
||||||
|
result.v_num = itoq(calclevel());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
f_access(int count, VALUE **vals)
|
f_access(int count, VALUE **vals)
|
||||||
{
|
{
|
||||||
@@ -6818,6 +6834,8 @@ static CONST struct builtin builtins[] = {
|
|||||||
"round value a to b number of binary places"},
|
"round value a to b number of binary places"},
|
||||||
{"btrunc", 1, 2, 0, OP_NOP, f_btrunc, 0,
|
{"btrunc", 1, 2, 0, OP_NOP, f_btrunc, 0,
|
||||||
"truncate a to b number of binary places"},
|
"truncate a to b number of binary places"},
|
||||||
|
{"calclevel", 0, 0, 0, OP_NOP, 0, f_calclevel,
|
||||||
|
"current calculation level"},
|
||||||
{"ceil", 1, 1, 0, OP_NOP, 0, f_ceil,
|
{"ceil", 1, 1, 0, OP_NOP, 0, f_ceil,
|
||||||
"smallest integer greater than or equal to number"},
|
"smallest integer greater than or equal to number"},
|
||||||
{"cfappr", 1, 3, 0, OP_NOP, f_cfappr, 0,
|
{"cfappr", 1, 3, 0, OP_NOP, f_cfappr, 0,
|
||||||
|
@@ -105,29 +105,30 @@ BLT_HELP_FILES= ${BLT_HELP_FILES_3} ${BLT_HELP_FILES_5} \
|
|||||||
# This list is prodiced by the detaillist rule when no WARNINGS are detected.
|
# This list is prodiced by the detaillist rule when no WARNINGS are detected.
|
||||||
#
|
#
|
||||||
DETAIL_HELP= abs access acos acosh acot acoth acsc acsch address agd append \
|
DETAIL_HELP= abs access acos acosh acot acoth acsc acsch address agd append \
|
||||||
appr arg arrow asec asech asin asinh assign atan atan2 atanh avg base \
|
appr arg arrow asec asech asin asinh assign atan atan2 atanh avg \
|
||||||
bit blk blkcpy blkfree blocks bround btrunc ceil cfappr cfsim char \
|
base bit blk blkcpy blkfree blocks bround btrunc calclevel ceil \
|
||||||
cmdbuf cmp comb conj cos cosh cot coth count cp csc csch ctime delete \
|
cfappr cfsim char cmdbuf cmp comb conj cos cosh cot coth count cp \
|
||||||
den dereference det digit digits dp epsilon errcount errmax errno \
|
csc csch ctime delete den dereference det digit digits dp epsilon \
|
||||||
error eval exp fact factor fclose fcnt feof ferror fflush fgetc \
|
errcount errmax errno error eval exp fact factor fclose fcnt feof \
|
||||||
fgetfield fgetline fgets fgetstr fib files floor fopen forall fprintf \
|
ferror fflush fgetc fgetfield fgetline fgets fgetstr fib files \
|
||||||
fputc fputs fputstr frac free freeglobals freeredc freestatics frem \
|
floor fopen forall fprintf fputc fputs fputstr frac free freeglobals \
|
||||||
freopen fscan fscanf fseek fsize ftell gcd gcdrem gd getenv hash head \
|
freeredc freestatics frem freopen fscan fscanf fseek fsize ftell gcd \
|
||||||
highbit hmean hnrmod hypot ilog ilog10 ilog2 im insert int inverse \
|
gcdrem gd getenv hash head highbit hmean hnrmod hypot ilog ilog10 \
|
||||||
iroot isassoc isatty isblk isconfig isdefined iserror iseven isfile \
|
ilog2 im inputlevel insert int inverse iroot isassoc isatty isblk \
|
||||||
ishash isident isint islist ismat ismult isnull isnum isobj isobjtype \
|
isconfig isdefined iserror iseven isfile ishash isident isint islist \
|
||||||
isodd isprime isptr isqrt isrand israndom isreal isrel issimple issq \
|
ismat ismult isnull isnum isobj isobjtype isodd isprime isptr isqrt \
|
||||||
isstr istype jacobi join lcm lcmfact lfactor ln lowbit ltol makelist \
|
isrand israndom isreal isrel issimple issq isstr istype jacobi join \
|
||||||
matdim matfill matmax matmin matsum mattrace mattrans max md5 memsize \
|
lcm lcmfact lfactor ln lowbit ltol makelist matdim matfill matmax \
|
||||||
meq min minv mmin mne mod modify name near newerror nextcand \
|
matmin matsum mattrace mattrans max md5 memsize meq min minv mmin \
|
||||||
nextprime norm null num oldvalue ord param perm pfact pi pix places \
|
mne mod modify name near newerror nextcand nextprime norm null \
|
||||||
pmod polar poly pop popcnt power prevcand prevprime printf prompt \
|
num oldvalue ord param perm pfact pi pix places pmod polar poly \
|
||||||
protect ptest push putenv quo quomod rand randbit random randombit \
|
pop popcnt power prevcand prevprime printf prompt protect ptest \
|
||||||
randperm rcin rcmul rcout rcpow rcsq re remove reverse rewind rm root \
|
push putenv quo quomod rand randbit random randombit randperm rcin \
|
||||||
round rsearch runtime saveval scale scan scanf search sec sech seed \
|
rcmul rcout rcpow rcsq re remove reverse rewind rm root round rsearch \
|
||||||
segment select sgn sha sha1 sin sinh size sizeof sort sqrt srand \
|
runtime saveval scale scan scanf search sec sech seed segment select \
|
||||||
srandom ssq str strcat strerror strlen strpos strprintf strscan \
|
sgn sha sha1 sin sinh size sizeof sort sqrt srand srandom ssq str \
|
||||||
strscanf substr sum swap system tail tan tanh test time trunc xor
|
strcat strerror strlen strpos strprintf strscan strscanf substr \
|
||||||
|
sum swap system tail tan tanh test time trunc xor
|
||||||
|
|
||||||
# This list is of files that are clones of DETAIL_HELP files. They are
|
# This list is of files that are clones of DETAIL_HELP files. They are
|
||||||
# built from DETAIL_HELP files.
|
# built from DETAIL_HELP files.
|
||||||
@@ -258,7 +259,7 @@ calc: usage
|
|||||||
|
|
||||||
custom_cal: ../custom/CUSTOM_CAL
|
custom_cal: ../custom/CUSTOM_CAL
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp ../custom/CUSTOM_CAL $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -270,7 +271,7 @@ custom_cal: ../custom/CUSTOM_CAL
|
|||||||
|
|
||||||
new_custom: ../custom/HOW_TO_ADD
|
new_custom: ../custom/HOW_TO_ADD
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp ../custom/HOW_TO_ADD $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -282,7 +283,7 @@ new_custom: ../custom/HOW_TO_ADD
|
|||||||
|
|
||||||
copy: blkcpy
|
copy: blkcpy
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp blkcpy $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -416,8 +417,8 @@ bsdi: all
|
|||||||
detaillist:
|
detaillist:
|
||||||
${Q}-(echo "xxxxx"; \
|
${Q}-(echo "xxxxx"; \
|
||||||
for i in ${DETAIL_HELP}; do \
|
for i in ${DETAIL_HELP}; do \
|
||||||
if [ ! -f SCCS/s.$$i ]; then \
|
if [ ! -f RCS/$$i,v ]; then \
|
||||||
echo "WARNING: $$i not under SCCS control" 1>&2; \
|
echo "WARNING: $$i not under RCS control" 1>&2; \
|
||||||
else \
|
else \
|
||||||
echo $$i; \
|
echo $$i; \
|
||||||
fi; \
|
fi; \
|
||||||
|
22
help/archive
22
help/archive
@@ -1,26 +1,14 @@
|
|||||||
Where to get the the latest versions of calc
|
Where to get the the latest versions of calc
|
||||||
|
|
||||||
Landon Noll maintains the official calc ftp archive at:
|
Landon Noll maintains the official calc home page at:
|
||||||
|
|
||||||
ftp://ftp.uu.net/pub/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
|
||||||
Alpha test versions, complete with bugs, untested code and
|
See:
|
||||||
experimental features may be fetched (if you are brave) under:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc/
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
One may join the calc testing group by sending a request to:
|
for information on how to obtain up a recent version of calc.
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
|
||||||
|
|
||||||
subscribe calc-tester address
|
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
|
||||||
is your full name.
|
|
||||||
|
|
||||||
Landon Curt Noll
|
Landon Curt Noll
|
||||||
http://reality.sgi.com/chongo
|
http://reality.sgi.com/chongo
|
||||||
|
35
help/calclevel
Normal file
35
help/calclevel
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
NAME
|
||||||
|
calclevel - current calculation level
|
||||||
|
|
||||||
|
SYNOPSIS
|
||||||
|
calclevel()
|
||||||
|
|
||||||
|
TYPES
|
||||||
|
return nonnegative integer
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
This function returns the calculation level at which it is called.
|
||||||
|
When a command is being read from a terminal or from a file,
|
||||||
|
calc is at calculation level zero. The level is increased
|
||||||
|
by 1 each time calculation starts of a user-defined function
|
||||||
|
or of eval(S) for some expression S which evaluates to a string. It
|
||||||
|
decreases to zero if an error occurs or a quit or abort statement
|
||||||
|
is executed. Otherwise, it decreases by 1 when the calculation
|
||||||
|
is completed. Except when an error occurs or abort is executed,
|
||||||
|
the input level is not affected by changes in the calculation level.
|
||||||
|
|
||||||
|
Zero calculation level is also called top calculation level; greater
|
||||||
|
values of calclevel() indicate calculation is occurring at greater
|
||||||
|
depths.
|
||||||
|
|
||||||
|
EXAMPLE
|
||||||
|
n/a
|
||||||
|
|
||||||
|
LIMITS
|
||||||
|
none
|
||||||
|
|
||||||
|
LIBRARY
|
||||||
|
none
|
||||||
|
|
||||||
|
SEE ALSO
|
||||||
|
eval, read, quit, abort, inputlevel
|
263
help/command
263
help/command
@@ -14,12 +14,10 @@ Command sequence
|
|||||||
described in the next section.
|
described in the next section.
|
||||||
|
|
||||||
|
|
||||||
NOTE: Calc commands are in lower case. UPPER case is used below
|
define a function
|
||||||
for emphasis only, and should be considered in lower case.
|
-----------------
|
||||||
|
define function(params) { body }
|
||||||
|
define function(params) = expression
|
||||||
DEFINE function(params) { body }
|
|
||||||
DEFINE function(params) = expression
|
|
||||||
This first form defines a full function which can consist
|
This first form defines a full function which can consist
|
||||||
of declarations followed by many statements which implement
|
of declarations followed by many statements which implement
|
||||||
the function.
|
the function.
|
||||||
@@ -30,13 +28,22 @@ Command sequence
|
|||||||
and question mark operators can be useful. Examples of
|
and question mark operators can be useful. Examples of
|
||||||
simple functions are:
|
simple functions are:
|
||||||
|
|
||||||
define sumcubes(a, b) = a^3 + b^3;
|
define sumcubes(a, b) = a^3 + b^3
|
||||||
define pimod(a) = a % pi();
|
define pimod(a) = a % pi()
|
||||||
|
define printnum(a, n, p)
|
||||||
|
{
|
||||||
|
if (p == 0) {
|
||||||
|
print a: "^": n, "=", a^n;
|
||||||
|
} else {
|
||||||
|
print a: "^": n, "mod", p, "=", pmod(a,n,p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
HELP
|
|
||||||
This displays a general help message.
|
|
||||||
|
|
||||||
READ filename
|
read calc commands
|
||||||
|
------------------
|
||||||
|
read filename
|
||||||
|
read -once filename
|
||||||
This reads definitions from the specified filename.
|
This reads definitions from the specified filename.
|
||||||
The name can be quoted if desired. The calculator
|
The name can be quoted if desired. The calculator
|
||||||
uses the CALCPATH environment variable to search
|
uses the CALCPATH environment variable to search
|
||||||
@@ -52,14 +59,11 @@ Command sequence
|
|||||||
evaluate or functions to define, just like at the top
|
evaluate or functions to define, just like at the top
|
||||||
level command level.
|
level command level.
|
||||||
|
|
||||||
If the -m mode disallows opening of files for reading,
|
When -once is given, the read command acts like the regular
|
||||||
this command will be disabled.
|
read expect that it will ignore filename if is has been
|
||||||
|
previously read.
|
||||||
|
|
||||||
READ -once filename
|
The read -once form is particularly useful in a library that
|
||||||
This command acts like the regular READ expect that it
|
|
||||||
will ignore filename if is has been previously read.
|
|
||||||
|
|
||||||
This command is particularly useful in a library that
|
|
||||||
needs to read a 2nd library. By using the READ -once
|
needs to read a 2nd library. By using the READ -once
|
||||||
command, one will not reread that 2nd library, nor will
|
command, one will not reread that 2nd library, nor will
|
||||||
once risk entering into a infinite READ loop (where
|
once risk entering into a infinite READ loop (where
|
||||||
@@ -69,7 +73,10 @@ Command sequence
|
|||||||
If the -m mode disallows opening of files for reading,
|
If the -m mode disallows opening of files for reading,
|
||||||
this command will be disabled.
|
this command will be disabled.
|
||||||
|
|
||||||
WRITE filename
|
|
||||||
|
write calc commands
|
||||||
|
-------------------
|
||||||
|
write filename
|
||||||
This writes the values of all global variables to the
|
This writes the values of all global variables to the
|
||||||
specified filename, in such a way that the file can be
|
specified filename, in such a way that the file can be
|
||||||
later read in order to recreate the variable values.
|
later read in order to recreate the variable values.
|
||||||
@@ -81,19 +88,221 @@ Command sequence
|
|||||||
If the -m mode disallows opening of files for writing,
|
If the -m mode disallows opening of files for writing,
|
||||||
this command will be disabled.
|
this command will be disabled.
|
||||||
|
|
||||||
QUIT
|
|
||||||
This leaves the calculator, when given as a top-level
|
|
||||||
command.
|
|
||||||
|
|
||||||
CD
|
quit or exit
|
||||||
Change the current directory to the home directory, if $HOME
|
------------
|
||||||
|
quit
|
||||||
|
quit string
|
||||||
|
exit
|
||||||
|
exit string
|
||||||
|
The action of these commands depends on where they are used.
|
||||||
|
At the interactive level, they will cause calc it edit.
|
||||||
|
This is the normal way to leave the calculator. In any
|
||||||
|
other use, they will stop the current calculation as if
|
||||||
|
an error had occurred.
|
||||||
|
|
||||||
|
If a string is given, then the string is printed as the reason
|
||||||
|
for quitting, otherwise a general quit message is printed.
|
||||||
|
The routine name and line number which executed the quit is
|
||||||
|
also printed in either case.
|
||||||
|
|
||||||
|
Exit is an alias for quit.
|
||||||
|
|
||||||
|
Quit is useful when a routine detects invalid arguments,
|
||||||
|
in order to stop a calculation cleanly. For example,
|
||||||
|
for a square root routine, an error can be given if the
|
||||||
|
supplied parameter was a negative number, as in:
|
||||||
|
|
||||||
|
define mysqrt(n)
|
||||||
|
{
|
||||||
|
if (! isnum(n))
|
||||||
|
quit "non-numeric argument";
|
||||||
|
if (n < 0)
|
||||||
|
quit "Negative argument";
|
||||||
|
return sqrt(n);
|
||||||
|
}
|
||||||
|
|
||||||
|
See 'more information about abort and quit' below for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
abort
|
||||||
|
-----
|
||||||
|
abort
|
||||||
|
abort string
|
||||||
|
This command behaves like QUIT except that it will attempt
|
||||||
|
to return to the interactive level if permitted, otherwise
|
||||||
|
calc exit.
|
||||||
|
|
||||||
|
See 'more information about abort and quit' below for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
|
||||||
|
change current directory
|
||||||
|
------------------------
|
||||||
|
cd
|
||||||
|
cd dir
|
||||||
|
Change the current directory to 'dir'. If 'dir' is ommitted,
|
||||||
|
change the current directory to the home directory, if $HOME
|
||||||
is set in the environment.
|
is set in the environment.
|
||||||
|
|
||||||
CD dir
|
|
||||||
Change the current directory to dir.
|
show information
|
||||||
|
----------------
|
||||||
|
show item
|
||||||
|
This command displays some information where 'item' is
|
||||||
|
one of the following:
|
||||||
|
|
||||||
|
blocks unfreed named blocks
|
||||||
|
builtin built in functions
|
||||||
|
config config parameters and values
|
||||||
|
constants cache of numeric constants
|
||||||
|
custom custom functions if calc -C was used
|
||||||
|
errors new error-values created
|
||||||
|
files open files, file position and sizes
|
||||||
|
function user-defined functions
|
||||||
|
globaltypes global variables
|
||||||
|
objfunctions possible object functions
|
||||||
|
objtypes defined objects
|
||||||
|
opcodes func internal opcodes for function `func'
|
||||||
|
sizes size in octets of calc value types
|
||||||
|
realglobals numeric global variables
|
||||||
|
statics unscoped static variables
|
||||||
|
numbers calc number cache
|
||||||
|
redcdata REDC data defined
|
||||||
|
strings calc string cache
|
||||||
|
literals calc literal cache
|
||||||
|
|
||||||
|
Only the first 4 characters of item are examined, so:
|
||||||
|
|
||||||
|
show globals
|
||||||
|
show global
|
||||||
|
show glob
|
||||||
|
|
||||||
|
do the same thing.
|
||||||
|
|
||||||
|
|
||||||
|
calc help
|
||||||
|
---------
|
||||||
|
help
|
||||||
|
help name
|
||||||
|
This displays a help related to 'name' or general
|
||||||
|
help of none is given.
|
||||||
|
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
|
||||||
|
more information about abort and quit
|
||||||
|
=====================================
|
||||||
|
|
||||||
|
Consider the following calc file called myfile.cal:
|
||||||
|
|
||||||
|
print "start of myfile.cal";
|
||||||
|
define q() {quit "quit from q()"; print "end of q()"}
|
||||||
|
define a() {abort "abort from a()"}
|
||||||
|
x = 3;
|
||||||
|
{print "start #1"; if (x > 1) q()} print "after #1";
|
||||||
|
{print "start #2"; if (x > 1) a()} print "after #2";
|
||||||
|
{print "start #3"; if (x > 1) quit "quit from 3rd statement"}
|
||||||
|
print "end of myfile.cal";
|
||||||
|
|
||||||
|
The command:
|
||||||
|
|
||||||
|
calc read myfile
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
|
||||||
|
The QUIT within the q() function prevented the ``end of q()''
|
||||||
|
statement from being evaluated. This QUIT command caused
|
||||||
|
control to be returned to just after the place where q()
|
||||||
|
was called.
|
||||||
|
|
||||||
|
Notice that unlike QUIT, the ABORT inside function a() halts
|
||||||
|
the processing of statements from the input source (myfile.cal).
|
||||||
|
Because calc was not interactive, ABORT causes calc to exit.
|
||||||
|
|
||||||
|
The command:
|
||||||
|
|
||||||
|
calc -i read myfile
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
> <==== calc interactive prompt
|
||||||
|
|
||||||
|
because the '-i' calc causes ABORT to drop into an
|
||||||
|
interactive prompt. However typing a QUIT or ABORT
|
||||||
|
at the interactive prompt level will always calc to exit,
|
||||||
|
even when calc is invoked with '-i'.
|
||||||
|
|
||||||
|
Also observe that both of these commands:
|
||||||
|
|
||||||
|
cat myfile.cal | calc
|
||||||
|
cat myfile.cal | calc -i
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
|
||||||
|
The ABORT inside function a() halts the processing of statements
|
||||||
|
from the input source (standard input). Because standard input
|
||||||
|
is not a terminal, using '-i' does not force it to drop into
|
||||||
|
an interactive prompt.
|
||||||
|
|
||||||
|
If one were to type in the contents of myfile.cal interactively,
|
||||||
|
calc will produce:
|
||||||
|
|
||||||
|
> print "start of myfile.cal";
|
||||||
|
start of myfile.cal
|
||||||
|
> define q() {quit "quit from q()"; print "end of q()"}
|
||||||
|
q() defined
|
||||||
|
> define a() {abort "abort from a()"}
|
||||||
|
a() defined
|
||||||
|
> x = 3;
|
||||||
|
> {print "start #1"; if (x > 1) q()} print "after #1";
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
> {print "start #2"; if (x > 1) a()} print "after #2";
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
> {print "start #3"; if (x > 1) quit "quit from 3rd statement"}
|
||||||
|
start #3
|
||||||
|
quit from 3rd statement
|
||||||
|
|
||||||
|
The ABORT from within the a() function returned control to
|
||||||
|
the interactive level.
|
||||||
|
|
||||||
|
The QUIT (after the if (x > 1) ...) will cause calc to exit
|
||||||
|
because it was given at the interactive prompt level.
|
||||||
|
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
|
||||||
Also see the help topic:
|
Also see the help topic:
|
||||||
|
|
||||||
statement flow control and declaration statements
|
statement flow control and declaration statements
|
||||||
usage for -m modes
|
usage how to invoke the calc command and calc -options
|
||||||
|
@@ -43,6 +43,7 @@ Configuration parameters
|
|||||||
"lib_debug" controls library script debug information
|
"lib_debug" controls library script debug information
|
||||||
"calc_debug" controls internal calc debug information
|
"calc_debug" controls internal calc debug information
|
||||||
"user_debug" for user defined debug information
|
"user_debug" for user defined debug information
|
||||||
|
"verbose_quit" TRUE=>print message on empty quit or abort
|
||||||
|
|
||||||
|
|
||||||
The "all" config value allows one to save/restore the configuration
|
The "all" config value allows one to save/restore the configuration
|
||||||
@@ -375,6 +376,14 @@ Configuration parameters
|
|||||||
slower operation or more memory usage, and a particular value (like
|
slower operation or more memory usage, and a particular value (like
|
||||||
-1 or 0) corresponding to "no tests".
|
-1 or 0) corresponding to "no tests".
|
||||||
|
|
||||||
|
The "verbose_quit" controls the print of the message:
|
||||||
|
|
||||||
|
Quit or abort executed
|
||||||
|
|
||||||
|
when a non-interactive quit or abort without an argument is encounted.
|
||||||
|
A quit of abort without an argument does not display a message when
|
||||||
|
invoked at the interactive level.
|
||||||
|
|
||||||
The following are synonyms for true:
|
The following are synonyms for true:
|
||||||
|
|
||||||
"on" "yes" "y" "true" "t" "1" any non-zero number
|
"on" "yes" "y" "true" "t" "1" any non-zero number
|
||||||
|
42
help/contrib
42
help/contrib
@@ -5,30 +5,27 @@ We welcome and encourage you to send us:
|
|||||||
* custom functions that you have modified or written
|
* custom functions that you have modified or written
|
||||||
* any other source code modifications
|
* any other source code modifications
|
||||||
|
|
||||||
Prior to doing so, you should consider trying your changes on the most
|
Prior to doing so, you should consider applying your changes to the most
|
||||||
recent alpha test code. To obtain the most recent code, look under
|
recent version of calc.
|
||||||
|
|
||||||
|
Landon Noll maintains the official calc home page at:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc/
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
|
||||||
You should also consider joining the calc testing group by sending a
|
See:
|
||||||
request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
for information on how to obtain up a recent version of calc.
|
||||||
|
|
||||||
subscribe calc-tester address
|
=-=
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
|
||||||
is your full name.
|
|
||||||
|
|
||||||
In order to consider integrating your code, we need:
|
In order to consider integrating your code, we need:
|
||||||
|
|
||||||
* help files (documentation)
|
* the calc version you are working with (use the latest calc, see above)
|
||||||
* CHANGES text (brief description of what it does)
|
* new help files or help file patches, if applicable (documentation)
|
||||||
* regress.cal test (to test non-custom code)
|
* proposed text for the CHANGES file (brief description of what it does)
|
||||||
|
* regress.cal test patch, if applicable
|
||||||
* your source code and/or source code changes (:-))
|
* your source code and/or source code changes (:-))
|
||||||
|
|
||||||
The best way to send us new code, if your changes are small, is
|
The best way to send us new code, if your changes are small, is
|
||||||
@@ -45,6 +42,21 @@ Thanks for considering submitting code to calc. Calc is a collective
|
|||||||
work by a number of people. It would not be what it is today without
|
work by a number of people. It would not be what it is today without
|
||||||
your efforts and submissions!
|
your efforts and submissions!
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
One may join the calc testing group by sending a request to:
|
||||||
|
|
||||||
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
|
|
||||||
|
Your message body (not the subject) should consist of:
|
||||||
|
|
||||||
|
subscribe calc-tester address
|
||||||
|
end
|
||||||
|
name your_full_name
|
||||||
|
|
||||||
|
where "address" is your EMail address and "your_full_name"
|
||||||
|
is your full name.
|
||||||
|
|
||||||
Landon Curt Noll
|
Landon Curt Noll
|
||||||
http://reality.sgi.com/chongo
|
http://reality.sgi.com/chongo
|
||||||
|
|
||||||
|
39
help/credit
39
help/credit
@@ -22,41 +22,10 @@ Credits
|
|||||||
|
|
||||||
Most of this source and binary has one of the following copyrights:
|
Most of this source and binary has one of the following copyrights:
|
||||||
|
|
||||||
Copyright (c) 19xx David I. Bell
|
Copyright (c) year David I. Bell
|
||||||
Copyright (c) 19xx David I. Bell and Landon Curt Noll
|
Copyright (c) year David I. Bell and Landon Curt Noll
|
||||||
Copyright (c) 19xx Landon Curt Noll
|
Copyright (c) year Landon Curt Noll
|
||||||
Copyright (c) 19xx Ernest Bowen and Landon Curt Noll
|
Copyright (c) year 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.
|
||||||
|
|
||||||
Send calc comments, suggestions, bug fixes, enhancements and
|
|
||||||
interesting calc scripts that you would like you see included in
|
|
||||||
future distributions to:
|
|
||||||
|
|
||||||
calc-tester@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Landon Noll maintains the official calc http/ftp archive at:
|
|
||||||
|
|
||||||
ftp://reality.sgi.com/users/chongo/src/calc
|
|
||||||
http://reality.sgi.com/chongo/src/calc/
|
|
||||||
|
|
||||||
Alpha test versions, complete with bugs, untested code and
|
|
||||||
experimental features may be fetched (if you are brave) under:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc/
|
|
||||||
|
|
||||||
One may join the calc testing group by sending a request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
|
||||||
|
|
||||||
subscribe calc-tester address
|
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
|
||||||
is your full name.
|
|
||||||
|
|
||||||
Enjoy!
|
|
||||||
|
36
help/inputlevel
Normal file
36
help/inputlevel
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
NAME
|
||||||
|
inputlevel - current input level
|
||||||
|
|
||||||
|
SYNOPSIS
|
||||||
|
inputlevel()
|
||||||
|
|
||||||
|
TYPES
|
||||||
|
return nonnegative integer
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
This function returns the input level at which it is called.
|
||||||
|
When calc starts, it is at level zero. The level is increased
|
||||||
|
by 1 each time execution starts of a read file command or a call to
|
||||||
|
eval(S) for some expression S which evaluates to a string. It
|
||||||
|
decreases by 1 when a file being read reaches EOF or a string
|
||||||
|
being eval-ed reaches '\0', or earlier if a quit statement is
|
||||||
|
encountered at top calculation-level in the flle or string. It
|
||||||
|
decreases to zero if an abort statement is encountered at any
|
||||||
|
function-level in the file or string. If a quit or abort
|
||||||
|
statement is encountered at top calculation-level at top input-level,
|
||||||
|
calc is exited.
|
||||||
|
|
||||||
|
Zero input level is also called top input level; greater values
|
||||||
|
of inputlevel() indicate reading at greater depths.
|
||||||
|
|
||||||
|
EXAMPLE
|
||||||
|
n/a
|
||||||
|
|
||||||
|
LIMITS
|
||||||
|
none
|
||||||
|
|
||||||
|
LIBRARY
|
||||||
|
none
|
||||||
|
|
||||||
|
SEE ALSO
|
||||||
|
read, eval, quit, abort, calclevel
|
@@ -71,6 +71,10 @@
|
|||||||
|
|
||||||
help stdlib
|
help stdlib
|
||||||
|
|
||||||
|
To learn how to invoke the calc command and about calc -flags, try:
|
||||||
|
|
||||||
|
help usage
|
||||||
|
|
||||||
A full and extensive overview of calc may be obtained by:
|
A full and extensive overview of calc may be obtained by:
|
||||||
|
|
||||||
help full
|
help full
|
||||||
@@ -160,5 +164,3 @@
|
|||||||
These can contain both functions to be defined, and expressions
|
These can contain both functions to be defined, and expressions
|
||||||
to be calculated. Global variables which are numbers can be
|
to be calculated. Global variables which are numbers can be
|
||||||
saved to a file by using the 'write filename' command.
|
saved to a file by using the 'write filename' command.
|
||||||
|
|
||||||
XXX - update this file and add in new major features
|
|
||||||
|
117
help/statement
117
help/statement
@@ -10,28 +10,38 @@ Statements
|
|||||||
expressions are optional and may be omitted (as in RETURN).
|
expressions are optional and may be omitted (as in RETURN).
|
||||||
|
|
||||||
|
|
||||||
NOTE: Calc commands are in lower case. UPPER case is used below
|
C-like statements
|
||||||
for emphasis only, and should be considered in lower case.
|
-----------------
|
||||||
|
{ statement }
|
||||||
|
{ statement; ... statement }
|
||||||
IF (expr) statement
|
if (expr) statement
|
||||||
IF (expr) statement ELSE statement
|
if (expr) statement ELSE statement
|
||||||
FOR (optionalexpr ; optionalexpr ; optionalexpr) statement
|
for (optionalexpr ; optionalexpr ; optionalexpr) statement
|
||||||
WHILE (expr) statement
|
while (expr) statement
|
||||||
DO statement WHILE (expr)
|
do statement while (expr)
|
||||||
CONTINUE
|
continue
|
||||||
BREAK
|
break
|
||||||
GOTO label
|
goto label
|
||||||
These all work like in normal C.
|
These all work like in normal C.
|
||||||
|
|
||||||
RETURN optionalexpr
|
See 'help expression' for details on expressions.
|
||||||
|
See 'help builtin' for details on calc builtin functions.
|
||||||
|
|
||||||
|
|
||||||
|
return
|
||||||
|
------
|
||||||
|
return optionalexpr
|
||||||
|
return ( optionalexpr )
|
||||||
This returns a value from a function. Functions always
|
This returns a value from a function. Functions always
|
||||||
have a return value, even if this statement is not used.
|
have a return value, even if this statement is not used.
|
||||||
If no return statement is executed, or if no expression
|
If no return statement is executed, or if no expression
|
||||||
is specified in the return statement, then the return
|
is specified in the return statement, then the return
|
||||||
value from the function is the null type.
|
value from the function is the null type.
|
||||||
|
|
||||||
SWITCH (expr) { caseclauses }
|
|
||||||
|
switch
|
||||||
|
------
|
||||||
|
switch (expr) { caseclauses }
|
||||||
Switch statements work similarly to C, except for the
|
Switch statements work similarly to C, except for the
|
||||||
following. A switch can be done on any type of value,
|
following. A switch can be done on any type of value,
|
||||||
and the case statements can be of any type of values.
|
and the case statements can be of any type of values.
|
||||||
@@ -42,17 +52,12 @@ Statements
|
|||||||
is the exception, and only matches once all other cases
|
is the exception, and only matches once all other cases
|
||||||
have been tested.
|
have been tested.
|
||||||
|
|
||||||
{ statements }
|
|
||||||
This is a normal list of statements, each one ended by
|
|
||||||
a semicolon. Unlike the C language, no declarations are
|
|
||||||
permitted within an inner-level compound statement.
|
|
||||||
Declarations are only permitted at the beginning of a
|
|
||||||
function definition, or at the beginning of an expression
|
|
||||||
sequence.
|
|
||||||
|
|
||||||
MAT variable [dimension] [dimension] ...
|
matrix
|
||||||
MAT variable [dimension, dimension, ...]
|
------
|
||||||
MAT variable [] = { value, ... }
|
mat variable [dimension] [dimension] ...
|
||||||
|
mat variable [dimension, dimension, ...]
|
||||||
|
mat variable [] = { value, ... }
|
||||||
This creates a matrix variable with the specified dimensions.
|
This creates a matrix variable with the specified dimensions.
|
||||||
Matrices can have from 1 to 4 dimensions. When specifying
|
Matrices can have from 1 to 4 dimensions. When specifying
|
||||||
multiple dimensions, you can use either the standard C syntax,
|
multiple dimensions, you can use either the standard C syntax,
|
||||||
@@ -119,8 +124,11 @@ Statements
|
|||||||
local mat temp[5];
|
local mat temp[5];
|
||||||
static mat strtable[] = {"hi", "there", "folks");
|
static mat strtable[] = {"hi", "there", "folks");
|
||||||
|
|
||||||
OBJ type { elementnames } optionalvariables
|
|
||||||
OBJ type variable
|
object
|
||||||
|
------
|
||||||
|
obj type { elementnames } optionalvariables
|
||||||
|
obj type variable
|
||||||
These create a new object type, or create one or more
|
These create a new object type, or create one or more
|
||||||
variables of the specified type. For this calculator,
|
variables of the specified type. For this calculator,
|
||||||
an object is just a structure which is implicitly acted
|
an object is just a structure which is implicitly acted
|
||||||
@@ -183,33 +191,12 @@ Statements
|
|||||||
static obj point temp2 = {4, 3};
|
static obj point temp2 = {4, 3};
|
||||||
global obj point p1, p2, p3;
|
global obj point p1, p2, p3;
|
||||||
|
|
||||||
EXIT string
|
|
||||||
QUIT string
|
|
||||||
This command is used in two cases. At the top command
|
|
||||||
line level, quit will exit from the calculator. This
|
|
||||||
is the normal way to leave the calculator. In any other
|
|
||||||
use, quit will abort the current calculation as if an
|
|
||||||
error had occurred. If a string is given, then the string
|
|
||||||
is printed as the reason for quitting, otherwise a general
|
|
||||||
quit message is printed. The routine name and line number
|
|
||||||
which executed the quit is also printed in either case.
|
|
||||||
|
|
||||||
Quit is useful when a routine detects invalid arguments,
|
print expressions
|
||||||
in order to stop a calculation cleanly. For example,
|
-----------------
|
||||||
for a square root routine, an error can be given if the
|
print expr
|
||||||
supplied parameter was a negative number, as in:
|
print expr, ... expr
|
||||||
|
print expr: ... expr
|
||||||
define mysqrt(n)
|
|
||||||
{
|
|
||||||
if (n < 0)
|
|
||||||
quit "Negative argument";
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
Exit is an alias for quit.
|
|
||||||
|
|
||||||
|
|
||||||
PRINT exprs
|
|
||||||
For interactive expression evaluation, the values of all
|
For interactive expression evaluation, the values of all
|
||||||
typed-in expressions are automatically displayed to the
|
typed-in expressions are automatically displayed to the
|
||||||
user. However, within a function or loop, the printing of
|
user. However, within a function or loop, the printing of
|
||||||
@@ -228,8 +215,8 @@ Statements
|
|||||||
expression unless the statement ends with a colon. As
|
expression unless the statement ends with a colon. As
|
||||||
examples:
|
examples:
|
||||||
|
|
||||||
print 3, 4; prints "3 4" and newline.
|
print 3, 4; prints "3 4" and newline.
|
||||||
print 5:; prints "5" with no newline.
|
print 5:; prints "5" with no newline.
|
||||||
print 'a' : 'b' , 'c'; prints "ab c" and newline.
|
print 'a' : 'b' , 'c'; prints "ab c" and newline.
|
||||||
print; prints a newline.
|
print; prints a newline.
|
||||||
|
|
||||||
@@ -247,25 +234,9 @@ Statements
|
|||||||
prints the name of the file that was opened.
|
prints the name of the file that was opened.
|
||||||
|
|
||||||
|
|
||||||
SHOW item
|
|
||||||
This command displays some information.
|
|
||||||
|
|
||||||
builtin built in functions
|
|
||||||
global global variables
|
|
||||||
function user-defined functions
|
|
||||||
objfunc possible object functions
|
|
||||||
config config parameters and values
|
|
||||||
objtype defined objects
|
|
||||||
|
|
||||||
Only the first 4 characters of item are examined, so:
|
|
||||||
|
|
||||||
show globals
|
|
||||||
show global
|
|
||||||
show glob
|
|
||||||
|
|
||||||
do the same thing.
|
|
||||||
|
|
||||||
|
|
||||||
Also see the help topic:
|
Also see the help topic:
|
||||||
|
|
||||||
command top level commands
|
command top level commands
|
||||||
|
expression calc expression syntax
|
||||||
|
builtin calc builtin functions
|
||||||
|
usage how to invoke the calc command and calc -options
|
||||||
|
30
help/todo
30
help/todo
@@ -13,14 +13,40 @@ Calc Todo Items:
|
|||||||
|
|
||||||
Very High priority items:
|
Very High priority items:
|
||||||
|
|
||||||
* Write the help file for the inputlevel() builtin function.
|
|
||||||
|
|
||||||
* Write the help file for the display() builtin function.
|
* Write the help file for the display() builtin function.
|
||||||
|
|
||||||
* Write the help file for the stoponerror() builtin function.
|
* Write the help file for the stoponerror() builtin function.
|
||||||
|
|
||||||
* Update the errmax about the meaning of errmax(-1).
|
* Update the errmax about the meaning of errmax(-1).
|
||||||
|
|
||||||
|
* Review and if needed, correct/update the help topics:
|
||||||
|
|
||||||
|
topic description
|
||||||
|
----- -----------
|
||||||
|
intro introduction to calc
|
||||||
|
overview overview of calc
|
||||||
|
assoc using associations
|
||||||
|
command top level commands
|
||||||
|
config configuration parameters
|
||||||
|
define how to define functions
|
||||||
|
environment how environment variables effect calc
|
||||||
|
errorcodes calc generated error codes
|
||||||
|
expression expression sequences
|
||||||
|
file using files
|
||||||
|
history command history
|
||||||
|
interrupt how interrupts are handled
|
||||||
|
list using lists
|
||||||
|
mat using matrices
|
||||||
|
obj user defined data types
|
||||||
|
operator math, relational, logic and variable access ...
|
||||||
|
statement flow control and declaration statements
|
||||||
|
types builtin data types
|
||||||
|
unexpected unexpected syntax/usage surprises for C ...
|
||||||
|
variable variables and variable declarations
|
||||||
|
libcalc using the arbitrary precision routines in ...
|
||||||
|
bugs known bugs and mis-features
|
||||||
|
wishlist wish list of future enhancements of calc
|
||||||
|
|
||||||
* Fix any 'Known bugs' as noted in the BUGS file or as
|
* Fix any 'Known bugs' as noted in the BUGS file or as
|
||||||
displayed by 'calc help bugs'.
|
displayed by 'calc help bugs'.
|
||||||
|
|
||||||
|
@@ -19,6 +19,10 @@ Calc command line
|
|||||||
will cause calc to try to process each line being read
|
will cause calc to try to process each line being read
|
||||||
despite the errors that it encounters.
|
despite the errors that it encounters.
|
||||||
|
|
||||||
|
By default, calc startup scripts ($CALCRC) are silently
|
||||||
|
ignored if not found. This flag will report missing
|
||||||
|
startup scripts unless -d is also given.
|
||||||
|
|
||||||
-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
|
||||||
simply generate an error.
|
simply generate an error.
|
||||||
@@ -48,6 +52,9 @@ Calc command line
|
|||||||
|
|
||||||
It's nearly ten past six.
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
This flag disables the reporting of missing calc
|
||||||
|
startup scripts ($CALCRC).
|
||||||
|
|
||||||
-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.
|
||||||
|
|
||||||
|
2
hist.c
2
hist.c
@@ -242,7 +242,7 @@ int
|
|||||||
hist_getline(char *prompt, char *buf, int len)
|
hist_getline(char *prompt, char *buf, int len)
|
||||||
{
|
{
|
||||||
if (!inited)
|
if (!inited)
|
||||||
(void) hist_init((char *) NULL);
|
(void) hist_init(calcbindings);
|
||||||
|
|
||||||
HS.prompt = prompt;
|
HS.prompt = prompt;
|
||||||
HS.bufsize = len - 2;
|
HS.bufsize = len - 2;
|
||||||
|
@@ -44,7 +44,7 @@ CALC_FILES= README bigprime.cal deg.cal ellip.cal lucas.cal lucas_chk.cal \
|
|||||||
test2700.cal test3100.cal test3300.cal test3400.cal prompt.cal \
|
test2700.cal test3100.cal test3300.cal test3400.cal prompt.cal \
|
||||||
test3500.cal seedrandom.cal test4000.cal test4100.cal test4600.cal \
|
test3500.cal seedrandom.cal test4000.cal test4100.cal test4600.cal \
|
||||||
beer.cal hello.cal test5100.cal test5200.cal randombitrun.cal \
|
beer.cal hello.cal test5100.cal test5200.cal randombitrun.cal \
|
||||||
randomrun.cal xx_print.cal natnumset.cal qtime.cal
|
randomrun.cal xx_print.cal natnumset.cal qtime.cal test8400.cal
|
||||||
|
|
||||||
# These files are found (but not built) in the distribution
|
# These files are found (but not built) in the distribution
|
||||||
#
|
#
|
||||||
|
@@ -17,7 +17,7 @@ For example:
|
|||||||
|
|
||||||
will cause calc to load and execute the 'lucas.cal' library.
|
will cause calc to load and execute the 'lucas.cal' library.
|
||||||
Executing the library will cause several functions to be defined.
|
Executing the library will cause several functions to be defined.
|
||||||
Executing the lucas function
|
Executing the lucas function:
|
||||||
|
|
||||||
> lucas(149,60)
|
> lucas(149,60)
|
||||||
1
|
1
|
||||||
|
@@ -30,6 +30,7 @@ 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 */
|
initcfg = config("lib_debug", 0); /* disable lib startup messages */
|
||||||
initcfg = config("calc_debug", 0); /* disable internal debugging */
|
initcfg = config("calc_debug", 0); /* disable internal debugging */
|
||||||
|
initcnf = config("verbose_quit", 0); /* disable quit messages */
|
||||||
initcfg = config("all"); /* save state for later use */
|
initcfg = config("all"); /* save state for later use */
|
||||||
|
|
||||||
print '003: parsed global definitions';
|
print '003: parsed global definitions';
|
||||||
@@ -964,7 +965,7 @@ define test_functions()
|
|||||||
vrfy(strpos(a, a) == 1, '948: strpos(a, a) == 1');
|
vrfy(strpos(a, a) == 1, '948: strpos(a, a) == 1');
|
||||||
vrfy(system("") == 0, '949: system("") == 0');
|
vrfy(system("") == 0, '949: system("") == 0');
|
||||||
vrfy(system("true") == 0, '950: system("true") == 0');
|
vrfy(system("true") == 0, '950: system("true") == 0');
|
||||||
vrfy(isatty(files(0)) == 1, '951: isatty(files(0)) == 1');
|
print '951: test disabled due to stdin dependency';
|
||||||
print '952: test removed';
|
print '952: test removed';
|
||||||
print '953: test removed';
|
print '953: test removed';
|
||||||
vrfy(isstr(cmdbuf()) == 1, '954: isstr(cmdbuf()) == 1');
|
vrfy(isstr(cmdbuf()) == 1, '954: isstr(cmdbuf()) == 1');
|
||||||
@@ -3302,7 +3303,7 @@ define test_fileops()
|
|||||||
|
|
||||||
print '4261: Ending test_fileops';
|
print '4261: Ending test_fileops';
|
||||||
}
|
}
|
||||||
print '071: parsed test_redc()';
|
print '071: parsed test_fileops()';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -5106,7 +5107,7 @@ define test_is()
|
|||||||
vrfy(isatty(square) == 0, '5981: isatty(square) == 0');
|
vrfy(isatty(square) == 0, '5981: isatty(square) == 0');
|
||||||
vrfy(isatty(string) == 0, '5982: isatty(string) == 0');
|
vrfy(isatty(string) == 0, '5982: isatty(string) == 0');
|
||||||
vrfy(isatty(com) == 0, '5983: isatty(com) == 0');
|
vrfy(isatty(com) == 0, '5983: isatty(com) == 0');
|
||||||
vrfy(isatty(files(0)) == 1, '5984: isatty(files(0)) == 1');
|
print '5984: test disabled due to stdin dependency';
|
||||||
/* if we pipe to awk (for make chk), stdout and stderr are not ttys */
|
/* if we pipe to awk (for make chk), stdout and stderr are not ttys */
|
||||||
print '5985: test unused';
|
print '5985: test unused';
|
||||||
print '5986: test unused';
|
print '5986: test unused';
|
||||||
@@ -7120,9 +7121,11 @@ print '188: parsed test_natnumset()';
|
|||||||
/*
|
/*
|
||||||
* test_somenew - test some new features
|
* test_somenew - test some new features
|
||||||
*/
|
*/
|
||||||
|
define func8200(x,y) {if (x>0) return calclevel()+func8200(x-1,y)-y; return 0;}
|
||||||
|
print '189: define func8200(x,y)';
|
||||||
define test_somenew()
|
define test_somenew()
|
||||||
{
|
{
|
||||||
local a, s;
|
local a, s, y;
|
||||||
|
|
||||||
print '8200: Starting test_somenew';
|
print '8200: Starting test_somenew';
|
||||||
|
|
||||||
@@ -7150,13 +7153,40 @@ define test_somenew()
|
|||||||
|
|
||||||
a = isqrt(2e1000); s = "xyz";
|
a = isqrt(2e1000); s = "xyz";
|
||||||
print '8217: a = isqrt(2e1000); s = "xyz";';
|
print '8217: a = isqrt(2e1000); s = "xyz";';
|
||||||
vrfy(hash(a,s) == 2378490456, '8218: hash(a,s) == 2378490456');
|
vrfy(hash(a,s) == 2708885378, '8218: hash(a,s) == 2708885378');
|
||||||
vrfy(hash("curds n whey") == 2376141927,
|
vrfy(hash("curds n whey") == 2376141927,
|
||||||
'8219: hash("curds n whey") == 2376141927');
|
'8219: hash("curds n whey") == 2376141927');
|
||||||
|
|
||||||
print '8220: Ending test_somenew';
|
y = calclevel();
|
||||||
|
print '8220: y = calclevel()';
|
||||||
|
vrfy(func8200(0,y) == 0, '8221: func8200(0,y) == 0');
|
||||||
|
vrfy(func8200(1,y) == 1, '8222: func8200(1,y) == 1');
|
||||||
|
vrfy(func8200(10,y) == 55, '8223: func8200(10,y) == 55');
|
||||||
|
vrfy(func8200(100,y) == 5050, '8224: func8200(100,y) == 5050');
|
||||||
|
|
||||||
|
vrfy(inputlevel() == 1, '8225: inputlevel() == 1');
|
||||||
|
|
||||||
|
print '8226: Ending test_somenew';
|
||||||
}
|
}
|
||||||
print '189: parsed test_somenew()';
|
print '190: parsed test_somenew()';
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* test_quit - test the QUIT functionality
|
||||||
|
*/
|
||||||
|
define test_quit()
|
||||||
|
{
|
||||||
|
local x8400 = 23209; /* watch for lost memory */
|
||||||
|
static s8400 = 21701; /* watch for lost memory */
|
||||||
|
|
||||||
|
print '8400: Starting test_quit';
|
||||||
|
|
||||||
|
quit;
|
||||||
|
prob('quit did not end the test_quit() function');
|
||||||
|
|
||||||
|
/* 8400 serise continued after return, do not print end here */
|
||||||
|
}
|
||||||
|
print '191: parsed test_quit()';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -7442,6 +7472,17 @@ vrfy(l8300(10) == 15, '8309: l8300(10) == 15');
|
|||||||
print '8310: Ending define tests';
|
print '8310: Ending define tests';
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* quit tests
|
||||||
|
*/
|
||||||
|
print;
|
||||||
|
return test_quit();
|
||||||
|
read -once test8400;
|
||||||
|
print '8404: read -once test8400';
|
||||||
|
vrfy(test8400() == 64434, '8405: test8400() == 64434');
|
||||||
|
print '8406: Ending test_quit';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* read various calc libs
|
* read various calc libs
|
||||||
*
|
*
|
||||||
@@ -7455,7 +7496,7 @@ print '8310: Ending define tests';
|
|||||||
* lucas_tbl.cal - duplicatres code already read by another file
|
* lucas_tbl.cal - duplicatres code already read by another file
|
||||||
* regress.cal - this file
|
* regress.cal - this file
|
||||||
* surd.cal - already read by this file
|
* surd.cal - already read by this file
|
||||||
* testXXXX.cal - already read by this file
|
* test9999.cal - files of this form are already read by this file
|
||||||
* xx_print.cal - prints a bunch of things when loaded
|
* xx_print.cal - prints a bunch of things when loaded
|
||||||
*
|
*
|
||||||
* We want to do this 2nd to last; ahead of any final cleanup and behind
|
* We want to do this 2nd to last; ahead of any final cleanup and behind
|
||||||
|
30
lib/test8400.cal
Normal file
30
lib/test8400.cal
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 1999 Landon Curt Noll
|
||||||
|
* Permission is granted to use, distribute, or modify this source,
|
||||||
|
* provided that this copyright notice remains intact.
|
||||||
|
*
|
||||||
|
* By: Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
|
*
|
||||||
|
* This library is used by the 8400 series of the regress.cal test suite.
|
||||||
|
*/
|
||||||
|
|
||||||
|
print "8401: in test8400.cal";
|
||||||
|
|
||||||
|
/*
|
||||||
|
* test8400 - dummy function to allow a check of quit-based memory leaks
|
||||||
|
*/
|
||||||
|
define test8400()
|
||||||
|
{
|
||||||
|
local x8401 = 19937; /* watch for lost memory */
|
||||||
|
static s8401 = 44497; /* watch for lost memory */
|
||||||
|
|
||||||
|
return x8401+s8401;
|
||||||
|
}
|
||||||
|
print "8402: parsed test8400()";
|
||||||
|
vrfy(test8400() == 64434, '8403: test8400() == 64434');
|
||||||
|
|
||||||
|
quit;
|
||||||
|
prob('quit did not end test8400.cal');
|
21
lib_calc.c
21
lib_calc.c
@@ -89,19 +89,20 @@ int i_flag = FALSE; /* TRUE => go interactive if permitted */
|
|||||||
/*
|
/*
|
||||||
* global values
|
* global values
|
||||||
*/
|
*/
|
||||||
char *calcpath; /* $CALCPATH or default */
|
char *calcpath = NULL; /* $CALCPATH or default */
|
||||||
char *calcrc; /* $CALCRC or default */
|
char *calcrc = NULL; /* $CALCRC or default */
|
||||||
char *calcbindings; /* $CALCBINDINGS or default */
|
char *calcbindings = NULL; /* $CALCBINDINGS or default */
|
||||||
char *home; /* $HOME or default */
|
char *home = NULL; /* $HOME or default */
|
||||||
char *pager; /* $PAGER or default */
|
char *pager = NULL; /* $PAGER or default */
|
||||||
char *shell; /* $SHELL or default */
|
char *shell = NULL; /* $SHELL or default */
|
||||||
int stdin_tty = FALSE; /* TRUE if stdin is a tty */
|
int stdin_tty = FALSE; /* TRUE if stdin is a tty */
|
||||||
int havecommands = FALSE; /* TRUE if have one or more cmd args */
|
int havecommands = FALSE; /* TRUE if have one or more cmd args */
|
||||||
int stoponerror = FALSE; /* >0 => stop, <0 => continue on error */
|
int stoponerror = FALSE; /* >0 => stop, <0 => continue on error */
|
||||||
int post_init = FALSE; /* TRUE setjmp for math_error is ready */
|
int post_init = FALSE; /* TRUE setjmp for math_error is ready */
|
||||||
|
BOOL abort_now = FALSE; /* TRUE => go interactive now, if permitted */
|
||||||
|
|
||||||
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 */
|
||||||
|
|
||||||
NUMBER *epsilon_default; /* default allowed error for float calcs */
|
NUMBER *epsilon_default; /* default allowed error for float calcs */
|
||||||
|
|
||||||
|
43
opcodes.c
43
opcodes.c
@@ -33,6 +33,7 @@ static BOOL saveval = TRUE; /* to enable or disable saving */
|
|||||||
static int calc_errno; /* most recent error-number */
|
static int calc_errno; /* most recent error-number */
|
||||||
static int errcount; /* counts calls to error_value */
|
static int errcount; /* counts calls to error_value */
|
||||||
static BOOL go;
|
static BOOL go;
|
||||||
|
static long calc_depth;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* global symbols
|
* global symbols
|
||||||
@@ -106,6 +107,9 @@ initstack(void)
|
|||||||
freevalue(stack--);
|
freevalue(stack--);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
/* initialize calc_depth */
|
||||||
|
|
||||||
|
calc_depth = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -3124,8 +3128,7 @@ o_quit(FUNC *fp, long index)
|
|||||||
s = findstring(index);
|
s = findstring(index);
|
||||||
cp = s->s_str;
|
cp = s->s_str;
|
||||||
}
|
}
|
||||||
if (inputisterminal() && (fp->f_name[0] == '*')
|
if (inputisterminal() && !strcmp(fp->f_name, "*")) {
|
||||||
&& (fp->f_name[1] == '\0')) {
|
|
||||||
if (cp)
|
if (cp)
|
||||||
printf("%s\n", cp);
|
printf("%s\n", cp);
|
||||||
hist_term();
|
hist_term();
|
||||||
@@ -3138,14 +3141,22 @@ o_quit(FUNC *fp, long index)
|
|||||||
}
|
}
|
||||||
if (cp)
|
if (cp)
|
||||||
printf("%s\n", cp);
|
printf("%s\n", cp);
|
||||||
else
|
else if (conf->verbose_quit)
|
||||||
printf("Quit statement executed\n");
|
printf("Quit or abort executed\n");
|
||||||
if (!inputisterminal() && fp->f_name[0] == '*')
|
if (!inputisterminal() && !strcmp(fp->f_name, "*"))
|
||||||
closeinput();
|
closeinput();
|
||||||
go = FALSE;
|
go = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
o_abort(FUNC *fp, long index)
|
||||||
|
{
|
||||||
|
abort_now = TRUE;
|
||||||
|
o_quit(fp, index);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
o_getepsilon(void)
|
o_getepsilon(void)
|
||||||
{
|
{
|
||||||
@@ -3533,7 +3544,8 @@ static struct opcode opcodes[MAX_OPCODE+1] = {
|
|||||||
{o_backslash, OPNUL, "BACKSLASH"}, /* unary backslash op */
|
{o_backslash, OPNUL, "BACKSLASH"}, /* unary backslash op */
|
||||||
{o_setminus, OPNUL, "SETMINUS"}, /* binary backslash op */
|
{o_setminus, OPNUL, "SETMINUS"}, /* binary backslash op */
|
||||||
{o_plus, OPNUL, "PLUS"}, /* unary + op */
|
{o_plus, OPNUL, "PLUS"}, /* unary + op */
|
||||||
{o_jumpnn, OPJMP, "JUMPNN"} /* jump if non-null */
|
{o_jumpnn, OPJMP, "JUMPNN"}, /* jump if non-null */
|
||||||
|
{o_abort, OPONE, "ABORT"} /* abort operation */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -3567,6 +3579,7 @@ calculate(FUNC *fp, int argcount)
|
|||||||
funcname = fp->f_name;
|
funcname = fp->f_name;
|
||||||
funcline = 0;
|
funcline = 0;
|
||||||
go = TRUE;
|
go = TRUE;
|
||||||
|
++calc_depth;
|
||||||
origargcount = argcount;
|
origargcount = argcount;
|
||||||
while (argcount < fp->f_paramcount) {
|
while (argcount < fp->f_paramcount) {
|
||||||
stack++;
|
stack++;
|
||||||
@@ -3682,6 +3695,7 @@ calculate(FUNC *fp, int argcount)
|
|||||||
}
|
}
|
||||||
funcname = oldname;
|
funcname = oldname;
|
||||||
funcline = oldline;
|
funcline = oldline;
|
||||||
|
--calc_depth;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case OPSTI: /* static initialization code */
|
case OPSTI: /* static initialization code */
|
||||||
@@ -3703,6 +3717,7 @@ calculate(FUNC *fp, int argcount)
|
|||||||
freevalue(stack--);
|
freevalue(stack--);
|
||||||
funcname = oldname;
|
funcname = oldname;
|
||||||
funcline = oldline;
|
funcline = oldline;
|
||||||
|
--calc_depth;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3748,8 +3763,10 @@ dumpop(unsigned long *pc)
|
|||||||
case OP_PRINTSTRING: case OP_STRING:
|
case OP_PRINTSTRING: case OP_STRING:
|
||||||
printf(" \"%s\"\n", findstring((long)(*pc))->s_str);
|
printf(" \"%s\"\n", findstring((long)(*pc))->s_str);
|
||||||
return 2;
|
return 2;
|
||||||
case OP_QUIT:
|
case OP_QUIT: case OP_ABORT:
|
||||||
printf(" \"%s\"\n", findstring((long)(*pc))->s_str);
|
if ((long)(*pc) >= 0)
|
||||||
|
printf(" \"%s\"", findstring((long)(*pc))->s_str);
|
||||||
|
putchar('\n');
|
||||||
return 2;
|
return 2;
|
||||||
case OP_INDEXADDR:
|
case OP_INDEXADDR:
|
||||||
printf(" %ld %ld\n", pc[0], pc[1]);
|
printf(" %ld %ld\n", pc[0], pc[1]);
|
||||||
@@ -3837,3 +3854,13 @@ freenumbers(FUNC *fp)
|
|||||||
}
|
}
|
||||||
trimconstants();
|
trimconstants();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
long
|
||||||
|
calclevel(void)
|
||||||
|
{
|
||||||
|
return calc_depth - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* END CODE */
|
||||||
|
@@ -144,7 +144,8 @@
|
|||||||
#define OP_SETMINUS 129L /* binary backslash */
|
#define OP_SETMINUS 129L /* binary backslash */
|
||||||
#define OP_PLUS 130L /* unary + */
|
#define OP_PLUS 130L /* unary + */
|
||||||
#define OP_JUMPNN 131L /* jump if top value is non-null */
|
#define OP_JUMPNN 131L /* jump if top value is non-null */
|
||||||
#define MAX_OPCODE 131L /* highest legal opcode */
|
#define OP_ABORT 132L /* abort operation */
|
||||||
|
#define MAX_OPCODE 132L /* highest legal opcode */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
109
quickhash.c
109
quickhash.c
@@ -56,11 +56,6 @@
|
|||||||
#include "zrand.h"
|
#include "zrand.h"
|
||||||
#include "zrandom.h"
|
#include "zrandom.h"
|
||||||
|
|
||||||
#define ZMOST 2 /* most significant HALFs to hash */
|
|
||||||
#define ZLEAST 2 /* least significant HALFs to hash */
|
|
||||||
#define ZMIDDLE 4 /* HALFs in the middle to hash */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* forward declarations
|
* forward declarations
|
||||||
*/
|
*/
|
||||||
@@ -71,7 +66,8 @@ static QCKHASH objhash(OBJECT *op, QCKHASH val);
|
|||||||
static QCKHASH randhash(RAND *r, QCKHASH val);
|
static QCKHASH randhash(RAND *r, QCKHASH val);
|
||||||
static QCKHASH randomhash(RANDOM *state, QCKHASH val);
|
static QCKHASH randomhash(RANDOM *state, QCKHASH val);
|
||||||
static QCKHASH config_hash(CONFIG *cfg, QCKHASH val);
|
static QCKHASH config_hash(CONFIG *cfg, QCKHASH val);
|
||||||
static QCKHASH fnv_strhash(char *str, QCKHASH val);
|
static QCKHASH fnv_strhash(char *ch, QCKHASH val);
|
||||||
|
static QCKHASH fnv_STRhash(STRING *str, QCKHASH val);
|
||||||
static QCKHASH fnv_fullhash(FULL *v, LEN len, QCKHASH val);
|
static QCKHASH fnv_fullhash(FULL *v, LEN len, QCKHASH val);
|
||||||
static QCKHASH fnv_zhash(ZVALUE z, QCKHASH val);
|
static QCKHASH fnv_zhash(ZVALUE z, QCKHASH val);
|
||||||
static QCKHASH hash_hash(HASH *hash, QCKHASH val);
|
static QCKHASH hash_hash(HASH *hash, QCKHASH val);
|
||||||
@@ -167,7 +163,7 @@ hashvalue(VALUE *vp, QCKHASH val)
|
|||||||
case V_COM:
|
case V_COM:
|
||||||
return fnv_chash(vp->v_com, val);
|
return fnv_chash(vp->v_com, val);
|
||||||
case V_STR:
|
case V_STR:
|
||||||
return fnv_strhash(vp->v_str->s_str, val);
|
return fnv_STRhash(vp->v_str, val);
|
||||||
case V_NULL:
|
case V_NULL:
|
||||||
return val;
|
return val;
|
||||||
case V_OBJ:
|
case V_OBJ:
|
||||||
@@ -411,6 +407,7 @@ config_hash(CONFIG *cfg, QCKHASH val)
|
|||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->lib_debug);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->lib_debug);
|
||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->calc_debug);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->calc_debug);
|
||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->user_debug);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->user_debug);
|
||||||
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->verbose_quit);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash the built up scalar
|
* hash the built up scalar
|
||||||
@@ -438,7 +435,29 @@ config_hash(CONFIG *cfg, QCKHASH val)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* fnv_strhash - Fowler/Noll/Vo 32 bit hash of a string
|
* fnv_strhash - Fowler/Noll/Vo 32 bit hash of a null-terminated string
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* ch the start of the string to hash
|
||||||
|
* val initial hash value
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* a 32 bit QCKHASH value
|
||||||
|
*/
|
||||||
|
static QCKHASH
|
||||||
|
fnv_strhash(char *ch, QCKHASH val)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* hash each character in the string
|
||||||
|
*/
|
||||||
|
while (*ch) {
|
||||||
|
val = fnv(*ch++, val);
|
||||||
|
}
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* fnv_STRhash - Fowler/Noll/Vo 32 bit hash of a STRING
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* str the string to hash
|
* str the string to hash
|
||||||
@@ -448,13 +467,19 @@ config_hash(CONFIG *cfg, QCKHASH val)
|
|||||||
* a 32 bit QCKHASH value
|
* a 32 bit QCKHASH value
|
||||||
*/
|
*/
|
||||||
static QCKHASH
|
static QCKHASH
|
||||||
fnv_strhash(char *str, QCKHASH val)
|
fnv_STRhash(STRING *str, QCKHASH val)
|
||||||
{
|
{
|
||||||
|
char *ch;
|
||||||
|
long n;
|
||||||
|
|
||||||
|
ch = str->s_str;
|
||||||
|
n = str->s_len;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash each character in the string
|
* hash each character in the string
|
||||||
*/
|
*/
|
||||||
while (*str) {
|
while (n-- > 0) {
|
||||||
val = fnv(*str++, val);
|
val = fnv(*ch++, val);
|
||||||
}
|
}
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
@@ -497,48 +522,36 @@ fnv_fullhash(FULL *v, LEN len, QCKHASH val)
|
|||||||
static QCKHASH
|
static QCKHASH
|
||||||
fnv_zhash(ZVALUE z, QCKHASH val)
|
fnv_zhash(ZVALUE z, QCKHASH val)
|
||||||
{
|
{
|
||||||
int skip; /* HALFs to skip in the middle */
|
LEN n;
|
||||||
int i;
|
HALF *hp;
|
||||||
|
#if BASEB == 16
|
||||||
|
FULL f;
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash the sign and length
|
* hash the sign
|
||||||
*/
|
*/
|
||||||
if (zisneg(z)) {
|
val = fnv(z.sign, val + V_NUM);
|
||||||
val = fnv(-(z.len), val+V_NUM);
|
|
||||||
} else {
|
n = z.len;
|
||||||
val = fnv(z.len, val+V_NUM);
|
hp = z.v;
|
||||||
|
|
||||||
|
#if BASEB == 16
|
||||||
|
while (n > 1) {
|
||||||
|
f = (FULL) *hp++;
|
||||||
|
f |= (FULL) *hp++ << BASEB;
|
||||||
|
val = fnv(f, val);
|
||||||
|
n -= 2;
|
||||||
}
|
}
|
||||||
|
if (n) {
|
||||||
/*
|
val = fnv(*hp, val);
|
||||||
* if a ZVALUE is short enough, hash it all
|
|
||||||
*/
|
|
||||||
if (z.len <= ZMOST+ZLEAST+ZMIDDLE) {
|
|
||||||
/* hash all HALFs of a short ZVALUE */
|
|
||||||
for (i=0; i < z.len; ++i) {
|
|
||||||
val = fnv(z.v[i], val);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* otherwise hash the ZLEAST significant HALFs followed by
|
|
||||||
* ZMIDDLE HALFs followed by the ZMOST significant HALFs.
|
|
||||||
*/
|
|
||||||
} else {
|
|
||||||
/* hash the ZLEAST significant HALFs */
|
|
||||||
for (i=0; i < ZLEAST; ++i) {
|
|
||||||
val = fnv(z.v[i], val);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* hash ZMIDDLE HALFs in the middle */
|
|
||||||
skip = (z.len-ZLEAST-ZMOST)/(ZMIDDLE + 1);
|
|
||||||
for (i=ZLEAST-1+skip; i < ZLEAST-1+skip*(ZMIDDLE+1); i+=skip) {
|
|
||||||
val = fnv(z.v[i], val);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* hash the ZMOST significant HALFs */
|
|
||||||
for (i=z.len-1-ZMOST; i < z.len; ++i) {
|
|
||||||
val = fnv(z.v[i], val);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
while (n-- > 0) {
|
||||||
|
val = fnv(*hp, val);
|
||||||
|
++hp;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
return val;
|
return val;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -33,18 +33,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#if defined(__sgi)
|
|
||||||
# include "../longbits.h"
|
|
||||||
# if defined(HAVE_B64)
|
|
||||||
typedef USB64 k_sigset_t;
|
|
||||||
# else
|
|
||||||
typedef struct {
|
|
||||||
USB32 sigbits[2];
|
|
||||||
} k_sigset_t;
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "../calc.h"
|
#include "../calc.h"
|
||||||
|
@@ -33,18 +33,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#if defined(__sgi)
|
|
||||||
# include "../longbits.h"
|
|
||||||
# if defined(HAVE_B64)
|
|
||||||
typedef USB64 k_sigset_t;
|
|
||||||
# else
|
|
||||||
typedef struct {
|
|
||||||
USB32 sigbits[2];
|
|
||||||
} k_sigset_t;
|
|
||||||
# endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "../calc.h"
|
#include "../calc.h"
|
||||||
|
4
seed.c
4
seed.c
@@ -230,8 +230,8 @@ hash_buf(char *buf, unsigned len)
|
|||||||
|
|
||||||
/* convert to hash64 */
|
/* convert to hash64 */
|
||||||
/* hval.w32[1] = 0xffff&(val[3]<<16)+val[2]; */
|
/* hval.w32[1] = 0xffff&(val[3]<<16)+val[2]; */
|
||||||
hval.w32[1] = val[3]<<16 + val[2];
|
hval.w32[1] = (val[3]<<16) + val[2];
|
||||||
hval.w32[0] = val[1]<<16 + val[0];
|
hval.w32[0] = (val[1]<<16) + val[0];
|
||||||
|
|
||||||
#endif /* HAVE_B64 */
|
#endif /* HAVE_B64 */
|
||||||
|
|
||||||
|
15
token.c
15
token.c
@@ -83,6 +83,7 @@ static struct keyword keywords[] = {
|
|||||||
{"print", T_PRINT},
|
{"print", T_PRINT},
|
||||||
{"cd", T_CD},
|
{"cd", T_CD},
|
||||||
{"undefine", T_UNDEFINE},
|
{"undefine", T_UNDEFINE},
|
||||||
|
{"abort", T_ABORT},
|
||||||
{NULL, 0}
|
{NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -334,22 +335,22 @@ static void
|
|||||||
eatcomment(void)
|
eatcomment(void)
|
||||||
{
|
{
|
||||||
int ch;
|
int ch;
|
||||||
|
setprompt(conf->prompt2);
|
||||||
for (;;) {
|
for (;;) {
|
||||||
ch = nextchar();
|
ch = nextchar();
|
||||||
if (ch == '*') {
|
if (ch == '*') {
|
||||||
ch = nextchar();
|
ch = nextchar();
|
||||||
if (ch == '/')
|
if (ch == '/')
|
||||||
return;
|
break;
|
||||||
reread();
|
reread();
|
||||||
}
|
}
|
||||||
if ((ch == EOF) || (ch == '\0') ||
|
if (ch == EOF || ch == '\0') {
|
||||||
(newlines && (ch == '\n') && inputisterminal())) {
|
fprintf(stderr, "Unterminated comment ignored\n");
|
||||||
reread();
|
reread();
|
||||||
scanerror(T_NULL, "Unterminated comment");
|
break;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
setprompt(conf->prompt1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
1
token.h
1
token.h
@@ -110,6 +110,7 @@
|
|||||||
#define T_PRINT 124 /* print keyword */
|
#define T_PRINT 124 /* print keyword */
|
||||||
#define T_CD 125 /* change directory keyword */
|
#define T_CD 125 /* change directory keyword */
|
||||||
#define T_UNDEFINE 126 /* undefine keyword */
|
#define T_UNDEFINE 126 /* undefine keyword */
|
||||||
|
#define T_ABORT 127 /* abort operation */
|
||||||
|
|
||||||
|
|
||||||
#define iskeyword(n) ((n) > 100) /* TRUE if token is a keyword */
|
#define iskeyword(n) ((n) > 100) /* TRUE if token is a keyword */
|
||||||
|
@@ -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 "8.5" /* test number or empty string if no patch */
|
#define MINOR_PATCH "9.1.1" /* test number or empty string if no patch */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version constants
|
* calc version constants
|
||||||
|
2
zmath.h
2
zmath.h
@@ -72,7 +72,7 @@ typedef SB16 SHALF; /* signed HALF */
|
|||||||
typedef USB32 FULL; /* double unit of number storage */
|
typedef USB32 FULL; /* double unit of number storage */
|
||||||
typedef SB32 SFULL; /* signed FULL */
|
typedef SB32 SFULL; /* signed FULL */
|
||||||
|
|
||||||
#define SWAP_HALF_IN_B64(dest, src) SWAP_B32_IN_B64(dest, src)
|
#define SWAP_HALF_IN_B64(dest, src) SWAP_B16_IN_B64(dest, src)
|
||||||
#define SWAP_HALF_IN_B32(dest, src) SWAP_B16_IN_B32(dest, src)
|
#define SWAP_HALF_IN_B32(dest, src) SWAP_B16_IN_B32(dest, src)
|
||||||
#define SWAP_HALF_IN_FULL(dest, src) SWAP_B16_IN_B32(dest, src)
|
#define SWAP_HALF_IN_FULL(dest, src) SWAP_B16_IN_B32(dest, src)
|
||||||
#define SWAP_HALF_IN_HASH(dest, src) SWAP_B16_IN_HASH(dest, src)
|
#define SWAP_HALF_IN_HASH(dest, src) SWAP_B16_IN_HASH(dest, src)
|
||||||
|
Reference in New Issue
Block a user