Release calc version 2.11.0t8.5

This commit is contained in:
Landon Curt Noll
1999-10-27 00:16:03 -07:00
parent 8db10967e8
commit a7e363da8b
34 changed files with 290 additions and 202 deletions

5
BUGS
View File

@@ -79,6 +79,11 @@ Known bugs:
At this point, calc will re-prompt if you give it an EOF, or 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. 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 We are sure some more bugs exist. When you find them, please let
us know! See the above for details on how to report and were to us know! See the above for details on how to report and were to
EMail your bug reports and hopefully patches to fix them. EMail your bug reports and hopefully patches to fix them.

58
CHANGES
View File

@@ -71,6 +71,64 @@ Following is the change from calc version 2.11.0t8 to date:
s = "curds" ' and ' "whey"; s = "curds" ' and ' "whey";
Added FNV hash to the regression test suite.
Added Ernest Bowen's <ernie@turing.une.edu.au> fix for the
FNV regression test of the hash() builtin function.
Added Ernest Bowen's <ernie@turing.une.edu.au> patch to improve
the way config("calc_debug"). Now the lower 4 bits of the
config("calc_debug") parameter have the following meaning:
n Meaning of bit n of config("calc_debug")
0 Outputs shell commands prior to execution.
1 Outputs currently active functions when a quit instruction
is executed.
2 Some details of shs, shs1 and md5 hash states are included
in the output when these are printed.
3 When a function constructs a block value, tests are
made that the result has the properties required for use of
that block, e.g. that the pointer to the start of the
block is not NULL, and that its "length" is not negative.
A failure will result in a runtime error.
Changed the meaning of (config("calc_debug") & 1) from only printing
the shell commands (and pausing) while displaying help files into
the printing of any shell command prior to execution.
Documented the meaning of config("lib_debug"):
n Meaning of bit n of config("lib_debug")
0 When a function is defined, redefined or undefined at
interactive level, a message saying what has been done
is displayed.
1 When a function is defined, redefined or undefined during
the reading of a file, a message saying what has been done
is displayed.
The value for config("lib_debug") in both oldstd and newstd is
3, but if calc is invoked with the -d flag, its initial value
is zero. Thus, if calc is started without the -d flag, until
config("lib_debug") is changed, a message will be output when a
function is defined either interactively or during the reading
of a file.
Changed the calc lib files to reflect the new config("lib_debug")
bit field meaning. Calc lib files that need to print extra information
should now do something such as:
if (config("lib_debug") & 3) {
print "obj xyz defined";
print "funcA([val1 [, val2]]) defined";
print "funcB(size, mass, ...) defined";
}
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:

View File

@@ -164,8 +164,8 @@ endfunc(void)
size += dumpop(&fp->f_opcodes[size]); size += dumpop(&fp->f_opcodes[size]);
} }
} }
if ((inputisterminal() && conf->lib_debug & 1) || if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
(!inputisterminal() && conf->lib_debug & 2)) { (!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC)) {
printf("%s(", fp->f_name); printf("%s(", fp->f_name);
for (index = 0; index < fp->f_paramcount; index++) { for (index = 0; index < fp->f_paramcount; index++) {
if (index) if (index)
@@ -238,8 +238,8 @@ rmuserfunc(char *name)
return; return;
freenumbers(functions[index]); freenumbers(functions[index]);
free(functions[index]); free(functions[index]);
if ((inputisterminal() && conf->lib_debug & 1) || if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
(!inputisterminal() && conf->lib_debug & 2)) (!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC))
printf("%s() undefined\n", name); printf("%s() undefined\n", name);
functions[index] = NULL; functions[index] = NULL;
} }

20
block.c
View File

