mirror of
https://github.com/lcn2/calc.git
synced 2025-08-19 01:13:27 +03:00
Release calc version 2.11.0t8.5
This commit is contained in:
5
BUGS
5
BUGS
@@ -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
58
CHANGES
@@ -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:
|
||||||
|
|
||||||
|
8
addop.c
8
addop.c
@@ -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
20
block.c
@@ -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;
|
||||||
|
22
config.h
22
config.h
@@ -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
9
func.c
@@ -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
3
help.c
@@ -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 */
|
||||||
|
118
help/config
118
help/config
@@ -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:
|
||||||
|
|
||||||
|
32
help/hash
32
help/hash
@@ -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
|
||||||
|
@@ -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.
|
||||||
|
@@ -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
|
|
||||||
|
9
input.c
9
input.c
@@ -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");
|
||||||
|
42
lib/README
42
lib/README
@@ -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";
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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;
|
||||||
|
@@ -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;
|
||||||
|
@@ -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";
|
||||||
|
@@ -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]]])"
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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()';
|
||||||
|
|
||||||
|
@@ -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";
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
|
@@ -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
2
md5.c
@@ -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 */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -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--);
|
||||||
|
33
quickhash.c
33
quickhash.c
@@ -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
39
seed.c
@@ -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
2
shs.c
@@ -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
2
shs1.c
@@ -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 */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -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
|
||||||
|
Reference in New Issue
Block a user