@@ -104,7 +104,7 @@ blkalloc(int len, int chunk)
/* /*
* return BLOCK * return BLOCK
*/ */
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(nblk); blkchk(nblk);
} }
return nblk; return nblk;
@@ -145,13 +145,11 @@ blk_free(BLOCK *blk)
* debug time, we plan to call this function often. Once we are satisfied, * debug time, we plan to call this function often. Once we are satisfied,
* we will normally call this code only in a few places. * we will normally call this code only in a few places.
* *
* This function is normally called whenever the following builtins are called: * If "calc_debug" has the bit corresponding to CALCDBG_BLOCK set, this
* function is called during execution of the following builtins:
* *
* alloc(), realloc(), free() * alloc(), realloc(), free()
* *
* unless the "calc_debug" is set to -1. If "calc_debug" is > 0, then
* most blk builtins will call this function.
*
* given: * given:
* blk - the BLOCK to check * blk - the BLOCK to check
* *
@@ -166,7 +164,7 @@ blkchk(BLOCK *blk)
/* /*
* firewall - general sanity check * firewall - general sanity check
*/ */
if (conf->calc_debug == -1) { if ((conf->calc_debug & CALCDBG_BLOCK) == 0) {
/* do nothing when debugging is disabled */ /* do nothing when debugging is disabled */
return; return;
} }
@@ -231,7 +229,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
/* /*
* firewall * firewall
*/ */
if (conf->calc_debug != -1) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(blk); blkchk(blk);
} }
@@ -290,7 +288,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
memset(blk->data, 0, blk->maxsize); memset(blk->data, 0, blk->maxsize);
} }
blk->datalen = 0; blk->datalen = 0;
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(blk); blkchk(blk);
} }
return blk; return blk;
@@ -321,7 +319,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
/* /*
* return realloced type * return realloced type
*/ */
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(blk); blkchk(blk);
} }
return blk; return blk;
@@ -349,7 +347,7 @@ blktrunc(BLOCK *blk)
/* /*
* firewall * firewall
*/ */
if (conf->calc_debug != -1) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(blk); blkchk(blk);
} }
@@ -370,7 +368,7 @@ blktrunc(BLOCK *blk)
/*NOTREACHED*/ /*NOTREACHED*/
} }
blk->data[0] = (USB8)0; blk->data[0] = (USB8)0;
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_BLOCK) {
blkchk(blk); blkchk(blk);
} }
return; return;

View File

@@ -134,13 +134,31 @@ struct config {
int blkverbose; /* TRUE => print all lines if a block */ int 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: <0 none, 0 default, >0 more */ int lib_debug; /* library debug, see LIB_DEBUG_XXX below */
int calc_debug; /* internal debug: <0 none, 0 default,>0 more */ 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 */
}; };
typedef struct config CONFIG; typedef struct config CONFIG;
/*
* lib_debug bit masks
*/
#define LIBDBG_STDIN_FUNC (0x00000001) /* interactive func define debug */
#define LIBDBG_FILE_FUNC (0x00000002) /* file read func define debug */
#define LIBDBG_MASK (0x00000003)
/*
* calc_debug bit masks
*/
#define CALCDBG_SYSTEM (0x00000001) /* print system cmd prior to exec */
#define CALCDBG_FUNC_QUIT (0x00000002) /* active functions when quit */
#define CALCDBG_HASH_STATE (0x00000004) /* hash state details */
#define CALCDBG_BLOCK (0x00000008) /* block debug */
#define CALCDBG_MASK (0x0000000f)
/* /*
* global configuration states and aliases * global configuration states and aliases
*/ */

9
func.c
View File

@@ -1524,16 +1524,12 @@ static VALUE
f_hash(int count, VALUE **vals) f_hash(int count, VALUE **vals)
{ {
QCKHASH hash; QCKHASH hash;
long lhash;
VALUE result; VALUE result;
hash = FNV1_32_BASIS; hash = FNV1_32_BASIS;
while (count-- > 0) while (count-- > 0)
hash = hashvalue(*vals++, hash); hash = hashvalue(*vals++, hash);
lhash = (long) hash; result.v_num = utoq((FULL) hash);
if (lhash < 0)
lhash = -lhash;
result.v_num = itoq(lhash);
result.v_type = V_NUM; result.v_type = V_NUM;
return result; return result;
} }
@@ -6041,6 +6037,9 @@ f_system(VALUE *vp)
/*NOTREACHED*/ /*NOTREACHED*/
} }
result.v_type = V_NUM; result.v_type = V_NUM;
if (conf->calc_debug & CALCDBG_SYSTEM) {
printf("%s\n", vp->v_str->s_str);
}
result.v_num = itoq((long) system(vp->v_str->s_str)); result.v_num = itoq((long) system(vp->v_str->s_str));
return result; return result;
} }

3
help.c
View File

@@ -121,9 +121,8 @@ givehelp(char *type)
"else %s no such help, try: help help;fi", "else %s no such help, try: help help;fi",
HELPDIR, type, pager, HELPDIR, type, HELPDIR, type, pager, HELPDIR, type,
CUSTOMHELPDIR, type, pager, CUSTOMHELPDIR, type, ECHO); CUSTOMHELPDIR, type, pager, CUSTOMHELPDIR, type, ECHO);
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_SYSTEM) {
printf("%s\n", helpcmd); printf("%s\n", helpcmd);
sleep(3);
} }
/* execute the help command */ /* execute the help command */

View File

@@ -40,9 +40,9 @@ Configuration parameters
"blkverbose" TRUE=>print all lines, FALSE=>skip duplicates "blkverbose" TRUE=>print all lines, FALSE=>skip duplicates
"blkbase" block output base "blkbase" block output base
"blkfmt" block output format "blkfmt" block output format
"lib_debug" calc library script debug level "lib_debug" controls library script debug information
"calc_debug" internal calc debug level "calc_debug" controls internal calc debug information
"user_debug" user defined debug level "user_debug" for user defined debug information
The "all" config value allows one to save/restore the configuration The "all" config value allows one to save/restore the configuration
@@ -78,7 +78,8 @@ Configuration parameters
The "newstd" is not backward compatible with the historic The "newstd" is not backward compatible with the historic
configuration. Even so, some people prefer this configuration configuration. Even so, some people prefer this configuration
and place the config("all", "newstd") command in their CALCRC and place the config("all", "newstd") command in their CALCRC
startup files. startup files; newstd may also be established by invoking calc
with the flag -n.
When nonzero, the "trace" parameter activates one or more features When nonzero, the "trace" parameter activates one or more features
that may be useful for debugging. These features correspond to that may be useful for debugging. These features correspond to
@@ -103,9 +104,12 @@ Configuration parameters
the decimal point to be printed in real or exponential mode in the decimal point to be printed in real or exponential mode in
normal unformatted printing (print, strprint, fprint) or in normal unformatted printing (print, strprint, fprint) or in
formatted printing (printf, strprintf, fprintf) when precision is not formatted printing (printf, strprintf, fprintf) when precision is not
specified. The initial value is 20. This parameter does not change specified. The initial value for oldstd is 20, for newstd 10.
the stored value of a number. Where rounding is necessary, the type The parameter may be changed to the value d by either
of rounding to be used is controlled by "outround". config("display", d) or by display (d). This parameter does not change
the stored value of a number. Where rounding is necessary to
display up to d decimal places, the type of rounding to be used is
controlled by config("outround").
The "epsilon" parameter specifies the default accuracy for the The "epsilon" parameter specifies the default accuracy for the
calculation of functions for which exact values are not possible or calculation of functions for which exact values are not possible or
@@ -118,9 +122,10 @@ Configuration parameters
absolute value of the remainder usually does not exceed epsilon/2. absolute value of the remainder usually does not exceed epsilon/2.
Functions which require an epsilon value accept an Functions which require an epsilon value accept an
optional argument which overrides this default epsilon value for optional argument which overrides this default epsilon value for
that single call. (The value v can be assigned to the "epsilon" that single call. The value v can be assigned to the "epsilon"
parameter by epsilon(v) as well as by config("epsilon", v), and the parameter by either config("epsilon", v) or epsilon(v); each of
current value obtained by epsilon() as well as by config("epsilon").) these functions return the current epsilon value; config("epsilon")
or epsilon() returns but does not change the epsilon value.
For the transcendental functions and the functions sqrt() and For the transcendental functions and the functions sqrt() and
appr(), the calculated value is always a multiple of epsilon. appr(), the calculated value is always a multiple of epsilon.
@@ -311,67 +316,64 @@ Configuration parameters
The default "blkfmt" is "hd". The default "blkfmt" is "hd".
With regards to "lib_debug", "calc_debug" and "user_debug": The "lib_debug" parameter is intended for controlling the possible
higher absolute values result in more detailed debugging and display of special information relating to functions, objects, and
more verbose debug messages. The default value is 0 in which other structures created by instructions in calc scripts.
a very amount of debugging will be performed with nil messages. Zero value of config("lib_debug") means that no such information
The -1 value is reserved for no debugging or messages. Any is displayed. For other values, the non-zero bits which currently
value <-1 will perform debugging silently (presumably collecting have meanings are as follows:
data to be displayed at a later time). Values >0 result in a
greater degree of debugging and more verbose messages.
The "lib_debug" is reserved by convention for calc library scripts. n Meaning of bit n of config("lib_debug")
This config parameter takes the place of the lib_debug global variable.
By convention, "lib_debug" has the following meanings:
<-1 no debug messages are printed though some internal 0 When a function is defined, redefined or undefined at
debug actions and information may be collected interactive level, a message saying what has been done
is displayed.
-1 no debug messages are printed, no debug actions will be taken 1 When a function is defined, redefined or undefined during
the reading of a file, a message saying what has been done
is displayed.
0 only usage message regarding each important object are The value for config("lib_debug") in both oldstd and newstd is 3,
printed at the time of the read (default) but if calc is invoked with the -d flag, its initial value is zero.
Thus, if calc is started without the -d flag, until config("lib_debug")
is changed, a message will be output when a function is defined
either interactively or during the reading of a file.
>0 messages regarding each important object are The "calc_debug" is intended for controlling internal calc routines
printed at the time of the read in addition that test its operation, or collect or display information that
to other debug messages might be useful for debug purposes. Much of the output from these
will make sense only to calc wizards. Zero value (the default for
both oldstd and newstd) of config("lib_calc") corresponds to switching
off all these routines. For nonzero value, particular bits
currently have the following meanings:
The "calc_debug" is reserved by convention for internal calc routines. n Meaning of bit n of config("calc_debug")
The output of "calc_debug" will change from release to release.
Generally this value is used by calc wizards and by the regress.cal
routine (make check). By convention, "calc_debug" has the following
meanings:
<-1 reserved for future use 0 outputs shell commands prior to execution
-1 no debug messages are printed, no debug actions will be taken 1 outputs currently active functions when a quit instruction
is executed
0 very little, if any debugging is performed (and then mostly 2 some details of shs, shs1 and md5 hash states are included
in alpha test code). The only output is as a result of in the output when these are printed
internal fatal errors (typically either math_error() or
exit() will be called). (default)
>0 a greater degree of debugging is performed and more 3 when a function constructs a block value, tests are
verbose messages are printed (regress.cal uses 1). made that the result has the properties required for use of
that block, e.g. that the pointer to the start of the
block is not NULL, and that its "length" is not negative.
A failure will result in a runtime error.
Bits >= 4 are reserved for future use and should not be used at this time.
The "user_debug" is provided for use by users. Calc ignores this value The "user_debug" is provided for use by users. Calc ignores this value
other than to set it to 0 by default (for both "oldstd" and "newstd"). other than to set it to 0 by default (for both "oldstd" and "newstd").
No calc code or shipped library will change this value other than No calc code or shipped library should change this value. Users
during startup or during a config("all", xyz) call. should feel free to use it in any way. In particular they may
use particular bits for special purposes as with "calc_debug", or
The following is suggested as a convention for use of "user_debug". they may use it to indicate a debug level with larger values
These are only suggestions: feel free to use it as you like: indicating more stringent and more informative tests with presumably
slower operation or more memory usage, and a particular value (like
<-1 no debug messages are printed though some internal -1 or 0) corresponding to "no tests".
debug actions and information may be collected
-1 no debug messages are printed, no debug actions will be taken
0 very little, if any debugging is performed. The only output
are from fatal errors. (default)
>0 a greater degree of debugging is performed and more
verbose messages are printed
The following are synonyms for true: The following are synonyms for true:

View File

@@ -1,5 +1,5 @@
NAME NAME
hash - hash value hash - FNV-1 hash value
SYNOPSIS SYNOPSIS
hash(x_1 [, x_2, x_3, ...]) hash(x_1 [, x_2, x_3, ...])
@@ -12,23 +12,32 @@ TYPES
DESCRIPTION DESCRIPTION
Returns a hash value for one or more values of arbitrary types. Returns a hash value for one or more values of arbitrary types.
This function implements the Fowler/Noll/Vo hash-1 (FNV-1 hash). The basis of this hash algorithm was taken from an idea sent
The basis of the hash algorithm was taken from an idea sent as reviewer comments to the IEEE POSIX P1003.2 committee by:
by Email to the IEEE POSIX P1003.2 mailing list from Phong Vo
(kpv@research.att.com) and Glenn Fowler (gsf@research.att.com).
Landon Curt Noll (http://reality.sgi.com/chongo) later improved on
their algorithm to come up with Fowler/Noll/Vo hash.
See: Phong Vo (http://www.research.att.com/info/kpv)
Glenn Fowler (http://www.research.att.com/~gsf/)
http://reality.sgi.com/chongo/tech/comp/fnv/index.html In a subsequent ballot round:
for more information in this hash. Landon Curt Noll (http://reality.sgi.com/chongo)
improved on their algorithm. Some people tried this hash
and found that it worked rather well. In an EMail message
to Landon, they named it ``Fowler/Noll/Vo'' or the FNV hash.
FNV hashes are architected to be fast while maintaining a low
collision rate. The FNV speed allows one to quickly hash lots
of data while maintaining a reasonable collision rate. See:
http://reality.sgi.com/chongo/tech/comp/fnv/
for more details as well as other forms of the FNV hash.
EXAMPLE EXAMPLE
> a = isqrt(2e1000); s = "xyz"; > a = isqrt(2e1000); s = "xyz";
> hash(a,s) > hash(a,s)
1916476840 2378490456
LIMITS LIMITS
The number of arguments is not to exceed 100. The number of arguments is not to exceed 100.
@@ -37,3 +46,4 @@ LIBRARY
none none
SEE ALSO SEE ALSO
sha, sha1, md5

View File

@@ -21,9 +21,6 @@ Very High priority items:
* Update the errmax about the meaning of errmax(-1). * Update the errmax about the meaning of errmax(-1).
* Document the new meanings for bit values and the sign of
of config("lib_debug") in the appropriate help file(s).
* 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'.
@@ -61,6 +58,8 @@ High priority items:
ensure that they have not introduced new or re-introduced old bugs ensure that they have not introduced new or re-introduced old bugs
into calc. into calc.
* Consider using configure to build the calc Makefile.
=-= =-=
Medium priority items: Medium priority items:
@@ -91,3 +90,6 @@ Medium priority items:
other stuff) in a separate library. other stuff) in a separate library.
* Clean the source code and document it better. * Clean the source code and document it better.
* Add a builtin function to access the 64 bit FNV hash which
is currently being used internally in seed.c.

View File

@@ -179,37 +179,3 @@ Calc Enhancement Wish List:
* Add read -once -try "filename" which would do nothing * Add read -once -try "filename" which would do nothing
if "filename" was not a readable file. if "filename" was not a readable file.
* Blocks should have the following features:
+ read/write to/from files (ala fread/fwrite)
+ misc memory functions (ala memcpy, memcmp, memset,
memchr, etc.)
+ scatter and gather functions (to send every n-th octet
to another block and to copy from n blocks, the 1st
then 2nd then 3rd ... octets)
* Printing of blocks should be under the control of the
config() interface. This should allow one to select
from any of the following formats:
+ as one long string
+ as a series of lines (< 80 chars wide)
+ in od command style (offset: value value value ...)
+ in hex dump style (offset: val val val val ... 3hf.Uas.c)
* In addition one should be able to control the following
aspects of printing blocks via the config() interface:
+ base (hex, octal, char, base 2)
+ amount of data (the first n octets or the entire block)
+ skipping printing of duplicate print lines (ala od)
+ have the ability to print the block as raw data

View File

@@ -12,6 +12,12 @@
#include <pwd.h> #include <pwd.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/stat.h> #include <sys/stat.h>
#include "have_unistd.h"
#if defined(HAVE_UNISTD_H)
#include <unistd.h>
#endif
#include "calc.h" #include "calc.h"
#include "conf.h" #include "conf.h"
#include "hist.h" #include "hist.h"
@@ -633,6 +639,9 @@ ttychar(void)
if (*cmd == '\0' || *cmd == '\n') if (*cmd == '\0' || *cmd == '\n')
cmd = shell; cmd = shell;
if (allow_exec) { if (allow_exec) {
if (conf->calc_debug & CALCDBG_SYSTEM) {
printf("%s\n", cmd);
}
system(cmd); system(cmd);
} else { } else {
fprintf(stderr, "execution disallowed by -m flag\n"); fprintf(stderr, "execution disallowed by -m flag\n");

View File

@@ -50,37 +50,41 @@ version of read:
This will cause the needed library files to be read once. If these This will cause the needed library files to be read once. If these
files have already been read, the read -once will act as a noop. files have already been read, the read -once will act as a noop.
By convention, the config parameter "lib_debug" is used to control The "lib_debug" parameter is intended for controlling the possible
the verbosity of debug information printed by lib files. By default, display of special information relating to functions, objects, and
the "lib_debug" has a value of 0. other structures created by instructions in calc scripts.
Zero value of config("lib_debug") means that no such information
is displayed. For other values, the non-zero bits which currently
have meanings are as follows:
The "lib_debug" config parameter takes the place of the lib_debug n Meaning of bit n of config("lib_debug")
global variable. By convention, "lib_debug" has the following meanings:
<-1 no debug messages are printed though some internal 0 When a function is defined, redefined or undefined at
debug actions and information may be collected interactive level, a message saying what has been done
is displayed.
-1 no debug messages are printed, no debug actions will be taken 1 When a function is defined, redefined or undefined during
the reading of a file, a message saying what has been done
is displayed.
0 only usage message regarding each important object are The value for config("lib_debug") in both oldstd and newstd is 3,
printed at the time of the read (default) but if calc is invoked with the -d flag, its initial value is zero.
Thus, if calc is started without the -d flag, until config("lib_debug")
is changed, a message will be output when a function is defined
either interactively or during the reading of a file.
>0 messages regarding each important object are Sometimes the information printed is not enough. In addition to the
printed at the time of the read in addition standard information, one might want to print:
to other debug messages
When config("lib_debug") >= 0, function names and their arg are
printed as they are defined. Sometimes this printing is not enough
information. For example:
* useful obj definitions * useful obj definitions
* functions with optional args * functions with optional args
* functions with optional args where the param() interface is used * functions with optional args where the param() interface is used
For these cases we suggest that you place at the bottom of your code For these cases we suggest that you place at the bottom of your code
something like: something that prints extra information if config("lib_debug") has
either of the bottom 2 bits set:
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj xyz defined"; print "obj xyz defined";
print "funcA([val1 [, val2]]) defined"; print "funcA([val1 [, val2]]) defined";
print "funcB(size, mass, ...) defined"; print "funcB(size, mass, ...) defined";

View File

@@ -174,7 +174,7 @@ define chrem()
} }
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "chrem(r1,m1 [,r2,m2 ...]) defined"; print "chrem(r1,m1 [,r2,m2 ...]) defined";
print "chrem(rlist [,mlist]) defined"; print "chrem(rlist [,mlist]) defined";
} }

View File

@@ -111,6 +111,6 @@ define fixdms(a)
a.deg %= 360; a.deg %= 360;
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj dms {deg, min, sec} defined"; print "obj dms {deg, min, sec} defined";
} }

View File

@@ -1027,7 +1027,7 @@ gen_v1(h, n)
define define
ldebug(funct, str) ldebug(funct, str)
{ {
if (config("lib_debug") > 0) { if (config("lib_debug") & 3) {
print "DEBUG:", funct:":", str; print "DEBUG:", funct:":", str;
} }
return; return;

View File

@@ -331,7 +331,7 @@ lucas_chk(high_n, quiet)
/* skip primes where h>=2^n */ /* skip primes where h>=2^n */
if (highbit(h_p[i]) >= n_p[i]) { if (highbit(h_p[i]) >= n_p[i]) {
if (config("lib_debug") > 0) { if (config("lib_debug") & 3) {
print "h>=2^n skip:", h_p[i]:"*2^":n_p[i]:"-1"; print "h>=2^n skip:", h_p[i]:"*2^":n_p[i]:"-1";
} }
continue; continue;

View File

@@ -152,7 +152,7 @@ d_val[97]=1045; a_val[97]=33; b_val[97]=1; r_val[97]=44;
d_val[99]=9797; a_val[99]=97; b_val[99]=1; r_val[99]=388; d_val[99]=9797; a_val[99]=97; b_val[99]=1; r_val[99]=388;
d_val[100]= 51; a_val[100]= 7; b_val[100]=1; r_val[100]=2; d_val[100]= 51; a_val[100]= 7; b_val[100]=1; r_val[100]=2;
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "d_val[100] defined"; print "d_val[100] defined";
print "a_val[100] defined"; print "a_val[100] defined";
print "b_val[100] defined"; print "b_val[100] defined";

View File

@@ -312,6 +312,6 @@ define mfactor(n, start_k, rept_loop, p_elim)
return q; return q;
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "mfactor(n [, start_k=1 [, rept_loop=10000 [, p_elim=17]]])" print "mfactor(n [, start_k=1 [, rept_loop=10000 [, p_elim=17]]])"
} }

View File

@@ -189,7 +189,7 @@ define mod_pow(a, b)
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj mod {a} defined"; print "obj mod {a} defined";
print "mod_value defined"; print "mod_value defined";
print "set mod_value as needed"; print "set mod_value as needed";

View File

@@ -687,6 +687,6 @@ a=pol(1,4,4,2,3,1);
b=pol(5,16,8,1); b=pol(5,16,8,1);
c=pol(1+2i,3+4i,5+6i); c=pol(1+2i,3+4i,5+6i);
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj poly {p} defined"; print "obj poly {p} defined";
} }

View File

@@ -195,6 +195,6 @@ define quat_shift(a, b)
return x.s; return x.s;
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj quat {s, v} defined"; print "obj quat {s, v} defined";
} }

View File

@@ -122,6 +122,6 @@ define randrun(run_cnt)
printf("max length=%d\n", max_run); printf("max length=%d\n", max_run);
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "randrun([run_length]) defined"; print "randrun([run_length]) defined";
} }

View File

@@ -28,8 +28,8 @@ global ecnt; /* expected value of errcount() */
ecnt = 0; /* clear expected errcount() value */ ecnt = 0; /* clear expected errcount() value */
initcfg = config("all", "oldstd"); /* set config to startup default */ initcfg = config("all", "oldstd"); /* set config to startup default */
initcfg = config("lib_debug", -4); /* disable lib startup messages */ initcfg = config("lib_debug", 0); /* disable lib startup messages */
initcfg = config("calc_debug", 1); /* enable more internal debugging */ initcfg = config("calc_debug", 0); /* disable internal debugging */
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';
@@ -7150,9 +7150,11 @@ 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) == 1916476840, '8218: hash(a,s) == 1916476840'); vrfy(hash(a,s) == 2378490456, '8218: hash(a,s) == 2378490456');
vrfy(hash("curds n whey") == 2376141927,
'8219: hash("curds n whey") == 2376141927');
print '8219: Ending test_somenew'; print '8220: Ending test_somenew';
} }
print '189: parsed test_somenew()'; print '189: parsed test_somenew()';

View File

@@ -113,7 +113,7 @@ define seedrandom(seed1, seed2, size, trials)
p = 2*fp+1; p = 2*fp+1;
} while (ptest(p,1,0) == 0); } while (ptest(p,1,0) == 0);
} while(ptest(p, trials) == 0 || ptest(fp, trials) == 0); } while(ptest(p, trials) == 0 || ptest(fp, trials) == 0);
if (config("lib_debug") > 0) { if (config("lib_debug") & 3) {
print "/* 1st Blum prime */ p=", p; print "/* 1st Blum prime */ p=", p;
} }
@@ -127,7 +127,7 @@ define seedrandom(seed1, seed2, size, trials)
q = 2*fq+1; q = 2*fq+1;
} while (ptest(q,1,0) == 0); } while (ptest(q,1,0) == 0);
} while(ptest(q, trials) == 0 || ptest(fq, trials) == 0); } while(ptest(q, trials) == 0 || ptest(fq, trials) == 0);
if (config("lib_debug") > 0) { if (config("lib_debug") & 3) {
print "/* 2nd Blum prime */ q=", q; print "/* 2nd Blum prime */ q=", q;
} }
@@ -137,7 +137,7 @@ define seedrandom(seed1, seed2, size, trials)
n = p*q; /* the Blum modulus */ n = p*q; /* the Blum modulus */
binsize = highbit(n)+1; /* smallest power of 2 > p*q */ binsize = highbit(n)+1; /* smallest power of 2 > p*q */
r = pmod(rand(1<<ceil(binsize*4/5), 1<<(binsize-2)), 2, n); r = pmod(rand(1<<ceil(binsize*4/5), 1<<(binsize-2)), 2, n);
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "/* seed quadratic residue */ r=", r; print "/* seed quadratic residue */ r=", r;
print "/* newn", binsize, "bit quadratic residue*/ newn=", n; print "/* newn", binsize, "bit quadratic residue*/ newn=", n;
} }
@@ -154,6 +154,6 @@ define seedrandom(seed1, seed2, size, trials)
return old_state; return old_state;
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "seedrandom(seed1, seed2, size [, trials]) defined"; print "seedrandom(seed1, seed2, size [, trials]) defined";
} }

View File

@@ -261,7 +261,7 @@ define surd_rel(a, b)
return sgn(x^2 - y^2 * surd_type) * sgn(x); return sgn(x^2 - y^2 * surd_type) * sgn(x);
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "obj surd {a, b} defined"; print "obj surd {a, b} defined";
print "surd_type defined"; print "surd_type defined";
print "set surd_type as needed"; print "set surd_type as needed";

View File

@@ -23,6 +23,6 @@ define sc()
return s; return s;
} }
if (config("lib_debug") >= 0) { if (config("lib_debug") & 3) {
print "sc(a, b, ...) defined"; print "sc(a, b, ...) defined";
} }

2
md5.c
View File

@@ -656,7 +656,7 @@ MD5_print(HASH *state)
/* /*
* form the hash value * form the hash value
*/ */
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_HASH_STATE) {
char buf[DEBUG_SIZE+1]; /* hash value buffer */ char buf[DEBUG_SIZE+1]; /* hash value buffer */
/* /*

View File

@@ -3697,7 +3697,7 @@ calculate(FUNC *fp, int argcount)
freevalue(&locals[i]); freevalue(&locals[i]);
if (locals != localtable) if (locals != localtable)
free(locals); free(locals);
if (conf->calc_debug & 2) if (conf->calc_debug & CALCDBG_FUNC_QUIT)
printf("\t\"%s\": line %ld\n", funcname, funcline); printf("\t\"%s\": line %ld\n", funcname, funcline);
while (stack > beginstack) while (stack > beginstack)
freevalue(stack--); freevalue(stack--);

View File

@@ -79,22 +79,29 @@ static QCKHASH blk_hash(BLOCK *blk, QCKHASH val);
/* /*
* fnv - compute the next Fowler/Noll/Vo hash given a variable * FNV-0 - Fowler/Noll/Vo-0 32 bit hash
* *
* The basis of the hash algorithm was taken from an idea * The basis of this hash algorithm was taken from an idea sent
* sent by Email to the IEEE Posix P1003.2 mailing list from * as reviewer comments to the IEEE POSIX P1003.2 committee by:
* Phong Vo (kpv@research.att.com) and Glenn Fowler (gsf@research.att.com).
* Landon Curt Noll (http://reality.sgi.com/chongo) later improved on there
* algorithm to come up with Fowler/Noll/Vo hash.
* *
* The magic lies in the constant 16777619, which for 32 bit hashing * Phong Vo (http://www.research.att.com/info/kpv)
* is able to process 234936 words from the web2 dictionary without * Glenn Fowler (http://www.research.att.com/~gsf/)
* any collisions.
* *
* See: * In a subsequent ballot round:
* http://reality.sgi.com/chongo/src/fnv/fnv_hash.tar.gz *
* http://reality.sgi.com/chongo/src/fnv/h32.c * Landon Curt Noll (http://reality.sgi.com/chongo)
* http://reality.sgi.com/chongo/src/fnv/h64.c *
* improved on their algorithm. Some people tried this hash
* and found that it worked rather well. In an EMail message
* to Landon, they named it ``Fowler/Noll/Vo'' or the FNV hash.
*
* FNV hashes are architected to be fast while maintaining a low
* collision rate. The FNV speed allows one to quickly hash lots
* of data while maintaining a reasonable collision rate. See:
*
* http://reality.sgi.com/chongo/tech/comp/fnv/
*
* for more details as well as other forms of the FNV hash.
* *
* given: * given:
* x the value to hash (must not be longer than 32 bits) * x the value to hash (must not be longer than 32 bits)

39
seed.c
View File

@@ -87,7 +87,7 @@ typedef struct s_hash64 hash64;
/* /*
* FNV-1 basis * FNV-1 initial basis
* *
* We start the hash at a non-zero value at the beginning so that * We start the hash at a non-zero value at the beginning so that
* hashing blocks of data with all 0 bits do not map onto the same * hashing blocks of data with all 0 bits do not map onto the same
@@ -131,7 +131,7 @@ typedef struct s_hash64 hash64;
/* /*
* hash_buf - perform a 64 bit Fowler/Noll/Vo hash on a buffer * hash_buf - perform a Fowler/Noll/Vo-1 64 bit hash
* *
* input: * input:
* buf - start of buffer to hash * buf - start of buffer to hash
@@ -152,20 +152,29 @@ hash_buf(char *buf, unsigned len)
char *buf_end = buf+len; /* beyond end of hash area */ char *buf_end = buf+len; /* beyond end of hash area */
/* /*
* Fowler/Noll/Vo hash - hash each character in the string * FNV-1 - Fowler/Noll/Vo-1 64 bit hash
* *
* The basis of the hash algorithm was taken from an idea * The basis of this hash algorithm was taken from an idea sent
* sent by Email to the IEEE POSIX P1003.2 mailing list from * as reviewer comments to the IEEE POSIX P1003.2 committee by:
* Phong Vo (kpv@research.att.com) and Glenn Fowler *
* (gsf@research.att.com). * Phong Vo (http://www.research.att.com/info/kpv)
* * Glenn Fowler (http://www.research.att.com/~gsf/)
* See: *
* http://reality.sgi.com/chongo/tech/comp/fnv/index.html * In a subsequent ballot round:
* *
* for information on 32bit and 64bit Fowler/Noll/Vo hashes. * Landon Curt Noll (http://reality.sgi.com/chongo)
* *
* Landon Curt Noll (http://reality.sgi.com/chongo) later improved * improved on their algorithm. Some people tried this hash
* on their algorithm to come up with Fowler/Noll/Vo hash. * and found that it worked rather well. In an EMail message
* to Landon, they named it ``Fowler/Noll/Vo'' or the FNV hash.
*
* FNV hashes are architected to be fast while maintaining a low
* collision rate. The FNV speed allows one to quickly hash lots
* of data while maintaining a reasonable collision rate. See:
*
* http://reality.sgi.com/chongo/tech/comp/fnv/
*
* for more details as well as other forms of the FNV hash.
*/ */
#if defined(HAVE_B64) #if defined(HAVE_B64)
/* hash each octet of the buffer */ /* hash each octet of the buffer */

2
shs.c
View File

@@ -696,7 +696,7 @@ shs_print(HASH *state)
/* /*
* form the hash value * form the hash value
*/ */
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_HASH_STATE) {
char buf[DEBUG_SIZE+1]; /* hash value buffer */ char buf[DEBUG_SIZE+1]; /* hash value buffer */
/* /*

2
shs1.c
View File

@@ -672,7 +672,7 @@ shs1_print(HASH *state)
/* /*
* form the hash value * form the hash value
*/ */
if (conf->calc_debug > 0) { if (conf->calc_debug & CALCDBG_HASH_STATE) {
char buf[DEBUG_SIZE+1]; /* hash value buffer */ char buf[DEBUG_SIZE+1]; /* hash value buffer */
/* /*

View File

@@ -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.4" /* test number or empty string if no patch */ #define MINOR_PATCH "8.5" /* test number or empty string if no patch */
/* /*
* calc version constants * calc version constants