mirror of
https://github.com/lcn2/calc.git
synced 2025-08-19 01:13:27 +03:00
Compare commits
10 Commits
2.11.0t8.9
...
2.11.0t9.4
Author | SHA1 | Date | |
---|---|---|---|
|
7d0b761de3 | ||
|
82ff31f246 | ||
|
7cb0a77c25 | ||
|
afb0e5c32a | ||
|
df32e3956d | ||
|
75e742c716 | ||
|
1b42111665 | ||
|
ea6b3904be | ||
|
f3fceff1b6 | ||
|
69d4a17187 |
242
BUGS
242
BUGS
@@ -24,7 +24,7 @@ To be sure that your version of calc is up to date, check out:
|
|||||||
|
|
||||||
The calc web site is located at:
|
The calc web site is located at:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/index.html
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
@@ -68,178 +68,6 @@ importantly, fixes (in the form of a context diff patch) to:
|
|||||||
|
|
||||||
Known bugs:
|
Known bugs:
|
||||||
|
|
||||||
* When compiled on some Big Endian machines with BASEB forced to
|
|
||||||
be 16 (by setting LONGLONG_BITS= 0 in the Makefile), calc fails
|
|
||||||
a number of regression tests:
|
|
||||||
|
|
||||||
4230: n = ftell(f)
|
|
||||||
4231: isnull(fputs(f,L,"\n",C,"\n",N,"\n"))
|
|
||||||
4232: fseek(f, n)
|
|
||||||
**** Non-true result (0): 4233: fgetstr(f) == LCN
|
|
||||||
4234: isnull(fclose(f))
|
|
||||||
4235: a = exp(27, 1e-1000)
|
|
||||||
4236: b = sqrt(7 + 5i, 1e-2000)
|
|
||||||
4252: fscanf(f, "%*[^|]%*c%n%*[^[]%*c%n", m, n) == 2
|
|
||||||
4253: fseek(f, m)
|
|
||||||
4254: fscanf(f, "%3c", x) == 1
|
|
||||||
**** Non-true result (0): 4255: x == " Cu"
|
|
||||||
4256: fseek(f, n)
|
|
||||||
4257: fscanf(f, "%s", y) == 1
|
|
||||||
**** Non-true result (0): 4258: y == "Noll"
|
|
||||||
4259: isnull(fclose(f))
|
|
||||||
4260: x = rm("junk4200")
|
|
||||||
4261: Ending test_fileops
|
|
||||||
4600: Beginning test_fileop
|
|
||||||
4601: ttest(0,0): passed
|
|
||||||
4602: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4603: ttest(1,1): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4604: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4605: ttest(2,2): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4606: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4607: ttest(3,3): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4608: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4609: ttest(4,4): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4610: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4611: ttest(5,5): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4612: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4613: ttest(6,6): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4614: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4615: ttest(7,7): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4616: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4617: ttest(8,8): failed
|
|
||||||
**** Failure 2 for i = 0
|
|
||||||
4618: stest(): failed
|
|
||||||
**** search(f, "and") != 10 failed
|
|
||||||
4619: ttest(9,9): failed
|
|
||||||
**** Failure 1 for file size
|
|
||||||
4620: stest(): failed
|
|
||||||
**** fopen("junk4600", "w") failed
|
|
||||||
4621: Ending test_fileop
|
|
||||||
|
|
||||||
4700: Beginning test_charset
|
|
||||||
**** errcount:172 > ecnt:150
|
|
||||||
4701: "\a" == char(7)
|
|
||||||
4702: "\v" == char(11)
|
|
||||||
4703: "\e" == char(27)
|
|
||||||
5000: Beginning test_filesearch
|
|
||||||
5001: x = rm("-f", "junk5000")
|
|
||||||
5002: f = fopen("junk5000", "w")
|
|
||||||
**** Unable to open "junk5000" for writing
|
|
||||||
|
|
||||||
5100: Beginning test_newdecl
|
|
||||||
5101: test5100(1)
|
|
||||||
**** errcount:173 > ecnt:172
|
|
||||||
5102: a5100 == 0
|
|
||||||
5103: b5100 == 2
|
|
||||||
5104: test5100(1)
|
|
||||||
5927: test unused
|
|
||||||
5928: test unused
|
|
||||||
5929: test unused
|
|
||||||
**** errcount:180 > ecnt:177
|
|
||||||
5930: isassoc(loc) == 0
|
|
||||||
5931: isassoc(a) == 1
|
|
||||||
5932: isassoc(ofd) == 0
|
|
||||||
6079: test unused
|
|
||||||
6080: iserror(loc) == 0
|
|
||||||
6081: iserror(a) == 0
|
|
||||||
**** Non-true result (0): 6082: iserror(ofd) == 0
|
|
||||||
**** Non-true result (0): 6083: iserror(cfd) == 0
|
|
||||||
6084: iserror(blk) == 0
|
|
||||||
6085: iserror(nblk) == 0
|
|
||||||
6086: iserror(cfg) == 0
|
|
||||||
6139: test unused
|
|
||||||
6140: isfile(loc) == 0
|
|
||||||
6141: isfile(a) == 0
|
|
||||||
**** Non-true result (0): 6142: isfile(ofd) == 1
|
|
||||||
**** Non-true result (0): 6143: isfile(cfd) == 1
|
|
||||||
6144: isfile(blk) == 0
|
|
||||||
6145: isfile(nblk) == 0
|
|
||||||
6146: isfile(cfg) == 0
|
|
||||||
|
|
||||||
6700: Beginning test_blk
|
|
||||||
6701: A = blk(20);
|
|
||||||
**** errcount:181 > ecnt:180
|
|
||||||
6702: size(A) == 20
|
|
||||||
6703: sizeof(A) == 256
|
|
||||||
6704: B = A;
|
|
||||||
6822: C == A
|
|
||||||
6823: fs = fopen("junk6800", "w+");
|
|
||||||
6824: blkcpy(fs, A);
|
|
||||||
**** errcount:183 > ecnt:181
|
|
||||||
**** Non-true result (0): 6825: size(f) == 5
|
|
||||||
6826: blkcpy(B = blk(), fs);
|
|
||||||
**** errcount:184 > ecnt:183
|
|
||||||
**** Non-true result (0): 6827: B == A
|
|
||||||
6828: blkcpy(fs, A, ,100);
|
|
||||||
**** errcount:185 > ecnt:184
|
|
||||||
**** Non-true result (0): 6829: size(f) == 105
|
|
||||||
6830: blkcpy(C = blk(), fs, 2, ,100)
|
|
||||||
**** errcount:186 > ecnt:185
|
|
||||||
**** Non-true result (0): 6831: C == (blk() = {1,2}
|
|
||||||
6832: A = blk();
|
|
||||||
6833: blkcpy(A, "blk6800");
|
|
||||||
6834: size(A) == 9
|
|
||||||
6900: Beginning test_name
|
|
||||||
6901: x = rm("-f", "junk6900")
|
|
||||||
6902: f = fopen("junk6900", "w")
|
|
||||||
**** errcount:189 > ecnt:186
|
|
||||||
**** Non-true result (0): 6903: name(f) == "junk6900"
|
|
||||||
6904: fclose(f)
|
|
||||||
**** errcount:190 > ecnt:189
|
|
||||||
6905: name(f) == null()
|
|
||||||
6906: A = blk("blk6900")
|
|
||||||
6907: name(A) == "blk6900"
|
|
||||||
7002: B = blk();
|
|
||||||
7003: copy("abc yz", A);
|
|
||||||
7004: copy("defg", B);
|
|
||||||
**** errcount:191 > ecnt:190
|
|
||||||
7005: strprintf("%s", A) == "abc yz"
|
|
||||||
7006: strprintf("%s", A[2]) == "c yz"
|
|
||||||
7007: strprintf("%s", A[7]) == ""
|
|
||||||
|
|
||||||
9995: freeredc()
|
|
||||||
9996: freestatics()
|
|
||||||
**** 24 error(s) found \/++\/
|
|
||||||
|
|
||||||
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:
|
||||||
@@ -253,3 +81,71 @@ 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.
|
||||||
|
|
||||||
|
* Use of 'fmt' in the 2nd arg of printf() calls in c_sysinfo.c
|
||||||
|
cause some compilers to issue warnings.
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
Other items of note:
|
||||||
|
|
||||||
|
* There is a bug in gcc-2.95 that causes calc, when compiled with -O2,
|
||||||
|
to fail the regression test. The work-a-round is to compile with -O
|
||||||
|
or to use gcc-2.96 or later.
|
||||||
|
|
||||||
|
* There is a bug in some versions of the Dec/Compaq cc for the Alpha
|
||||||
|
where the following:
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#define SVAL(a,b) (unsigned long)(0x ## a ## b ## ULL)
|
||||||
|
main(){SVAL(b8a8aeb0,8168eadc);}
|
||||||
|
|
||||||
|
fails because it puts a space inside the concatenated hex. Calc
|
||||||
|
has code that is affected by this bug. This bug has been reported
|
||||||
|
to Compaq and may be fixed in the future. A work-a-round is to
|
||||||
|
compile with cc -std0 or to use a later version of their compiler.
|
||||||
|
|
||||||
|
* On a Digital UNIX V4.0F (Rev. 1229) on a 500 Mhz 21264, make check
|
||||||
|
dies a horrible death starting in test 600 and 622 gives 100s of
|
||||||
|
messages for calc version 2.11.0t9.4 using the Dec's cc with -O2:
|
||||||
|
|
||||||
|
600: Beginning test_bignums
|
||||||
|
601: muldivcheck 1
|
||||||
|
**** abc != acb: 602: muldivcheck 2
|
||||||
|
**** acb != bac: 602: muldivcheck 2
|
||||||
|
...
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
|
**** t5 != a5: 622: algcheck 1
|
||||||
|
**** t6 != a6: 622: algcheck 1
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
|
...
|
||||||
|
|
||||||
|
it finally hangs at test 2000.
|
||||||
|
|
||||||
|
The work-a-round is to compile calc without the optimizer. If this
|
||||||
|
happens to you, try compiling without -O and without -O2. I.e., in
|
||||||
|
the Makefile, set:
|
||||||
|
|
||||||
|
DEBUG= -g
|
||||||
|
|
||||||
|
or set:
|
||||||
|
|
||||||
|
DEBUG=
|
||||||
|
245
CHANGES
245
CHANGES
@@ -1,4 +1,231 @@
|
|||||||
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.
|
||||||
|
|
||||||
|
Declarations are permitted to end with EOF as well as a newline or ';'.
|
||||||
|
|
||||||
|
When prompt() occurs while reading a file, it will take input from
|
||||||
|
the terminal rather than taking it from a file. For example:
|
||||||
|
|
||||||
|
/* 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 input terminal level may be spread over several
|
||||||
|
lines. For example:
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Assume that this calc script is called: comment.cal
|
||||||
|
* Then these commands now work:
|
||||||
|
* cat comment.cal | calc
|
||||||
|
* calc < comment.cal
|
||||||
|
*/
|
||||||
|
print "Hello";
|
||||||
|
|
||||||
|
Added:
|
||||||
|
|
||||||
|
-D calc_debug[:lib_debug:[user_debug]]
|
||||||
|
|
||||||
|
to set the initial value of config("calc_debug"), config("lib_debug")
|
||||||
|
and config("user_debug").
|
||||||
|
|
||||||
|
The : separated strings of -D are interpreted as signed 32 bit values.
|
||||||
|
After an optional leading sign a leading zero indicates octal
|
||||||
|
conversion, and a leading ``0x'' or ``0X'' hexadecimal conversion.
|
||||||
|
Otherwise, decimal conversion is assumed.
|
||||||
|
|
||||||
|
Reordered the config structure moving calc_debug ahead of lib_debug.
|
||||||
|
|
||||||
|
Added bits 4 and 5 to config("calc_debug"):
|
||||||
|
|
||||||
|
4 Report on changes to the state of stdin as well as changes
|
||||||
|
to internal variables that control the setting and restoring
|
||||||
|
of stdin.
|
||||||
|
|
||||||
|
5 Report on changes to the run state of calc.
|
||||||
|
|
||||||
|
Fixed portability issue in seed.c relating to /dev/urandom and ustat.
|
||||||
|
|
||||||
|
Added a fix from Martin Buck <mb@netwings.ch> to detect when
|
||||||
|
calc aborts early instead of completing the regression test.
|
||||||
|
Now 'make chk' will require the last line of calc output to
|
||||||
|
end in the string ``Ending regression tests''.
|
||||||
|
|
||||||
|
Added a patch from Martin Buck <mb@netwings.ch> to allow use of
|
||||||
|
GNU-readline. Note that GNU-readline is not shipped with calc.
|
||||||
|
His patch only provides the hooks to use it. One must comment out:
|
||||||
|
|
||||||
|
USE_READLINE=
|
||||||
|
READLINE_LIB=
|
||||||
|
READLINE_INCLUDE=
|
||||||
|
|
||||||
|
and comment in:
|
||||||
|
|
||||||
|
USE_READLINE= -DUSE_READLINE
|
||||||
|
READLINE_LIB= -lreadline -lhistory
|
||||||
|
READLINE_INCLUDE= -I/usr/include/readline
|
||||||
|
|
||||||
|
in addition to pre-installing GNU-readline in your system to use
|
||||||
|
this facility.
|
||||||
|
|
||||||
|
Changed the "object already defined" math_error to a scanerror message.
|
||||||
|
|
||||||
|
Removed the limit on the number of object types.
|
||||||
|
|
||||||
|
Calc tarballs are now named calc-version.tar.gz and untar into
|
||||||
|
a sub-directory called calc-version.
|
||||||
|
|
||||||
|
Made a small change to declarations of static variables to reduce
|
||||||
|
the internal opcodes needed to declare them.
|
||||||
|
|
||||||
|
Fixed a permission problem on ranlib-ed *.a files that was reported
|
||||||
|
by Michael Somos <somos@grail.cba.csuohio.edu>.
|
||||||
|
|
||||||
|
Added patch by Klaus Alexander Seistrup <klaus@seistrup.dk> related
|
||||||
|
to GNU-readline:
|
||||||
|
|
||||||
|
+ enable calc specific bindings in ~/.inputrc
|
||||||
|
+ save a copy of your session to disk and reload them next
|
||||||
|
time you're using calc
|
||||||
|
+ only add a line to the history if it is different from
|
||||||
|
the previous line
|
||||||
|
|
||||||
|
Added the Makefile symbol HAVE_GETRUSAGE to determine if the
|
||||||
|
system supports the getrusage() system call.
|
||||||
|
|
||||||
|
Fixed the make depend code in the custom and sample Makefiles.
|
||||||
|
|
||||||
|
Fixed how the help/builtin file is formed. The help/Makefile is
|
||||||
|
now given the name of the native C compiler by the top level Makefile.
|
||||||
|
|
||||||
|
The include files are installed under INCDIRCALC (a new Makefile variable)
|
||||||
|
which by default is ${INCDIR}/calc. The INCDIR (also a new Makefile var)
|
||||||
|
by default is /usr/local/include. Include files previously installed
|
||||||
|
directly under ${LIBDIR} will be removed.
|
||||||
|
|
||||||
|
Added the piforever() funcion to lib/pi.cal. It was written by
|
||||||
|
Klaus Alexander Seistrup <klaus@seistrup.dk> and was inspired by
|
||||||
|
an algorithm conceived by Lambert Meertens. (See also the ABC
|
||||||
|
Programmer's Handbook, by Geurts, Meertens & Pemberton, published
|
||||||
|
by Prentice-Hall (UK) Ltd., 1990.) The piforever() funcion prints
|
||||||
|
digits of pi for as long as your memory and system uptime allows. :-)
|
||||||
|
|
||||||
|
Fixed the URLs found thruout the source and documentation which did
|
||||||
|
not and in /, but should for performance and server load reasons.
|
||||||
|
|
||||||
|
Cleaned up and improved handling of "mat" and "obj". The comma in:
|
||||||
|
|
||||||
|
mat A[2], B[3];
|
||||||
|
|
||||||
|
is changed to whatever is appropriate in the context:
|
||||||
|
|
||||||
|
+ comma operator
|
||||||
|
+ separator of arguments in a function call
|
||||||
|
+ separator of arguments in a defintion
|
||||||
|
etc.
|
||||||
|
|
||||||
|
The expression (mat A[2]), B[3] returns B[3], assuming B already
|
||||||
|
exists as something created by a statement like: global mat B[4].
|
||||||
|
|
||||||
|
What used to be done by the expression:
|
||||||
|
|
||||||
|
mat A[2], B[3]
|
||||||
|
|
||||||
|
will now require something like:
|
||||||
|
|
||||||
|
mat A[2], mat B[3] or A = mat[2], B = mat[3]
|
||||||
|
|
||||||
|
For example, if obj point and obj pair are known types, the
|
||||||
|
following is now allowed:
|
||||||
|
|
||||||
|
L = list(mat[2], mat[3], obj point, obj pair)
|
||||||
|
|
||||||
|
As another example, the following is allowed:
|
||||||
|
|
||||||
|
define f(a = mat[2] = {3,4}) = 5 * a;
|
||||||
|
|
||||||
|
as well as the following:
|
||||||
|
|
||||||
|
obj point {x,y}, PP = obj pair {A,B} = {obj point, obj point}
|
||||||
|
|
||||||
|
which creates two object types at compile time and when executed,
|
||||||
|
assigns a pair-object value to a variable PP.
|
||||||
|
|
||||||
|
Fixed a bug whereby a for loop would behave incorrectly. For example:
|
||||||
|
|
||||||
|
config("trace", 2),
|
||||||
|
global x;
|
||||||
|
define f() {for ( ; x > 0; x--) {print x;}}
|
||||||
|
x = 5, f()
|
||||||
|
|
||||||
|
will stop after printing 1 instead of looping forever.
|
||||||
|
|
||||||
|
Added values l_format, which when CHECK_L_FORMAT is defined ahead
|
||||||
|
of including longlong.h will help detect when a system can deal with
|
||||||
|
'long long' but not '%lld' in printf. If a system with 'long long'
|
||||||
|
uses '%ld' to print a 64 bit value, then l_format will be > 0;
|
||||||
|
othewise if "%lld" is required, l_format will be < 0.
|
||||||
|
|
||||||
|
Added HAVE_STRDUP Makefile variable as well as the have_strdup.c
|
||||||
|
program that forms the have_strdup.h file. The have_strdup.h file
|
||||||
|
will define HAVE_STRDUP is the system has strdup(). If HAVE_STRDUP
|
||||||
|
is not defined, then calc will use calc_strdup() to simulate
|
||||||
|
the real strdup() function.
|
||||||
|
|
||||||
|
Calc no longer makes use of sys_errlist and sys_nerr. Some systems
|
||||||
|
no longer suppor these values (even though they should from a
|
||||||
|
legacy prospective). Calc now relies on the fact that strerror()
|
||||||
|
will return NULL of no such system error exists. System errors >=
|
||||||
|
10000 will be considered calc errors instead. The Makefile symbol
|
||||||
|
ERRNO_DECL has gone away as well as calc_errno.c and calc_errno.h.
|
||||||
|
|
||||||
|
On system errors are are not known to to the libc strerror() function,
|
||||||
|
strerror() will now print something such as:
|
||||||
|
|
||||||
|
Unknown error 9999
|
||||||
|
|
||||||
|
|
||||||
|
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
|
||||||
@@ -151,20 +378,6 @@ Following is the change from calc version 2.11.0t8 to date:
|
|||||||
Fixed a bug, reported by Michael Somos <somos@grail.cba.csuohio.edu>,
|
Fixed a bug, reported by Michael Somos <somos@grail.cba.csuohio.edu>,
|
||||||
which prevented calc -m from being used.
|
which prevented calc -m from being used.
|
||||||
|
|
||||||
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 misc compiler warnings.
|
Fixed misc compiler warnings.
|
||||||
|
|
||||||
|
|
||||||
@@ -311,7 +524,7 @@ Following is the change from calc version 2.11.0t7 to 2.11.0t7.5:
|
|||||||
|
|
||||||
The main calc URL is now:
|
The main calc URL is now:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
|
||||||
Misc calc man page fixes.
|
Misc calc man page fixes.
|
||||||
|
|
||||||
|
464
Makefile
464
Makefile
@@ -261,6 +261,30 @@ HAVE_GETPRID=
|
|||||||
HAVE_URANDOM=
|
HAVE_URANDOM=
|
||||||
#HAVE_URANDOM= -DHAVE_NO_URANDOM
|
#HAVE_URANDOM= -DHAVE_NO_URANDOM
|
||||||
|
|
||||||
|
# Determine if we have getrusage()
|
||||||
|
#
|
||||||
|
# If HAVE_GETRUSAGE is empty, this makefile will run the have_memmv program
|
||||||
|
# to determine if getrusage() is supported. If HAVE_GETRUSAGE is set to
|
||||||
|
# -DHAVE_NO_GETRUSAGE, then calc will use internal functions to simulate
|
||||||
|
# the memory move function that does correct overlapping memory modes.
|
||||||
|
#
|
||||||
|
# If in doubt, leave HAVE_GETRUSAGE empty and this Makefile will figure it out.
|
||||||
|
#
|
||||||
|
HAVE_GETRUSAGE=
|
||||||
|
#HAVE_GETRUSAGE= -DHAVE_NO_GETRUSAGE
|
||||||
|
|
||||||
|
# Determine if we have strdup()
|
||||||
|
#
|
||||||
|
# If HAVE_STRDUP is empty, this makefile will run the have_memmv program
|
||||||
|
# to determine if strdup() is supported. If HAVE_STRDUP is set to
|
||||||
|
# -DHAVE_NO_STRDUP, then calc will use internal functions to simulate
|
||||||
|
# the memory move function that does correct overlapping memory modes.
|
||||||
|
#
|
||||||
|
# If in doubt, leave HAVE_STRDUP empty and this Makefile will figure it out.
|
||||||
|
#
|
||||||
|
HAVE_STRDUP=
|
||||||
|
#HAVE_STRDUP= -DHAVE_NO_STRDUP
|
||||||
|
|
||||||
# Some architectures such as Sparc do not allow one to access 32 bit values
|
# Some architectures such as Sparc do not allow one to access 32 bit values
|
||||||
# that are not alligned on a 32 bit boundary.
|
# that are not alligned on a 32 bit boundary.
|
||||||
#
|
#
|
||||||
@@ -278,39 +302,6 @@ HAVE_URANDOM=
|
|||||||
ALIGN32= -DMUST_ALIGN32
|
ALIGN32= -DMUST_ALIGN32
|
||||||
#ALIGN32= -UMUST_ALIGN32
|
#ALIGN32= -UMUST_ALIGN32
|
||||||
|
|
||||||
# On most machines: errno sys_errlist and sys_nerr are declared
|
|
||||||
# by either <stdio.h> and/or <errno.h>. But some systems declare
|
|
||||||
# them somewhere else or do not declare them at all!
|
|
||||||
#
|
|
||||||
# If the system were doing a proper job in headers, this should declare them:
|
|
||||||
#
|
|
||||||
# #include <stdio.h>
|
|
||||||
# #include <errno.h>
|
|
||||||
#
|
|
||||||
# But one some systems one must explicitly declare them as:
|
|
||||||
#
|
|
||||||
# extern int errno;
|
|
||||||
# extern const char *const sys_errlist[];
|
|
||||||
# extern int sys_nerr;
|
|
||||||
#
|
|
||||||
# and on some old systems they must be explicitly and incorrectly declared as:
|
|
||||||
#
|
|
||||||
# extern int errno;
|
|
||||||
# extern char *sys_errlist[];
|
|
||||||
# extern int sys_nerr;
|
|
||||||
#
|
|
||||||
# ERRNO_DECL= let calc_errno.c determine how to declare them
|
|
||||||
# ERRNO_DECL= -DERRNO_NO_DECL headers declare them correctly
|
|
||||||
# ERRNO_DECL= -DERRNO_STD_DECL one must explicitly declare then
|
|
||||||
# ERRNO_DECL= -DERRNO_OLD_DECL one must explicitly & incorrectly declare them
|
|
||||||
#
|
|
||||||
# When in doubt, be safe leave ERRNO_DECL empty.
|
|
||||||
#
|
|
||||||
ERRNO_DECL=
|
|
||||||
#ERRNO_DECL= -DERRNO_NO_DECL
|
|
||||||
#ERRNO_DECL= -DERRNO_STD_DECL
|
|
||||||
#ERRNO_DECL= -DERRNO_OLD_DECL
|
|
||||||
|
|
||||||
# where to install binary files
|
# where to install binary files
|
||||||
#
|
#
|
||||||
BINDIR= /usr/local/bin
|
BINDIR= /usr/local/bin
|
||||||
@@ -320,7 +311,9 @@ BINDIR= /usr/local/bin
|
|||||||
# where to install the *.cal, *.h and *.a files
|
# where to install the *.cal, *.h and *.a files
|
||||||
#
|
#
|
||||||
# ${TOPDIR} is the directory under which the calc directory will be placed.
|
# ${TOPDIR} is the directory under which the calc directory will be placed.
|
||||||
# ${LIBDIR} is where the *.cal, *.h, *.a, bindings and help dir are installed.
|
# ${LIBDIR} is where the *.cal, *.a, bindings and help dir are installed.
|
||||||
|
# ${INCDIR} is where the locally installed include files are found.
|
||||||
|
# ${INCDIRCALC} is where the calc include files are installed.
|
||||||
# ${HELPDIR} is where the help directory is installed.
|
# ${HELPDIR} is where the help directory is installed.
|
||||||
# ${CUSTOMLIBDIR} is where custom lib files are installed.
|
# ${CUSTOMLIBDIR} is where custom lib files are installed.
|
||||||
# ${CUSTOMHELPDIR} is where custom help files are installed.
|
# ${CUSTOMHELPDIR} is where custom help files are installed.
|
||||||
@@ -332,6 +325,8 @@ TOPDIR= /usr/local/lib
|
|||||||
#
|
#
|
||||||
LIBDIR= ${TOPDIR}/calc
|
LIBDIR= ${TOPDIR}/calc
|
||||||
HELPDIR= ${LIBDIR}/help
|
HELPDIR= ${LIBDIR}/help
|
||||||
|
INCDIR= /usr/local/include
|
||||||
|
INCDIRCALC= ${INCDIR}/calc
|
||||||
CUSTOMLIBDIR= ${LIBDIR}/custom
|
CUSTOMLIBDIR= ${LIBDIR}/custom
|
||||||
CUSTOMHELPDIR= ${HELPDIR}/custhelp
|
CUSTOMHELPDIR= ${HELPDIR}/custhelp
|
||||||
|
|
||||||
@@ -414,9 +409,41 @@ CALCRC= ${LIBDIR}/startup:~/.calcrc
|
|||||||
# ${LIBDIR}/bindings uses ^D for editing
|
# ${LIBDIR}/bindings uses ^D for editing
|
||||||
# ${LIBDIR}/altbind uses ^D for EOF
|
# ${LIBDIR}/altbind uses ^D for EOF
|
||||||
#
|
#
|
||||||
|
# NOTE: This facility is disabled if USE_READLINE is set to -DUSE_READLINE.
|
||||||
|
#
|
||||||
CALCBINDINGS= bindings
|
CALCBINDINGS= bindings
|
||||||
#CALCBINDINGS= altbind
|
#CALCBINDINGS= altbind
|
||||||
|
|
||||||
|
# Determine of the GNU-readline facility will be used instead of the
|
||||||
|
# built-in CALCBINDINGS above.
|
||||||
|
#
|
||||||
|
# USE_READLINE= Do not use GNU-readline, use CALCBINDINGS
|
||||||
|
# USE_READLINE= -DUSE_READLINE Use GNU-readline, do not use CALCBINDINGS
|
||||||
|
#
|
||||||
|
# NOTE: If you select the 'USE_READLINE= -DUSE_READLINE' mode, you must set:
|
||||||
|
#
|
||||||
|
# READLINE_LIB The flags needed to link in the readline
|
||||||
|
# and history libs
|
||||||
|
# READLINE_INCLUDE Where the readline include files reside
|
||||||
|
#
|
||||||
|
# NOTE: The GNU-readline code is not shipped with calc. You must have
|
||||||
|
# the appropriate headers and libs installed on your system in
|
||||||
|
# order to use it.
|
||||||
|
#
|
||||||
|
# If in doubt, set USE_READLINE, READLINE_LIB and READLINE_INCLUDE to nothing.
|
||||||
|
#
|
||||||
|
USE_READLINE=
|
||||||
|
#USE_READLINE= -DUSE_READLINE
|
||||||
|
#
|
||||||
|
READLINE_LIB=
|
||||||
|
#READLINE_LIB= -L/usr/gnu/lib -lreadline -lhistory
|
||||||
|
#READLINE_LIB= -lreadline -lhistory
|
||||||
|
#READLINE_LIB= -L/usr/local/lib -lreadline -lhistory
|
||||||
|
#
|
||||||
|
READLINE_INCLUDE=
|
||||||
|
#READLINE_INCLUDE= -I/usr/gnu/include
|
||||||
|
#READLINE_INCLUDE= -I/usr/local/include
|
||||||
|
|
||||||
# If $PAGER is not set, use this program to display a help file
|
# If $PAGER is not set, use this program to display a help file
|
||||||
#
|
#
|
||||||
CALCPAGER= more
|
CALCPAGER= more
|
||||||
@@ -714,7 +741,7 @@ CC= ${PURIFY} ${LCC}
|
|||||||
#
|
#
|
||||||
###
|
###
|
||||||
#
|
#
|
||||||
# RS6000 set
|
# AIX RS/6000 set
|
||||||
#
|
#
|
||||||
#CCWARN=
|
#CCWARN=
|
||||||
#CCOPT= ${DEBUG} ${NO_SHARED}
|
#CCOPT= ${DEBUG} ${NO_SHARED}
|
||||||
@@ -810,6 +837,7 @@ SORT= sort
|
|||||||
TEE= tee
|
TEE= tee
|
||||||
LINT= lint
|
LINT= lint
|
||||||
CTAGS= ctags
|
CTAGS= ctags
|
||||||
|
FMT= fmt
|
||||||
# assume the X11 makedepend tool for the depend rule
|
# assume the X11 makedepend tool for the depend rule
|
||||||
MAKEDEPEND= makedepend
|
MAKEDEPEND= makedepend
|
||||||
# echo command location
|
# echo command location
|
||||||
@@ -881,9 +909,10 @@ BUILD_H_SRC= align32.h args.h calcerr.h conf.h endian_calc.h \
|
|||||||
fposval.h have_const.h have_fpos.h have_malloc.h \
|
fposval.h have_const.h have_fpos.h have_malloc.h \
|
||||||
have_memmv.h have_newstr.h have_offscl.h have_posscl.h \
|
have_memmv.h have_newstr.h have_offscl.h have_posscl.h \
|
||||||
have_stdlib.h have_string.h have_times.h have_uid_t.h \
|
have_stdlib.h have_string.h have_times.h have_uid_t.h \
|
||||||
have_unistd.h longbits.h longlong.h terminal.h calc_errno.h \
|
have_unistd.h longbits.h longlong.h terminal.h \
|
||||||
have_ustat.h have_getsid.h have_getpgid.h \
|
have_ustat.h have_getsid.h have_getpgid.h \
|
||||||
have_gettime.h have_getprid.h have_urandom.h
|
have_gettime.h have_getprid.h have_urandom.h have_rusage.h \
|
||||||
|
have_strdup.h
|
||||||
|
|
||||||
# we build these .c files during the make
|
# we build these .c files during the make
|
||||||
#
|
#
|
||||||
@@ -895,9 +924,9 @@ BUILD_C_SRC= calcerr.c
|
|||||||
#
|
#
|
||||||
UTIL_C_SRC= align32.c endian.c longbits.c have_newstr.c have_uid_t.c \
|
UTIL_C_SRC= align32.c endian.c longbits.c have_newstr.c have_uid_t.c \
|
||||||
have_const.c have_stdvs.c have_varvs.c fposval.c have_fpos.c \
|
have_const.c have_stdvs.c have_varvs.c fposval.c have_fpos.c \
|
||||||
longlong.c have_offscl.c have_posscl.c have_memmv.c calc_errno.c \
|
longlong.c have_offscl.c have_posscl.c have_memmv.c \
|
||||||
have_ustat.c have_getsid.c have_getpgid.c \
|
have_ustat.c have_getsid.c have_getpgid.c \
|
||||||
have_gettime.c have_getprid.c
|
have_gettime.c have_getprid.c have_rusage.c have_strdup.c
|
||||||
|
|
||||||
# these awk and sed tools are used in the process of building BUILD_H_SRC
|
# these awk and sed tools are used in the process of building BUILD_H_SRC
|
||||||
# and BUILD_C_SRC
|
# and BUILD_C_SRC
|
||||||
@@ -911,22 +940,22 @@ UTIL_MISC_SRC= calcerr_h.sed calcerr_h.awk calcerr_c.sed calcerr_c.awk \
|
|||||||
#
|
#
|
||||||
UTIL_OBJS= endian.o longbits.o have_newstr.o have_uid_t.o \
|
UTIL_OBJS= endian.o longbits.o have_newstr.o have_uid_t.o \
|
||||||
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
have_const.o fposval.o have_fpos.o longlong.o try_strarg.o \
|
||||||
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o calc_errno.o \
|
have_stdvs.o have_varvs.o have_posscl.o have_memmv.o \
|
||||||
have_ustat.o have_getsid.o have_getpgid.o \
|
have_ustat.o have_getsid.o have_getpgid.o \
|
||||||
have_gettime.o have_getprid.o
|
have_gettime.o have_getprid.o ver_calc.o have_rusage.o have_strdup.o
|
||||||
|
|
||||||
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
# these temp files may be created (and removed) during the build of BUILD_C_SRC
|
||||||
#
|
#
|
||||||
UTIL_TMP= ll_tmp fpos_tmp fposv_tmp const_tmp uid_tmp newstr_tmp vs_tmp \
|
UTIL_TMP= ll_tmp fpos_tmp fposv_tmp const_tmp uid_tmp newstr_tmp vs_tmp \
|
||||||
calc_errno_tmp memmv_tmp offscl_tmp posscl_tmp newstr_tmp \
|
memmv_tmp offscl_tmp posscl_tmp newstr_tmp \
|
||||||
getsid_tmp gettime_tmp getprid_tmp
|
getsid_tmp gettime_tmp getprid_tmp rusage_tmp strdup_tmp
|
||||||
|
|
||||||
# these utility progs may be used in the process of building BUILD_H_SRC
|
# these utility progs may be used in the process of building BUILD_H_SRC
|
||||||
#
|
#
|
||||||
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
UTIL_PROGS= align32 fposval have_uid_t longlong have_const \
|
||||||
endian longbits have_newstr have_stdvs have_varvs calc_errno \
|
endian longbits have_newstr have_stdvs have_varvs \
|
||||||
have_ustat have_getsid have_getpgid \
|
have_ustat have_getsid have_getpgid \
|
||||||
have_gettime have_getprid
|
have_gettime have_getprid ver_calc have_strdup
|
||||||
|
|
||||||
# These files are required by the regress.cal regression test.
|
# These files are required by the regress.cal regression test.
|
||||||
#
|
#
|
||||||
@@ -984,7 +1013,7 @@ SAMPLE_PASSDOWN= Q="${Q}" \
|
|||||||
LCFLAGS="${LCFLAGS}" \
|
LCFLAGS="${LCFLAGS}" \
|
||||||
LDFLAGS="${LDFLAGS}" \
|
LDFLAGS="${LDFLAGS}" \
|
||||||
ILDFLAGS="${ILDFLAGS}" \
|
ILDFLAGS="${ILDFLAGS}" \
|
||||||
CALC_LIBS="../libcalc.a ../custom/libcustcalc.a" \
|
CALC_LIBS="../libcalc.a ../custom/libcustcalc.a ${READLINE_LIB}" \
|
||||||
LCC="${LCC}" \
|
LCC="${LCC}" \
|
||||||
CC="${CC}" \
|
CC="${CC}" \
|
||||||
MAKE_FILE=${MAKE_FILE} \
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
@@ -992,6 +1021,31 @@ SAMPLE_PASSDOWN= Q="${Q}" \
|
|||||||
MAKEDEPEND=${MAKEDEPEND} \
|
MAKEDEPEND=${MAKEDEPEND} \
|
||||||
SORT=${SORT}
|
SORT=${SORT}
|
||||||
|
|
||||||
|
# The compelte list of makefile vars passed down to help/Makefile.
|
||||||
|
#
|
||||||
|
HELP_PASSDOWN= Q="${Q}" \
|
||||||
|
TOPDIR="${TOPDIR}" \
|
||||||
|
LIBDIR="${LIBDIR}" \
|
||||||
|
HELPDIR="${HELPDIR}" \
|
||||||
|
CFLAGS="${CFLAGS} ${ALLOW_CUSTOM}" \
|
||||||
|
ICFLAGS="${ICFLAGS}" \
|
||||||
|
ILDFLAGS="${ILDFLAGS}" \
|
||||||
|
LCC="${LCC}" \
|
||||||
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
|
SED=${SED} \
|
||||||
|
FMT=${FMT}
|
||||||
|
|
||||||
|
# The compelte list of makefile vars passed down to lib/Makefile.
|
||||||
|
#
|
||||||
|
LIB_PASSDOWN= Q="${Q}" \
|
||||||
|
TOPDIR="${TOPDIR}" \
|
||||||
|
LIBDIR="${LIBDIR}" \
|
||||||
|
HELPDIR="${HELPDIR}" \
|
||||||
|
MAKE_FILE=${MAKE_FILE} \
|
||||||
|
SED=${SED} \
|
||||||
|
MAKEDEPEND=${MAKEDEPEND} \
|
||||||
|
SORT=${SORT}
|
||||||
|
|
||||||
# complete list of .h files found (but not built) in the distribution
|
# complete list of .h files found (but not built) in the distribution
|
||||||
#
|
#
|
||||||
H_SRC= ${LIB_H_SRC}
|
H_SRC= ${LIB_H_SRC}
|
||||||
@@ -1032,12 +1086,13 @@ TARGETS= ${CALC_LIBS} custom/.all calc sample/sample \
|
|||||||
all: .hsrc ${TARGETS}
|
all: .hsrc ${TARGETS}
|
||||||
|
|
||||||
calc: .hsrc ${CALC_LIBS} ${CALCOBJS}
|
calc: .hsrc ${CALC_LIBS} ${CALCOBJS}
|
||||||
${CC} ${LDFLAGS} ${CALCOBJS} ${CALC_LIBS} ${LD_DEBUG} -o calc
|
${CC} ${LDFLAGS} ${CALCOBJS} ${CALC_LIBS} ${LD_DEBUG} ${READLINE_LIB} -o calc
|
||||||
|
|
||||||
libcalc.a: ${LIBOBJS} ${MAKE_FILE}
|
libcalc.a: ${LIBOBJS} ${MAKE_FILE}
|
||||||
-rm -f libcalc.a
|
-rm -f libcalc.a
|
||||||
ar qc libcalc.a ${LIBOBJS}
|
ar qc libcalc.a ${LIBOBJS}
|
||||||
${RANLIB} libcalc.a
|
${RANLIB} libcalc.a
|
||||||
|
chmod 0644 libcalc.a
|
||||||
|
|
||||||
calc.1: calc.man ${MAKE_FILE}
|
calc.1: calc.man ${MAKE_FILE}
|
||||||
-rm -f calc.1
|
-rm -f calc.1
|
||||||
@@ -1053,13 +1108,14 @@ calc.1: calc.man ${MAKE_FILE}
|
|||||||
##
|
##
|
||||||
|
|
||||||
calc.o: calc.c ${MAKE_FILE}
|
calc.o: calc.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${CCOPT} ${ALLOW_CUSTOM} -c calc.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c calc.c
|
||||||
|
|
||||||
custom.o: custom.c ${MAKE_FILE}
|
custom.o: custom.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c custom.c
|
||||||
|
|
||||||
hist.o: hist.c ${MAKE_FILE}
|
hist.o: hist.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${TERMCONTROL} -c hist.c
|
${CC} ${CFLAGS} ${TERMCONTROL} ${USE_READLINE} ${READLINE_INCLUDE} \
|
||||||
|
-c hist.c
|
||||||
|
|
||||||
func.o: func.c ${MAKE_FILE}
|
func.o: func.c ${MAKE_FILE}
|
||||||
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
${CC} ${CFLAGS} ${ALLOW_CUSTOM} -c func.c
|
||||||
@@ -1460,6 +1516,8 @@ longlong.h: longlong.c have_stdlib.h have_string.h ${MAKE_FILE}
|
|||||||
else \
|
else \
|
||||||
echo '#undef HAVE_LONGLONG' >> longlong.h; \
|
echo '#undef HAVE_LONGLONG' >> longlong.h; \
|
||||||
echo '#define LONGLONG_BITS 0 /* no */' >> longlong.h; \
|
echo '#define LONGLONG_BITS 0 /* no */' >> longlong.h; \
|
||||||
|
echo '#undef LL_FORMAT' >> longlong.h; \
|
||||||
|
echo '#undef L_FORMAT' >> longlong.h; \
|
||||||
fi
|
fi
|
||||||
${Q}echo '' >> longlong.h
|
${Q}echo '' >> longlong.h
|
||||||
${Q}echo '' >> longlong.h
|
${Q}echo '' >> longlong.h
|
||||||
@@ -2060,6 +2118,84 @@ have_urandom.h: ${MAKE_FILE}
|
|||||||
true; \
|
true; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
have_rusage.h: have_rusage.c ${MAKE_FILE}
|
||||||
|
-${Q}rm -f have_rusage have_rusage.o rusage_tmp have_rusage.h
|
||||||
|
${Q}echo 'forming have_rusage.h'
|
||||||
|
${Q}echo '/*' > have_rusage.h
|
||||||
|
${Q}echo ' * DO NOT EDIT -- generated by the Makefile' >> have_rusage.h
|
||||||
|
${Q}echo ' */' >> have_rusage.h
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '#if !defined(__HAVE_RUSAGE_H__)' >> have_rusage.h
|
||||||
|
${Q}echo '#define __HAVE_RUSAGE_H__' >> have_rusage.h
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '/* do we have or want getrusage()? */' >> have_rusage.h
|
||||||
|
-${Q}rm -f have_rusage.o have_rusage
|
||||||
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_GETRUSAGE} have_rusage.c -c 2>/dev/null; \
|
||||||
|
true
|
||||||
|
-${Q}${LCC} ${ILDFLAGS} have_rusage.o -o have_rusage 2>/dev/null; true
|
||||||
|
-${Q}${SHELL} -c "./have_rusage > rusage_tmp 2>/dev/null" \
|
||||||
|
>/dev/null 2>&1; true
|
||||||
|
-${Q}if [ -s rusage_tmp ]; then \
|
||||||
|
cat rusage_tmp >> have_rusage.h; \
|
||||||
|
else \
|
||||||
|
echo '#undef HAVE_GETRUSAGE /* no */' >> have_rusage.h; \
|
||||||
|
fi
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '' >> have_rusage.h
|
||||||
|
${Q}echo '#endif /* !__HAVE_RUSAGE_H__ */' >> have_rusage.h
|
||||||
|
-${Q}rm -f have_rusage have_rusage.o rusage_tmp
|
||||||
|
${Q}echo 'have_rusage.h formed'
|
||||||
|
-@if [ -z "${Q}" ]; then \
|
||||||
|
echo ''; \
|
||||||
|
echo '=-=-= start of $@ =-=-='; \
|
||||||
|
cat $@; \
|
||||||
|
echo '=-=-= end of $@ =-=-='; \
|
||||||
|
echo ''; \
|
||||||
|
else \
|
||||||
|
true; \
|
||||||
|
fi
|
||||||
|
|
||||||
|
have_strdup.h: have_strdup.c ${MAKE_FILE}
|
||||||
|
-${Q}rm -f have_strdup have_strdup.o strdup_tmp have_strdup.h
|
||||||
|
${Q}echo 'forming have_strdup.h'
|
||||||
|
${Q}echo '/*' > have_strdup.h
|
||||||
|
${Q}echo ' * DO NOT EDIT -- generated by the Makefile' >> have_strdup.h
|
||||||
|
${Q}echo ' */' >> have_strdup.h
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '#if !defined(__HAVE_RUSAGE_H__)' >> have_strdup.h
|
||||||
|
${Q}echo '#define __HAVE_RUSAGE_H__' >> have_strdup.h
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '/* do we have or want getstrdup()? */' >> have_strdup.h
|
||||||
|
-${Q}rm -f have_strdup.o have_strdup
|
||||||
|
-${Q}${LCC} ${ICFLAGS} ${HAVE_STRDUP} have_strdup.c -c 2>/dev/null; \
|
||||||
|
true
|
||||||
|
-${Q}${LCC} ${ILDFLAGS} have_strdup.o -o have_strdup 2>/dev/null; true
|
||||||
|
-${Q}${SHELL} -c "./have_strdup > strdup_tmp 2>/dev/null" \
|
||||||
|
>/dev/null 2>&1; true
|
||||||
|
-${Q}if [ -s strdup_tmp ]; then \
|
||||||
|
cat strdup_tmp >> have_strdup.h; \
|
||||||
|
else \
|
||||||
|
echo '#undef HAVE_STRDUP /* no */' >> have_strdup.h; \
|
||||||
|
fi
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '' >> have_strdup.h
|
||||||
|
${Q}echo '#endif /* !__HAVE_RUSAGE_H__ */' >> have_strdup.h
|
||||||
|
-${Q}rm -f have_strdup have_strdup.o strdup_tmp
|
||||||
|
${Q}echo 'have_strdup.h formed'
|
||||||
|
-@if [ -z "${Q}" ]; then \
|
||||||
|
echo ''; \
|
||||||
|
echo '=-=-= start of $@ =-=-='; \
|
||||||
|
cat $@; \
|
||||||
|
echo '=-=-= end of $@ =-=-='; \
|
||||||
|
echo ''; \
|
||||||
|
else \
|
||||||
|
true; \
|
||||||
|
fi
|
||||||
|
|
||||||
args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
||||||
-${Q}rm -f args.h have_args
|
-${Q}rm -f args.h have_args
|
||||||
${Q}echo 'forming args.h'
|
${Q}echo 'forming args.h'
|
||||||
@@ -2119,98 +2255,6 @@ args.h: have_stdvs.c have_varvs.c have_string.h have_unistd.h have_string.h
|
|||||||
true; \
|
true; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
calc_errno.h: calc_errno.c ${MAKE_FILE}
|
|
||||||
-${Q}rm -f calc_errno.h calc_errno calc_errno_tmp
|
|
||||||
${Q}echo 'forming calc_errno.h'
|
|
||||||
${Q}echo '/*' > calc_errno.h
|
|
||||||
${Q}echo ' * DO NOT EDIT -- generated by the Makefile' >> calc_errno.h
|
|
||||||
${Q}echo ' */' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '#if !defined(__CALC_ERRNO_H__)' >> calc_errno.h
|
|
||||||
${Q}echo '#define __CALC_ERRNO_H__' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
-${Q}if [ X"${ERRNO_DECL}" = X"-DERRNO_NO_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo '#include <stdio.h>' >> calc_errno.h; \
|
|
||||||
echo '#include <errno.h>' >> calc_errno.h; \
|
|
||||||
elif [ X"${ERRNO_DECL}" = X"-DERRNO_STD_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern const char *const sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
elif [ X"${ERRNO_DECL}" = X"-DERRNO_OLD_DECL" ]; then \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * The calc Makefile explicitly told us' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern char *sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_NO_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_STD_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
${LCC} ${ICFLAGS} -DTRY_ERRNO_OLD_DECL \
|
|
||||||
calc_errno.c -o calc_errno 2>calc_errno_tmp; \
|
|
||||||
if [ -x ./calc_errno ]; then \
|
|
||||||
./calc_errno >> calc_errno.h; \
|
|
||||||
else \
|
|
||||||
echo '/*' >> calc_errno.h; \
|
|
||||||
echo ' * We were unable to to determine' >> calc_errno.h; \
|
|
||||||
echo ' * how to declare errno and friends.' >> calc_errno.h; \
|
|
||||||
echo ' * So we will guess this will work' >> calc_errno.h; \
|
|
||||||
echo ' * and hope for the best.' >> calc_errno.h; \
|
|
||||||
echo ' */' >> calc_errno.h; \
|
|
||||||
echo '' >> calc_errno.h; \
|
|
||||||
echo 'extern int errno; ' \
|
|
||||||
'/* last system error */' >> calc_errno.h; \
|
|
||||||
echo 'extern const char *const sys_errlist[];' \
|
|
||||||
' /* system error messages*/' >> calc_errno.h; \
|
|
||||||
echo 'extern int sys_nerr; ' \
|
|
||||||
'/* number of system errors */' >> calc_errno.h; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
fi; \
|
|
||||||
fi
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '' >> calc_errno.h
|
|
||||||
${Q}echo '#endif /* !__CALC_ERRNO_H__ */' >> calc_errno.h
|
|
||||||
-${Q}rm -f calc_errno calc_errno_tmp
|
|
||||||
${Q}echo 'calc_errno.h formed'
|
|
||||||
-@if [ -z "${Q}" ]; then \
|
|
||||||
echo ''; \
|
|
||||||
echo '=-=-= start of $@ =-=-='; \
|
|
||||||
cat $@; \
|
|
||||||
echo '=-=-= end of $@ =-=-='; \
|
|
||||||
echo ''; \
|
|
||||||
else \
|
|
||||||
true; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
calcerr.h: calcerr.tbl calcerr_h.sed calcerr_h.awk ${MAKE_FILE}
|
calcerr.h: calcerr.tbl calcerr_h.sed calcerr_h.awk ${MAKE_FILE}
|
||||||
-${Q}rm -f calerr.h
|
-${Q}rm -f calerr.h
|
||||||
${Q}echo 'forming calcerr.h'
|
${Q}echo 'forming calcerr.h'
|
||||||
@@ -2291,27 +2335,21 @@ longbits: longbits.o
|
|||||||
lib/.all:
|
lib/.all:
|
||||||
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking all rule for lib =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking all rule for lib =-=-=-=-='
|
||||||
cd lib; ${MAKE} -f Makefile \
|
cd lib; ${MAKE} -f Makefile ${LIB_PASSDOWN} all
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} all
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
help/.all:
|
help/.all:
|
||||||
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking all rule for help =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking all rule for help =-=-=-=-='
|
||||||
cd help; ${MAKE} -f Makefile \
|
cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} all
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} all
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
help/builtin: func.c help/builtin.top help/builtin.end help/funclist.sed
|
help/builtin: func.c help/builtin.top help/builtin.end help/funclist.sed
|
||||||
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= start of $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking builtin rule for help =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking builtin rule for help =-=-=-=-='
|
||||||
cd help; ${MAKE} -f Makefile \
|
cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} builtin
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} builtin
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
@@ -2411,9 +2449,7 @@ bsdi: ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
echo chmod 0444 gen_h/$$i; \
|
echo chmod 0444 gen_h/$$i; \
|
||||||
chmod 0444 gen_h/$$i; \
|
chmod 0444 gen_h/$$i; \
|
||||||
done
|
done
|
||||||
cd help; ${MAKE} -f Makefile \
|
cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} bsdi
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} bsdi
|
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
##
|
##
|
||||||
@@ -2505,6 +2541,12 @@ h_list:
|
|||||||
echo $$i; \
|
echo $$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
|
# print the calc version
|
||||||
|
#
|
||||||
|
ver_calc: version.c
|
||||||
|
-rm -f $@
|
||||||
|
${LCC} ${ICFLAGS} -DCALC_VER ${ILDFLAGS} version.c -o $@
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# File distribution list generation. You can ignore this section.
|
# File distribution list generation. You can ignore this section.
|
||||||
@@ -2516,34 +2558,19 @@ h_list:
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}(for i in ${DISTLIST}; do \
|
${Q}(for i in ${DISTLIST}; do \
|
||||||
echo calc/$$i; \
|
echo $$i; \
|
||||||
done; \
|
done; \
|
||||||
(cd help; ${MAKE} distlist \
|
(cd help; ${MAKE} ${HELP_PASSDOWN} distlist); \
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
(cd lib; ${MAKE} ${LIB_PASSDOWN} distlist); \
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
|
||||||
(cd lib; ${MAKE} distlist \
|
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}) ) | ${SORT}; \
|
|
||||||
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distlist); \
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distlist); \
|
||||||
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distlist) | ${SORT}
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distlist)) | ${SORT}
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
# The the .h files are placed under calc/gen_h.
|
${Q}(echo .; \
|
||||||
#
|
(cd help; ${MAKE} ${HELP_PASSDOWN} distdir); \
|
||||||
bsdilist: ${DISTLIST} ${BUILD_H_SRC} calc.1
|
(cd lib; ${MAKE} ${LIB_PASSDOWN} distdir); \
|
||||||
${Q}(for i in ${DISTLIST}; do \
|
(cd custom; ${MAKE} ${CUSTOM_PASSDOWN} distdir); \
|
||||||
echo calc/$$i; \
|
(cd sample; ${MAKE} ${SAMPLE_PASSDOWN} distdir)) | ${SORT}
|
||||||
done; \
|
|
||||||
for i in ${BUILD_H_SRC}; do \
|
|
||||||
echo calc/gen_h/$$i; \
|
|
||||||
done; \
|
|
||||||
echo calc/calc.1; \
|
|
||||||
(cd help; ${MAKE} bsdilist \
|
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}); \
|
|
||||||
(cd lib; ${MAKE} bsdilist \
|
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} SORT=${SORT}) ) | ${SORT}
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -2603,7 +2630,6 @@ env:
|
|||||||
@echo "HAVE_GETPRID=${HAVE_GETPRID}"; echo ""
|
@echo "HAVE_GETPRID=${HAVE_GETPRID}"; echo ""
|
||||||
@echo "HAVE_URANDOM=${HAVE_URANDOM}"; echo ""
|
@echo "HAVE_URANDOM=${HAVE_URANDOM}"; echo ""
|
||||||
@echo "ALIGN32=${ALIGN32}"; echo ""
|
@echo "ALIGN32=${ALIGN32}"; echo ""
|
||||||
@echo "ERRNO_DECL=${ERRNO_DECL}"; echo ""
|
|
||||||
@echo "BINDIR=${BINDIR}"; echo ""
|
@echo "BINDIR=${BINDIR}"; echo ""
|
||||||
@echo "TOPDIR=${TOPDIR}"; echo ""
|
@echo "TOPDIR=${TOPDIR}"; echo ""
|
||||||
@echo "LIBDIR=${LIBDIR}"; echo ""
|
@echo "LIBDIR=${LIBDIR}"; echo ""
|
||||||
@@ -2668,6 +2694,8 @@ env:
|
|||||||
@echo "REGRESS_CAL=${REGRESS_CAL}"; echo ""
|
@echo "REGRESS_CAL=${REGRESS_CAL}"; echo ""
|
||||||
@echo "CUSTOM_PASSDOWN=${CUSTOM_PASSDOWN}"; echo ""
|
@echo "CUSTOM_PASSDOWN=${CUSTOM_PASSDOWN}"; echo ""
|
||||||
@echo "SAMPLE_PASSDOWN=${SAMPLE_PASSDOWN}"; echo ""
|
@echo "SAMPLE_PASSDOWN=${SAMPLE_PASSDOWN}"; echo ""
|
||||||
|
@echo "HELP_PASSDOWN=${HELP_PASSDOWN}"; echo ""
|
||||||
|
@echo "LIB_PASSDOWN=${LIB_PASSDOWN}"; echo ""
|
||||||
@echo "H_SRC=${H_SRC}"; echo ""
|
@echo "H_SRC=${H_SRC}"; echo ""
|
||||||
@echo "C_SRC=${C_SRC}"; echo ""
|
@echo "C_SRC=${C_SRC}"; echo ""
|
||||||
@echo "DISTLIST=${DISTLIST}"; echo ""
|
@echo "DISTLIST=${DISTLIST}"; echo ""
|
||||||
@@ -2765,14 +2793,10 @@ clean:
|
|||||||
-rm -f ${UTIL_PROGS}
|
-rm -f ${UTIL_PROGS}
|
||||||
-rm -f .libcustcalc_error
|
-rm -f .libcustcalc_error
|
||||||
${Q}echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
${Q}echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
||||||
-cd help; ${MAKE} -f Makefile \
|
-cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} clean
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} clean
|
|
||||||
${Q}echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${Q}echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${Q}echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
${Q}echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
||||||
-cd lib; ${MAKE} -f Makefile \
|
-cd lib; ${MAKE} -f Makefile ${LIB_PASSDOWN} clean
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} clean
|
|
||||||
${Q}echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${Q}echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
||||||
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} clean
|
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} clean
|
||||||
@@ -2780,7 +2804,6 @@ clean:
|
|||||||
${V} echo '=-=-=-=-= Invoking $@ rule for sample =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for sample =-=-=-=-='
|
||||||
cd sample; ${MAKE} -f Makefile ${SAMPLE_PASSDOWN} clean
|
cd sample; ${MAKE} -f Makefile ${SAMPLE_PASSDOWN} clean
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
-rm -f funclist.o funclist.c
|
|
||||||
${Q}echo remove files that are obsolete
|
${Q}echo remove files that are obsolete
|
||||||
-rm -f endian.h stdarg.h libcalcerr.a lib/obj help/obj
|
-rm -f endian.h stdarg.h libcalcerr.a lib/obj help/obj
|
||||||
-rm -f have_vs.c std_arg.h try_stdarg.c fnvhash.c
|
-rm -f have_vs.c std_arg.h try_stdarg.c fnvhash.c
|
||||||
@@ -2803,14 +2826,10 @@ clobber: lintclean
|
|||||||
-rm -f calc.pixie calc.rf calc.Counts calc.cord
|
-rm -f calc.pixie calc.rf calc.Counts calc.cord
|
||||||
-rm -rf gen_h skel Makefile.bak
|
-rm -rf gen_h skel Makefile.bak
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
||||||
-cd help;${MAKE} -f Makefile \
|
-cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} clobber
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} clobber
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
||||||
-cd lib; ${MAKE} -f Makefile \
|
-cd lib; ${MAKE} -f Makefile ${LIB_PASSDOWN} clobber
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} clobber
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
||||||
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} clobber
|
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} clobber
|
||||||
@@ -2846,6 +2865,20 @@ install: calc libcalc.a ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
true; \
|
true; \
|
||||||
fi
|
fi
|
||||||
-chmod 0755 ${HELPDIR}
|
-chmod 0755 ${HELPDIR}
|
||||||
|
-${Q}if [ ! -d ${INCDIR} ]; then \
|
||||||
|
echo mkdir ${INCDIR}; \
|
||||||
|
mkdir ${INCDIR}; \
|
||||||
|
else \
|
||||||
|
true; \
|
||||||
|
fi
|
||||||
|
-chmod 0755 ${INCDIR}
|
||||||
|
-${Q}if [ ! -d ${INCDIRCALC} ]; then \
|
||||||
|
echo mkdir ${INCDIRCALC}; \
|
||||||
|
mkdir ${INCDIRCALC}; \
|
||||||
|
else \
|
||||||
|
true; \
|
||||||
|
fi
|
||||||
|
-chmod 0755 ${INCDIRCALC}
|
||||||
-${Q}if [ ! -d ${BINDIR} ]; then \
|
-${Q}if [ ! -d ${BINDIR} ]; then \
|
||||||
echo mkdir ${BINDIR}; \
|
echo mkdir ${BINDIR}; \
|
||||||
mkdir ${BINDIR}; \
|
mkdir ${BINDIR}; \
|
||||||
@@ -2857,14 +2890,10 @@ install: calc libcalc.a ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
cp calc ${BINDIR}
|
cp calc ${BINDIR}
|
||||||
-chmod 0555 ${BINDIR}/calc
|
-chmod 0555 ${BINDIR}/calc
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for help =-=-=-=-='
|
||||||
cd help; ${MAKE} -f Makefile \
|
cd help; ${MAKE} -f Makefile ${HELP_PASSDOWN} install
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} install
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for lib =-=-=-=-='
|
||||||
cd lib; ${MAKE} -f Makefile \
|
cd lib; ${MAKE} -f Makefile ${LIB_PASSDOWN} install
|
||||||
MAKE_FILE=${MAKE_FILE} TOPDIR=${TOPDIR} LIBDIR=${LIBDIR} \
|
|
||||||
HELPDIR=${HELPDIR} install
|
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
${V} echo '=-=-=-=-= Invoking $@ rule for custom =-=-=-=-='
|
||||||
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} install
|
cd custom; ${MAKE} -f Makefile ${CUSTOM_PASSDOWN} install
|
||||||
@@ -2873,16 +2902,18 @@ install: calc libcalc.a ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
cd sample; ${MAKE} -f Makefile ${SAMPLE_PASSDOWN} install
|
cd sample; ${MAKE} -f Makefile ${SAMPLE_PASSDOWN} install
|
||||||
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= Back to the main Makefile for $@ rule =-=-=-=-='
|
||||||
-rm -f ${LIBDIR}/libcalc.a
|
-rm -f ${LIBDIR}/libcalc.a
|
||||||
cp libcalc.a ${LIBDIR}/libcalc.a
|
cp -f libcalc.a ${LIBDIR}/libcalc.a
|
||||||
-chmod 0644 ${LIBDIR}/libcalc.a
|
|
||||||
${RANLIB} ${LIBDIR}/libcalc.a
|
${RANLIB} ${LIBDIR}/libcalc.a
|
||||||
|
-chmod 0644 ${LIBDIR}/libcalc.a
|
||||||
-${Q}for i in ${LIB_H_SRC} ${BUILD_H_SRC}; do \
|
-${Q}for i in ${LIB_H_SRC} ${BUILD_H_SRC}; do \
|
||||||
echo rm -f ${LIBDIR}/$$i; \
|
echo rm -f ${LIBDIR}/$$i; \
|
||||||
rm -f ${LIBDIR}/$$i; \
|
rm -f ${LIBDIR}/$$i; \
|
||||||
echo cp $$i ${LIBDIR}; \
|
echo rm -f ${INCDIRCALC}/$$i; \
|
||||||
cp $$i ${LIBDIR}; \
|
rm -f ${INCDIRCALC}/$$i; \
|
||||||
echo chmod 0444 ${LIBDIR}/$$i; \
|
echo cp $$i ${INCDIRCALC}; \
|
||||||
chmod 0444 ${LIBDIR}/$$i; \
|
cp $$i ${INCDIRCALC}; \
|
||||||
|
echo chmod 0444 ${INCDIRCALC}/$$i; \
|
||||||
|
chmod 0444 ${INCDIRCALC}/$$i; \
|
||||||
done
|
done
|
||||||
${Q}: If lint was made, install the lint library.
|
${Q}: If lint was made, install the lint library.
|
||||||
-${Q}if [ -f llib-lcalc.ln ]; then \
|
-${Q}if [ -f llib-lcalc.ln ]; then \
|
||||||
@@ -2925,6 +2956,8 @@ install: calc libcalc.a ${LIB_H_SRC} ${BUILD_H_SRC} calc.1
|
|||||||
-rm -f ${LIBDIR}/stdarg.h stdarg.h
|
-rm -f ${LIBDIR}/stdarg.h stdarg.h
|
||||||
-rm -f ${LIBDIR}/prototype.h prototype.h
|
-rm -f ${LIBDIR}/prototype.h prototype.h
|
||||||
-rm -f ${LIBDIR}/libcalcerr.a libcalcerr.a
|
-rm -f ${LIBDIR}/libcalcerr.a libcalcerr.a
|
||||||
|
-rm -f ${LIBDIR}/calc_errno.h calc_errno.h ${INCDIRCALC}/calc_errno.h
|
||||||
|
-rm -f calc_errno.c calc_errno.o calc_errno
|
||||||
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
${V} echo '=-=-=-=-= end of $@ rule =-=-=-=-='
|
||||||
|
|
||||||
##
|
##
|
||||||
@@ -2946,6 +2979,7 @@ addop.o: config.h
|
|||||||
addop.o: endian_calc.h
|
addop.o: endian_calc.h
|
||||||
addop.o: func.h
|
addop.o: func.h
|
||||||
addop.o: hash.h
|
addop.o: hash.h
|
||||||
|
addop.o: have_const.h
|
||||||
addop.o: have_malloc.h
|
addop.o: have_malloc.h
|
||||||
addop.o: have_memmv.h
|
addop.o: have_memmv.h
|
||||||
addop.o: have_newstr.h
|
addop.o: have_newstr.h
|
||||||
@@ -3002,6 +3036,7 @@ blkcpy.o: config.h
|
|||||||
blkcpy.o: endian_calc.h
|
blkcpy.o: endian_calc.h
|
||||||
blkcpy.o: file.h
|
blkcpy.o: file.h
|
||||||
blkcpy.o: hash.h
|
blkcpy.o: hash.h
|
||||||
|
blkcpy.o: have_const.h
|
||||||
blkcpy.o: have_fpos.h
|
blkcpy.o: have_fpos.h
|
||||||
blkcpy.o: have_malloc.h
|
blkcpy.o: have_malloc.h
|
||||||
blkcpy.o: have_memmv.h
|
blkcpy.o: have_memmv.h
|
||||||
@@ -3090,7 +3125,6 @@ calc.o: symbol.h
|
|||||||
calc.o: token.h
|
calc.o: token.h
|
||||||
calc.o: value.h
|
calc.o: value.h
|
||||||
calc.o: zmath.h
|
calc.o: zmath.h
|
||||||
calc_errno.o: calc_errno.c
|
|
||||||
calcerr.o: calcerr.c
|
calcerr.o: calcerr.c
|
||||||
calcerr.o: calcerr.h
|
calcerr.o: calcerr.h
|
||||||
calcerr.o: have_const.h
|
calcerr.o: have_const.h
|
||||||
@@ -3106,6 +3140,7 @@ codegen.o: config.h
|
|||||||
codegen.o: endian_calc.h
|
codegen.o: endian_calc.h
|
||||||
codegen.o: func.h
|
codegen.o: func.h
|
||||||
codegen.o: hash.h
|
codegen.o: hash.h
|
||||||
|
codegen.o: have_const.h
|
||||||
codegen.o: have_malloc.h
|
codegen.o: have_malloc.h
|
||||||
codegen.o: have_memmv.h
|
codegen.o: have_memmv.h
|
||||||
codegen.o: have_newstr.h
|
codegen.o: have_newstr.h
|
||||||
@@ -3190,6 +3225,7 @@ const.o: config.h
|
|||||||
const.o: const.c
|
const.o: const.c
|
||||||
const.o: endian_calc.h
|
const.o: endian_calc.h
|
||||||
const.o: hash.h
|
const.o: hash.h
|
||||||
|
const.o: have_const.h
|
||||||
const.o: have_malloc.h
|
const.o: have_malloc.h
|
||||||
const.o: have_memmv.h
|
const.o: have_memmv.h
|
||||||
const.o: have_newstr.h
|
const.o: have_newstr.h
|
||||||
@@ -3244,6 +3280,7 @@ file.o: file.c
|
|||||||
file.o: file.h
|
file.o: file.h
|
||||||
file.o: fposval.h
|
file.o: fposval.h
|
||||||
file.o: hash.h
|
file.o: hash.h
|
||||||
|
file.o: have_const.h
|
||||||
file.o: have_fpos.h
|
file.o: have_fpos.h
|
||||||
file.o: have_malloc.h
|
file.o: have_malloc.h
|
||||||
file.o: have_memmv.h
|
file.o: have_memmv.h
|
||||||
@@ -3268,7 +3305,6 @@ func.o: alloc.h
|
|||||||
func.o: block.h
|
func.o: block.h
|
||||||
func.o: byteswap.h
|
func.o: byteswap.h
|
||||||
func.o: calc.h
|
func.o: calc.h
|
||||||
func.o: calc_errno.h
|
|
||||||
func.o: calcerr.h
|
func.o: calcerr.h
|
||||||
func.o: cmath.h
|
func.o: cmath.h
|
||||||
func.o: config.h
|
func.o: config.h
|
||||||
@@ -3341,9 +3377,11 @@ have_newstr.o: have_newstr.c
|
|||||||
have_offscl.o: have_offscl.c
|
have_offscl.o: have_offscl.c
|
||||||
have_posscl.o: have_fpos.h
|
have_posscl.o: have_fpos.h
|
||||||
have_posscl.o: have_posscl.c
|
have_posscl.o: have_posscl.c
|
||||||
|
have_rusage.o: have_rusage.c
|
||||||
have_stdvs.o: have_stdvs.c
|
have_stdvs.o: have_stdvs.c
|
||||||
have_stdvs.o: have_string.h
|
have_stdvs.o: have_string.h
|
||||||
have_stdvs.o: have_unistd.h
|
have_stdvs.o: have_unistd.h
|
||||||
|
have_strdup.o: have_strdup.c
|
||||||
have_uid_t.o: have_uid_t.c
|
have_uid_t.o: have_uid_t.c
|
||||||
have_uid_t.o: have_unistd.h
|
have_uid_t.o: have_unistd.h
|
||||||
have_ustat.o: have_ustat.c
|
have_ustat.o: have_ustat.c
|
||||||
@@ -3360,6 +3398,7 @@ help.o: conf.h
|
|||||||
help.o: config.h
|
help.o: config.h
|
||||||
help.o: endian_calc.h
|
help.o: endian_calc.h
|
||||||
help.o: hash.h
|
help.o: hash.h
|
||||||
|
help.o: have_const.h
|
||||||
help.o: have_malloc.h
|
help.o: have_malloc.h
|
||||||
help.o: have_memmv.h
|
help.o: have_memmv.h
|
||||||
help.o: have_newstr.h
|
help.o: have_newstr.h
|
||||||
@@ -3385,10 +3424,12 @@ hist.o: cmath.h
|
|||||||
hist.o: config.h
|
hist.o: config.h
|
||||||
hist.o: endian_calc.h
|
hist.o: endian_calc.h
|
||||||
hist.o: hash.h
|
hist.o: hash.h
|
||||||
|
hist.o: have_const.h
|
||||||
hist.o: have_malloc.h
|
hist.o: have_malloc.h
|
||||||
hist.o: have_memmv.h
|
hist.o: have_memmv.h
|
||||||
hist.o: have_newstr.h
|
hist.o: have_newstr.h
|
||||||
hist.o: have_stdlib.h
|
hist.o: have_stdlib.h
|
||||||
|
hist.o: have_strdup.h
|
||||||
hist.o: have_string.h
|
hist.o: have_string.h
|
||||||
hist.o: have_unistd.h
|
hist.o: have_unistd.h
|
||||||
hist.o: hist.c
|
hist.o: hist.c
|
||||||
@@ -3413,11 +3454,13 @@ input.o: conf.h
|
|||||||
input.o: config.h
|
input.o: config.h
|
||||||
input.o: endian_calc.h
|
input.o: endian_calc.h
|
||||||
input.o: hash.h
|
input.o: hash.h
|
||||||
|
input.o: have_const.h
|
||||||
input.o: have_malloc.h
|
input.o: have_malloc.h
|
||||||
input.o: have_memmv.h
|
input.o: have_memmv.h
|
||||||
input.o: have_newstr.h
|
input.o: have_newstr.h
|
||||||
input.o: have_stdlib.h
|
input.o: have_stdlib.h
|
||||||
input.o: have_string.h
|
input.o: have_string.h
|
||||||
|
input.o: have_unistd.h
|
||||||
input.o: hist.h
|
input.o: hist.h
|
||||||
input.o: input.c
|
input.o: input.c
|
||||||
input.o: longbits.h
|
input.o: longbits.h
|
||||||
@@ -3442,6 +3485,7 @@ label.o: config.h
|
|||||||
label.o: endian_calc.h
|
label.o: endian_calc.h
|
||||||
label.o: func.h
|
label.o: func.h
|
||||||
label.o: hash.h
|
label.o: hash.h
|
||||||
|
label.o: have_const.h
|
||||||
label.o: have_malloc.h
|
label.o: have_malloc.h
|
||||||
label.o: have_memmv.h
|
label.o: have_memmv.h
|
||||||
label.o: have_newstr.h
|
label.o: have_newstr.h
|
||||||
@@ -3476,6 +3520,7 @@ lib_calc.o: have_malloc.h
|
|||||||
lib_calc.o: have_memmv.h
|
lib_calc.o: have_memmv.h
|
||||||
lib_calc.o: have_newstr.h
|
lib_calc.o: have_newstr.h
|
||||||
lib_calc.o: have_stdlib.h
|
lib_calc.o: have_stdlib.h
|
||||||
|
lib_calc.o: have_strdup.h
|
||||||
lib_calc.o: have_string.h
|
lib_calc.o: have_string.h
|
||||||
lib_calc.o: have_unistd.h
|
lib_calc.o: have_unistd.h
|
||||||
lib_calc.o: label.h
|
lib_calc.o: label.h
|
||||||
@@ -3571,6 +3616,7 @@ math_error.o: cmath.h
|
|||||||
math_error.o: config.h
|
math_error.o: config.h
|
||||||
math_error.o: endian_calc.h
|
math_error.o: endian_calc.h
|
||||||
math_error.o: hash.h
|
math_error.o: hash.h
|
||||||
|
math_error.o: have_const.h
|
||||||
math_error.o: have_malloc.h
|
math_error.o: have_malloc.h
|
||||||
math_error.o: have_memmv.h
|
math_error.o: have_memmv.h
|
||||||
math_error.o: have_newstr.h
|
math_error.o: have_newstr.h
|
||||||
@@ -3621,6 +3667,7 @@ obj.o: config.h
|
|||||||
obj.o: endian_calc.h
|
obj.o: endian_calc.h
|
||||||
obj.o: func.h
|
obj.o: func.h
|
||||||
obj.o: hash.h
|
obj.o: hash.h
|
||||||
|
obj.o: have_const.h
|
||||||
obj.o: have_malloc.h
|
obj.o: have_malloc.h
|
||||||
obj.o: have_memmv.h
|
obj.o: have_memmv.h
|
||||||
obj.o: have_newstr.h
|
obj.o: have_newstr.h
|
||||||
@@ -3834,6 +3881,7 @@ seed.o: have_gettime.h
|
|||||||
seed.o: have_malloc.h
|
seed.o: have_malloc.h
|
||||||
seed.o: have_memmv.h
|
seed.o: have_memmv.h
|
||||||
seed.o: have_newstr.h
|
seed.o: have_newstr.h
|
||||||
|
seed.o: have_rusage.h
|
||||||
seed.o: have_stdlib.h
|
seed.o: have_stdlib.h
|
||||||
seed.o: have_string.h
|
seed.o: have_string.h
|
||||||
seed.o: have_urandom.h
|
seed.o: have_urandom.h
|
||||||
@@ -3925,6 +3973,7 @@ string.o: cmath.h
|
|||||||
string.o: config.h
|
string.o: config.h
|
||||||
string.o: endian_calc.h
|
string.o: endian_calc.h
|
||||||
string.o: hash.h
|
string.o: hash.h
|
||||||
|
string.o: have_const.h
|
||||||
string.o: have_malloc.h
|
string.o: have_malloc.h
|
||||||
string.o: have_memmv.h
|
string.o: have_memmv.h
|
||||||
string.o: have_newstr.h
|
string.o: have_newstr.h
|
||||||
@@ -3950,6 +3999,7 @@ symbol.o: config.h
|
|||||||
symbol.o: endian_calc.h
|
symbol.o: endian_calc.h
|
||||||
symbol.o: func.h
|
symbol.o: func.h
|
||||||
symbol.o: hash.h
|
symbol.o: hash.h
|
||||||
|
symbol.o: have_const.h
|
||||||
symbol.o: have_malloc.h
|
symbol.o: have_malloc.h
|
||||||
symbol.o: have_memmv.h
|
symbol.o: have_memmv.h
|
||||||
symbol.o: have_newstr.h
|
symbol.o: have_newstr.h
|
||||||
@@ -3979,6 +4029,7 @@ token.o: cmath.h
|
|||||||
token.o: config.h
|
token.o: config.h
|
||||||
token.o: endian_calc.h
|
token.o: endian_calc.h
|
||||||
token.o: hash.h
|
token.o: hash.h
|
||||||
|
token.o: have_const.h
|
||||||
token.o: have_malloc.h
|
token.o: have_malloc.h
|
||||||
token.o: have_memmv.h
|
token.o: have_memmv.h
|
||||||
token.o: have_newstr.h
|
token.o: have_newstr.h
|
||||||
@@ -4038,6 +4089,7 @@ version.o: cmath.h
|
|||||||
version.o: config.h
|
version.o: config.h
|
||||||
version.o: endian_calc.h
|
version.o: endian_calc.h
|
||||||
version.o: hash.h
|
version.o: hash.h
|
||||||
|
version.o: have_const.h
|
||||||
version.o: have_malloc.h
|
version.o: have_malloc.h
|
||||||
version.o: have_memmv.h
|
version.o: have_memmv.h
|
||||||
version.o: have_newstr.h
|
version.o: have_newstr.h
|
||||||
|
2
README
2
README
@@ -87,4 +87,4 @@ your full name.
|
|||||||
|
|
||||||
The calc web site is located at:
|
The calc web site is located at:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* This file was written by:
|
* This file was written by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
2
blkcpy.c
2
blkcpy.c
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
2
block.c
2
block.c
@@ -28,7 +28,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
2
block.h
2
block.h
@@ -28,7 +28,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
95
calc.c
95
calc.c
@@ -39,8 +39,6 @@
|
|||||||
/*
|
/*
|
||||||
* static definitions and functions
|
* static definitions and functions
|
||||||
*/
|
*/
|
||||||
static char *usage = "usage: %s [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]\n"
|
|
||||||
"\t[-n] [-p] [-q] [-u] [-v] [[--] calc_cmd ...]\n";
|
|
||||||
static void intint(int arg); /* interrupt routine */
|
static void intint(int arg); /* interrupt routine */
|
||||||
|
|
||||||
|
|
||||||
@@ -55,13 +53,14 @@ main(int argc, char **argv)
|
|||||||
extern char *optarg; /* option argument */
|
extern char *optarg; /* option argument */
|
||||||
extern int optind; /* option index */
|
extern int optind; /* option index */
|
||||||
int c; /* option */
|
int c; /* option */
|
||||||
|
char *p;
|
||||||
long i;
|
long i;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* parse args
|
* parse args
|
||||||
*/
|
*/
|
||||||
program = argv[0];
|
program = argv[0];
|
||||||
while ((c = getopt(argc, argv, "Cehim:npquvcd")) != -1) {
|
while ((c = getopt(argc, argv, "Cehim:npquvcdD:")) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'C':
|
case 'C':
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
@@ -126,12 +125,36 @@ main(int argc, char **argv)
|
|||||||
*/
|
*/
|
||||||
printf("%s (version %s)\n", CALC_TITLE, version());
|
printf("%s (version %s)\n", CALC_TITLE, version());
|
||||||
exit(0);
|
exit(0);
|
||||||
|
case 'D':
|
||||||
|
/*
|
||||||
|
* parse the -D optarg
|
||||||
|
*
|
||||||
|
* Could be calc_debug
|
||||||
|
* or calc_debug:lib_debug
|
||||||
|
* or calc_debug:lib_debug:user_debug
|
||||||
|
*/
|
||||||
|
calc_debug = optarg;
|
||||||
|
p = strchr(optarg, ':');
|
||||||
|
if (p != NULL) {
|
||||||
|
*p = '\0';
|
||||||
|
lib_debug = p+1;
|
||||||
|
p = strchr(lib_debug, ':');
|
||||||
|
if (p != NULL) {
|
||||||
|
*p = '\0';
|
||||||
|
user_debug = p+1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
/*
|
/*
|
||||||
* we are too early in processing to call
|
* we are too early in processing to call
|
||||||
* libcalc_call_me_last() - nothing to cleanup
|
* libcalc_call_me_last() - nothing to cleanup
|
||||||
*/
|
*/
|
||||||
fprintf(stderr, usage, program);
|
fprintf(stderr,
|
||||||
|
"usage: %s [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]\n"
|
||||||
|
"\t[-D calc_debug[:lib_debug:[user_debug]]]\n"
|
||||||
|
"\t[-n] [-p] [-q] [-u] [-v] [[--] calc_cmd ...]\n",
|
||||||
|
program);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -185,6 +208,8 @@ main(int argc, char **argv)
|
|||||||
*/
|
*/
|
||||||
libcalc_call_me_first();
|
libcalc_call_me_first();
|
||||||
stdin_tty = isatty(0); /* assume stdin is on fd 0 */
|
stdin_tty = isatty(0); /* assume stdin is on fd 0 */
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: stdin_tty is %d\n", stdin_tty);
|
||||||
if (want_defhelp) {
|
if (want_defhelp) {
|
||||||
givehelp(DEFAULTCALCHELP);
|
givehelp(DEFAULTCALCHELP);
|
||||||
libcalc_call_me_last();
|
libcalc_call_me_last();
|
||||||
@@ -239,9 +264,17 @@ main(int argc, char **argv)
|
|||||||
*/
|
*/
|
||||||
if (run_state == RUN_BEGIN) {
|
if (run_state == RUN_BEGIN) {
|
||||||
if (!q_flag && allow_read) {
|
if (!q_flag && allow_read) {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_RCFILES));
|
||||||
run_state = RUN_RCFILES;
|
run_state = RUN_RCFILES;
|
||||||
runrcfiles();
|
runrcfiles();
|
||||||
}
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_CMD_ARGS));
|
||||||
run_state = RUN_PRE_CMD_ARGS;
|
run_state = RUN_PRE_CMD_ARGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -252,25 +285,46 @@ main(int argc, char **argv)
|
|||||||
if (inputlevel() == 0) {
|
if (inputlevel() == 0) {
|
||||||
closeinput();
|
closeinput();
|
||||||
runrcfiles();
|
runrcfiles();
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_CMD_ARGS));
|
||||||
run_state = RUN_PRE_CMD_ARGS;
|
run_state = RUN_PRE_CMD_ARGS;
|
||||||
} else {
|
} else {
|
||||||
closeinput();
|
closeinput();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ((havecommands && !i_flag) || !stdin_tty)
|
if ((havecommands && !i_flag) || !stdin_tty) {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_EXIT_WITH_ERROR));
|
||||||
run_state = RUN_EXIT_WITH_ERROR;
|
run_state = RUN_EXIT_WITH_ERROR;
|
||||||
else
|
} else {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_CMD_ARGS));
|
||||||
run_state = RUN_PRE_CMD_ARGS;
|
run_state = RUN_PRE_CMD_ARGS;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (run_state == RUN_PRE_CMD_ARGS) {
|
if (run_state == RUN_PRE_CMD_ARGS) {
|
||||||
if (havecommands) {
|
if (havecommands) {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_CMD_ARGS));
|
||||||
run_state = RUN_CMD_ARGS;
|
run_state = RUN_CMD_ARGS;
|
||||||
(void) openstring(cmdbuf, (long) strlen(cmdbuf));
|
(void) openstring(cmdbuf, (long) strlen(cmdbuf));
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
closeinput();
|
closeinput();
|
||||||
}
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_TOP_LEVEL));
|
||||||
run_state = RUN_PRE_TOP_LEVEL;
|
run_state = RUN_PRE_TOP_LEVEL;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -279,19 +333,36 @@ main(int argc, char **argv)
|
|||||||
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
if (inputlevel() == 0)
|
if (inputlevel() == 0)
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_TOP_LEVEL));
|
||||||
run_state = RUN_PRE_TOP_LEVEL;
|
run_state = RUN_PRE_TOP_LEVEL;
|
||||||
closeinput();
|
closeinput();
|
||||||
} else {
|
} else {
|
||||||
closeinput();
|
closeinput();
|
||||||
if (!stdin_tty || !i_flag || p_flag)
|
if (!stdin_tty || !i_flag || p_flag) {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_EXIT_WITH_ERROR));
|
||||||
run_state = RUN_EXIT_WITH_ERROR;
|
run_state = RUN_EXIT_WITH_ERROR;
|
||||||
else
|
} else {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_PRE_TOP_LEVEL));
|
||||||
run_state = RUN_PRE_TOP_LEVEL;
|
run_state = RUN_PRE_TOP_LEVEL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (run_state == RUN_PRE_TOP_LEVEL) {
|
if (run_state == RUN_PRE_TOP_LEVEL) {
|
||||||
if (stdin_tty && ((havecommands && !i_flag) || p_flag)) {
|
if (stdin_tty && ((havecommands && !i_flag) || p_flag)) {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_EXIT));
|
||||||
run_state = RUN_EXIT;
|
run_state = RUN_EXIT;
|
||||||
} else {
|
} else {
|
||||||
if (stdin_tty) {
|
if (stdin_tty) {
|
||||||
@@ -300,6 +371,10 @@ main(int argc, char **argv)
|
|||||||
resetinput();
|
resetinput();
|
||||||
openterminal();
|
openterminal();
|
||||||
}
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_TOP_LEVEL));
|
||||||
run_state = RUN_TOP_LEVEL;
|
run_state = RUN_TOP_LEVEL;
|
||||||
getcommands(TRUE);
|
getcommands(TRUE);
|
||||||
}
|
}
|
||||||
@@ -315,6 +390,10 @@ main(int argc, char **argv)
|
|||||||
reinitialize();
|
reinitialize();
|
||||||
getcommands(TRUE);
|
getcommands(TRUE);
|
||||||
} else {
|
} else {
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE)
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_EXIT_WITH_ERROR));
|
||||||
run_state = RUN_EXIT_WITH_ERROR;
|
run_state = RUN_EXIT_WITH_ERROR;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
6
calc.h
6
calc.h
@@ -14,6 +14,8 @@
|
|||||||
|
|
||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
|
||||||
|
#include "have_const.h"
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Configuration definitions
|
* Configuration definitions
|
||||||
@@ -38,7 +40,6 @@
|
|||||||
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
||||||
#define MAXINDICES 20 /* maximum number of indices for objects */
|
#define MAXINDICES 20 /* maximum number of indices for objects */
|
||||||
#define MAXLABELS 100 /* maximum number of user labels in function */
|
#define MAXLABELS 100 /* maximum number of user labels in function */
|
||||||
#define MAXOBJECTS 128 /* maximum number of object types */
|
|
||||||
#define MAXSTRING 1024 /* maximum size of string constant */
|
#define MAXSTRING 1024 /* maximum size of string constant */
|
||||||
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
#define MAXSTACK 1000 /* maximum depth of evaluation stack */
|
||||||
#define MAXFILES 20 /* maximum number of opened files */
|
#define MAXFILES 20 /* maximum number of opened files */
|
||||||
@@ -123,6 +124,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);
|
||||||
@@ -140,6 +142,7 @@ extern void givehelp(char *type);
|
|||||||
extern void libcalc_call_me_first(void);
|
extern void libcalc_call_me_first(void);
|
||||||
extern void libcalc_call_me_last(void);
|
extern void libcalc_call_me_last(void);
|
||||||
extern void showerrors(void);
|
extern void showerrors(void);
|
||||||
|
extern char *calc_strdup(CONST char *);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialization
|
* Initialization
|
||||||
@@ -207,6 +210,7 @@ typedef enum {
|
|||||||
RUN_EXIT_WITH_ERROR = 7 /* exit with error */
|
RUN_EXIT_WITH_ERROR = 7 /* exit with error */
|
||||||
} run;
|
} run;
|
||||||
extern run run_state;
|
extern run run_state;
|
||||||
|
extern char *run_state_name(run state);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version information
|
* calc version information
|
||||||
|
50
calc.man
50
calc.man
@@ -15,17 +15,19 @@ calc \- arbitrary precision calculator
|
|||||||
.RB [ \-c ]
|
.RB [ \-c ]
|
||||||
.RB [ \-C ]
|
.RB [ \-C ]
|
||||||
.RB [ \-d ]
|
.RB [ \-d ]
|
||||||
|
.RB [ -D\ \&calc_debug[:lib_debug:[user_debug]] ]
|
||||||
|
.br
|
||||||
|
.in +5n
|
||||||
.RB [ \-e ]
|
.RB [ \-e ]
|
||||||
.RB [ \-h ]
|
.RB [ \-h ]
|
||||||
.RB [ \-i ]
|
.RB [ \-i ]
|
||||||
.RB [ \-m\ \&mode ]
|
.RB [ \-m\ \&mode ]
|
||||||
.br
|
|
||||||
.in +5n
|
|
||||||
.RB [ \-n ]
|
.RB [ \-n ]
|
||||||
.RB [ \-p ]
|
.RB [ \-p ]
|
||||||
.RB [ \-q ]
|
.RB [ \-q ]
|
||||||
.RB [ \-u ]
|
.RB [ \-u ]
|
||||||
.RB [ \-v ]
|
.RB [ \-v ]
|
||||||
|
.br
|
||||||
.RB [ calc_cmd\ \&.\|.\|. ]
|
.RB [ calc_cmd\ \&.\|.\|. ]
|
||||||
.in -5n
|
.in -5n
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
@@ -122,6 +124,34 @@ It's nearly ten past six.
|
|||||||
This flag disables the reporting of missing calc
|
This flag disables the reporting of missing calc
|
||||||
startup scripts ($CALCRC).
|
startup scripts ($CALCRC).
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.BR -D " calc_debug[:lib_debug:[user_debug]]"
|
||||||
|
Force the initial value of config("calc_debug"),
|
||||||
|
config("lib_debug") and config("user_debug").
|
||||||
|
.sp 1
|
||||||
|
The : separated strings are interpreted as signed 32 bit values.
|
||||||
|
After an optional leading sign a leading zero indicates octal
|
||||||
|
conversion, and a leading ``0x'' or ``0X'' hexadecimal
|
||||||
|
conversion. Otherwise, decimal conversion is assumed.
|
||||||
|
.sp 1
|
||||||
|
By default,
|
||||||
|
.I calc_debug
|
||||||
|
is 0,
|
||||||
|
.I lib_debug
|
||||||
|
is 3 and
|
||||||
|
.I lib_debug
|
||||||
|
is 0.
|
||||||
|
.sp 1
|
||||||
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
command:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
help config
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
.B \-e
|
.B \-e
|
||||||
Ignore any environment variables on startup.
|
Ignore any environment variables on startup.
|
||||||
@@ -182,7 +212,8 @@ This flag sets the permission mode of
|
|||||||
It controls the ability for
|
It controls the ability for
|
||||||
.B calc
|
.B calc
|
||||||
to open files and execute programs.
|
to open files and execute programs.
|
||||||
Mode may be a number from 0 to 7.
|
.I Mode
|
||||||
|
may be a number from 0 to 7.
|
||||||
.sp 1
|
.sp 1
|
||||||
The mode value is interpreted in a way similar to that
|
The mode value is interpreted in a way similar to that
|
||||||
of the
|
of the
|
||||||
@@ -205,8 +236,8 @@ octal mode:
|
|||||||
If one wished to run
|
If one wished to run
|
||||||
.B calc
|
.B calc
|
||||||
from a privileged user, one might want to use
|
from a privileged user, one might want to use
|
||||||
.B \-m
|
.BR \-m " 0"
|
||||||
0 in an effort to make
|
in an effort to make
|
||||||
.B calc
|
.B calc
|
||||||
somewhat more secure.
|
somewhat more secure.
|
||||||
.sp 1
|
.sp 1
|
||||||
@@ -214,8 +245,8 @@ Mode bits for reading and writing apply only on an
|
|||||||
open.
|
open.
|
||||||
Files already open are not effected.
|
Files already open are not effected.
|
||||||
Thus if one wanted to use the
|
Thus if one wanted to use the
|
||||||
.B \-m
|
.BR \-m " 0"
|
||||||
0 in an effort to make
|
in an effort to make
|
||||||
.B calc
|
.B calc
|
||||||
somewhat more secure, but still wanted to read and write a specific
|
somewhat more secure, but still wanted to read and write a specific
|
||||||
file, one might want to do in
|
file, one might want to do in
|
||||||
@@ -528,6 +559,9 @@ by this environment variable.
|
|||||||
.sp
|
.sp
|
||||||
Default value: ${CALCBINDINGS}
|
Default value: ${CALCBINDINGS}
|
||||||
.sp
|
.sp
|
||||||
|
This variable is not used if calc was compiled with GNU-readline support.
|
||||||
|
In that case, the standard readline mechanisms (see readline(3)) are used.
|
||||||
|
.sp
|
||||||
.SH CREDIT
|
.SH CREDIT
|
||||||
\&
|
\&
|
||||||
.br
|
.br
|
||||||
@@ -584,7 +618,7 @@ Landon Noll maintains the the
|
|||||||
web site is located at:
|
web site is located at:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
http://reality.sgi.com/chongo/tech/comp/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
One may join the
|
One may join the
|
||||||
|
123
calc_errno.c
123
calc_errno.c
@@ -1,123 +0,0 @@
|
|||||||
/*
|
|
||||||
* errno - Determine how to declare errno, sys_errlist and sys_nerr
|
|
||||||
*
|
|
||||||
* On most machines: errno sys_errlist and sys_nerr are declared
|
|
||||||
* by either <stdio.h> and/or <errno.h>. But some systems declare
|
|
||||||
* them somewhere else or do not declare them at all!
|
|
||||||
*
|
|
||||||
* If the system were doing a proper job in headers, this should declare them:
|
|
||||||
*
|
|
||||||
* #include <stdio.h>
|
|
||||||
* #include <errno.h>
|
|
||||||
*
|
|
||||||
* But one some systems one must explicitly declare them as:
|
|
||||||
*
|
|
||||||
* extern int errno;
|
|
||||||
* extern const char *const sys_errlist[];
|
|
||||||
* extern int sys_nerr;
|
|
||||||
*
|
|
||||||
* and on some old systems they must be explicitly and incorrectly declared as:
|
|
||||||
*
|
|
||||||
* extern int errno;
|
|
||||||
* extern char *sys_errlist[];
|
|
||||||
* extern int sys_nerr;
|
|
||||||
*
|
|
||||||
* The purpose of this utility is try and find the right way to declare
|
|
||||||
* them and to output the middle of a header file called calc_errno.h.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
|
||||||
*
|
|
||||||
* Permission to use, copy, modify, and distribute this software and
|
|
||||||
* its documentation for any purpose and without fee is hereby granted,
|
|
||||||
* provided that the above copyright, this permission notice and text
|
|
||||||
* this comment, and the disclaimer below appear in all of the following:
|
|
||||||
*
|
|
||||||
* supporting documentation
|
|
||||||
* source copies
|
|
||||||
* source works derived from this source
|
|
||||||
* binaries derived from this source or from derived source
|
|
||||||
*
|
|
||||||
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
|
||||||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO
|
|
||||||
* EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
|
||||||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
|
||||||
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
||||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
||||||
* PERFORMANCE OF THIS SOFTWARE.
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#if defined(TRY_ERRNO_NO_DECL)
|
|
||||||
# include <errno.h>
|
|
||||||
#endif /* TRY_ERRNO_NO_DECL */
|
|
||||||
|
|
||||||
int
|
|
||||||
main(void)
|
|
||||||
{
|
|
||||||
|
|
||||||
#if defined(TRY_ERRNO_NO_DECL)
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("#include <stdio.h>\n");
|
|
||||||
printf("#include <errno.h>\n");
|
|
||||||
#elif defined(TRY_ERRNO_OLD_DECL)
|
|
||||||
extern int errno; /* last system error */
|
|
||||||
extern char *sys_errlist[]; /* system error messages */
|
|
||||||
extern int sys_nerr; /* number of system errors*/
|
|
||||||
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("extern int errno;\t\t/* last system error */\n");
|
|
||||||
printf("extern char *sys_errlist[];\t"
|
|
||||||
"/* system error messages */\n");
|
|
||||||
printf("extern int sys_nerr;\t\t/* number of system errors*/\n");
|
|
||||||
#else /* assume defined(TRY_ERRNO_STD_DECL) */
|
|
||||||
extern int errno; /* last system error */
|
|
||||||
extern const char *const sys_errlist[]; /* system error messages */
|
|
||||||
extern int sys_nerr; /* number of system errors*/
|
|
||||||
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * The following comments were produced by calc_errno\n");
|
|
||||||
printf(" * in an effort to see if these values were correctly\n");
|
|
||||||
printf(" * declared when calc_errno.c was compiled.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("/* Initially errno is %d */\n", errno);
|
|
||||||
printf("/* There are %d entries in sys_errlist[] */\n", sys_nerr);
|
|
||||||
printf("/* The 2nd sys_errlist entry is \"%s\" */\n\n", sys_errlist[1]);
|
|
||||||
printf("/*\n");
|
|
||||||
printf(" * Based on the above, calc_errno now knows\n");
|
|
||||||
printf(" * how to declare errno and friends.\n");
|
|
||||||
printf(" */\n\n");
|
|
||||||
printf("extern int errno;\t\t\t/* last system error */\n");
|
|
||||||
printf("extern const char *const sys_errlist[];\t"
|
|
||||||
"/* system error messages */\n");
|
|
||||||
printf("extern int sys_nerr;\t\t\t/* number of system errors*/\n");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* exit(0); */
|
|
||||||
return 0;
|
|
||||||
}
|
|
@@ -11,6 +11,7 @@ BEGIN {
|
|||||||
havebuf2=0;
|
havebuf2=0;
|
||||||
buf2=0;
|
buf2=0;
|
||||||
error = 0;
|
error = 0;
|
||||||
|
end_seen = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
NF == 0 {
|
NF == 0 {
|
||||||
@@ -29,6 +30,10 @@ NF == 0 {
|
|||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/: Ending regression tests$/ {
|
||||||
|
end_seen = 1;
|
||||||
|
}
|
||||||
|
|
||||||
$1 ~ /^[0-9]+:/ {
|
$1 ~ /^[0-9]+:/ {
|
||||||
if (error > 0) {
|
if (error > 0) {
|
||||||
if (havebuf2) {
|
if (havebuf2) {
|
||||||
@@ -71,7 +76,7 @@ END {
|
|||||||
if (error > 0 && havebuf0) {
|
if (error > 0 && havebuf0) {
|
||||||
print buf0;
|
print buf0;
|
||||||
}
|
}
|
||||||
if (error > 0) {
|
if (error > 0 || !end_seen) {
|
||||||
exit(1);
|
exit(1);
|
||||||
} else {
|
} else {
|
||||||
exit(0);
|
exit(0);
|
||||||
|
103
codegen.c
103
codegen.c
@@ -32,8 +32,8 @@ static void getfunction(void);
|
|||||||
static void ungetfunction(void);
|
static void ungetfunction(void);
|
||||||
static void getbody(LABEL *contlabel, LABEL *breaklabel,
|
static void getbody(LABEL *contlabel, LABEL *breaklabel,
|
||||||
LABEL *nextcaselabel, LABEL *defaultlabel);
|
LABEL *nextcaselabel, LABEL *defaultlabel);
|
||||||
static void getdeclarations(int symtype);
|
static int getdeclarations(int symtype);
|
||||||
static void getsimpledeclaration (int symtype);
|
static int getsimpledeclaration (int symtype);
|
||||||
static int getonevariable (int symtype);
|
static int getonevariable (int symtype);
|
||||||
static void getstatement(LABEL *contlabel, LABEL *breaklabel,
|
static void getstatement(LABEL *contlabel, LABEL *breaklabel,
|
||||||
LABEL *nextcaselabel, LABEL *defaultlabel);
|
LABEL *nextcaselabel, LABEL *defaultlabel);
|
||||||
@@ -256,9 +256,15 @@ ungetfunction(void)
|
|||||||
case T_MULT:
|
case T_MULT:
|
||||||
rmalluserfunc();
|
rmalluserfunc();
|
||||||
continue;
|
continue;
|
||||||
default:
|
case T_NEWLINE:
|
||||||
|
case T_SEMICOLON:
|
||||||
|
case T_EOF:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
return;
|
return;
|
||||||
|
default:
|
||||||
|
scanerror(T_SEMICOLON,
|
||||||
|
"Non-name arg for undefine");
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -382,7 +388,7 @@ getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaul
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case T_EOF:
|
case T_EOF:
|
||||||
scanerror(T_SEMICOLON, "End-of-file in function body");
|
scanerror(T_NULL, "End-of-file in function body");
|
||||||
return;
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -398,9 +404,11 @@ getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaul
|
|||||||
* declarations = { LOCAL | GLOBAL | STATIC } onedeclaration
|
* declarations = { LOCAL | GLOBAL | STATIC } onedeclaration
|
||||||
* [ ',' onedeclaration ] ... ';'.
|
* [ ',' onedeclaration ] ... ';'.
|
||||||
*/
|
*/
|
||||||
static void
|
static int
|
||||||
getdeclarations(int symtype)
|
getdeclarations(int symtype)
|
||||||
{
|
{
|
||||||
|
int res = 0;
|
||||||
|
|
||||||
while (TRUE) {
|
while (TRUE) {
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_COMMA:
|
case T_COMMA:
|
||||||
@@ -409,29 +417,33 @@ 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 res;
|
||||||
|
|
||||||
case T_SYMBOL:
|
case T_SYMBOL:
|
||||||
addopone(OP_DEBUG, linenumber());
|
addopone(OP_DEBUG, linenumber());
|
||||||
rescantoken();
|
rescantoken();
|
||||||
getsimpledeclaration(symtype);
|
if (getsimpledeclaration(symtype))
|
||||||
|
res = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_MAT:
|
case T_MAT:
|
||||||
addopone(OP_DEBUG, linenumber());
|
addopone(OP_DEBUG, linenumber());
|
||||||
getmatdeclaration(symtype);
|
getmatdeclaration(symtype);
|
||||||
|
res = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_OBJ:
|
case T_OBJ:
|
||||||
addopone(OP_DEBUG, linenumber());
|
addopone(OP_DEBUG, linenumber());
|
||||||
getobjdeclaration(symtype);
|
getobjdeclaration(symtype);
|
||||||
addop(OP_POP);
|
addop(OP_POP);
|
||||||
|
res = 1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
scanerror(T_SEMICOLON, "Bad syntax in declaration statement");
|
scanerror(T_SEMICOLON, "Bad syntax in declaration statement");
|
||||||
return;
|
return res;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -443,22 +455,24 @@ getdeclarations(int symtype)
|
|||||||
* Subsequences end with "," or at end of line; spaces indicate
|
* Subsequences end with "," or at end of line; spaces indicate
|
||||||
* repeated assignment, e.g. "c d = 2" has the effect of "c = 2, d = 2".
|
* repeated assignment, e.g. "c d = 2" has the effect of "c = 2, d = 2".
|
||||||
*/
|
*/
|
||||||
static void
|
static int
|
||||||
getsimpledeclaration(int symtype)
|
getsimpledeclaration(int symtype)
|
||||||
{
|
{
|
||||||
|
int res = 0;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_SYMBOL:
|
case T_SYMBOL:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
if (getonevariable(symtype))
|
res = getonevariable(symtype);
|
||||||
|
if (res)
|
||||||
addop(OP_POP);
|
addop(OP_POP);
|
||||||
continue;
|
continue;
|
||||||
case T_COMMA:
|
case T_COMMA:
|
||||||
continue;
|
continue;
|
||||||
default:
|
default:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
return;
|
return res;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -507,11 +521,9 @@ getonevariable(int symtype)
|
|||||||
* | BREAK ';'
|
* | BREAK ';'
|
||||||
* | RETURN assignment ';'
|
* | RETURN assignment ';'
|
||||||
* | GOTO label ';'
|
* | GOTO label ';'
|
||||||
* | MAT name '[' value [ ':' value ] [',' value [ ':' value ] ] ']' ';'
|
|
||||||
* | OBJ type '{' arg [ ',' arg ] ... '}' ] ';'
|
|
||||||
* | OBJ type name [ ',' name ] ';'
|
|
||||||
* | PRINT assignment [, assignment ] ... ';'
|
* | PRINT assignment [, assignment ] ... ';'
|
||||||
* | QUIT [ string ] ';'
|
* | QUIT [ string ] ';'
|
||||||
|
* | ABORT [ string ] ';'
|
||||||
* | SHOW item ';'
|
* | SHOW item ';'
|
||||||
* | body
|
* | body
|
||||||
* | assignment ';'
|
* | assignment ';'
|
||||||
@@ -540,18 +552,20 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
case T_GLOBAL:
|
case T_GLOBAL:
|
||||||
getdeclarations(SYM_GLOBAL);
|
(void) getdeclarations(SYM_GLOBAL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_STATIC:
|
case T_STATIC:
|
||||||
clearlabel(&label);
|
clearlabel(&label);
|
||||||
addoplabel(OP_INITSTATIC, &label);
|
addoplabel(OP_INITSTATIC, &label);
|
||||||
getdeclarations(SYM_STATIC);
|
if (getdeclarations(SYM_STATIC))
|
||||||
setlabel(&label);
|
setlabel(&label);
|
||||||
|
else
|
||||||
|
curfunc->f_opcodecount -= 2;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_LOCAL:
|
case T_LOCAL:
|
||||||
getdeclarations(SYM_LOCAL);
|
(void) getdeclarations(SYM_LOCAL);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_RIGHTBRACE:
|
case T_RIGHTBRACE:
|
||||||
@@ -691,14 +705,14 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (gettoken() != T_RIGHTPAREN) { /* have 'c' part */
|
if (gettoken() != T_RIGHTPAREN) { /* have 'c' part */
|
||||||
if (label1.l_offset <= 0)
|
if (label1.l_offset < 0)
|
||||||
addoplabel(OP_JUMP, &label3);
|
addoplabel(OP_JUMP, &label3);
|
||||||
setlabel(&label2);
|
setlabel(&label2);
|
||||||
contlabel = &label2;
|
contlabel = &label2;
|
||||||
rescantoken();
|
rescantoken();
|
||||||
(void) getexprlist();
|
(void) getexprlist();
|
||||||
addop(OP_POP);
|
addop(OP_POP);
|
||||||
if (label1.l_offset > 0)
|
if (label1.l_offset >= 0)
|
||||||
addoplabel(OP_JUMP, &label1);
|
addoplabel(OP_JUMP, &label1);
|
||||||
if (gettoken() != T_RIGHTPAREN) {
|
if (gettoken() != T_RIGHTPAREN) {
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
@@ -718,15 +732,21 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
case T_WHILE:
|
case T_WHILE:
|
||||||
oldmode = tokenmode(TM_DEFAULT);
|
oldmode = tokenmode(TM_DEFAULT);
|
||||||
contlabel = &label1;
|
contlabel = &label1;
|
||||||
breaklabel = &label2;
|
|
||||||
clearlabel(contlabel);
|
clearlabel(contlabel);
|
||||||
clearlabel(breaklabel);
|
|
||||||
setlabel(contlabel);
|
setlabel(contlabel);
|
||||||
getcondition();
|
getcondition();
|
||||||
addoplabel(OP_JUMPZ, breaklabel);
|
if (gettoken() != T_SEMICOLON) {
|
||||||
getstatement(contlabel, breaklabel, NULL_LABEL, NULL_LABEL);
|
breaklabel = &label2;
|
||||||
addoplabel(OP_JUMP, contlabel);
|
clearlabel(breaklabel);
|
||||||
setlabel(breaklabel);
|
addoplabel(OP_JUMPZ, breaklabel);
|
||||||
|
rescantoken();
|
||||||
|
getstatement(contlabel, breaklabel,
|
||||||
|
NULL_LABEL, NULL_LABEL);
|
||||||
|
addoplabel(OP_JUMP, contlabel);
|
||||||
|
setlabel(breaklabel);
|
||||||
|
} else {
|
||||||
|
addoplabel(OP_JUMPNZ, contlabel);
|
||||||
|
}
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -994,7 +1014,11 @@ getobjdeclaration(int symtype)
|
|||||||
/*FALLTHRU*/
|
/*FALLTHRU*/
|
||||||
case T_RIGHTBRACE:
|
case T_RIGHTBRACE:
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
(void) defineobject(name, indices, count);
|
if (defineobject(name, indices, count)) {
|
||||||
|
scanerror(T_NULL,
|
||||||
|
"Object type \"%s\" is already defined", name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
getobjvars(name, symtype);
|
getobjvars(name, symtype);
|
||||||
return;
|
return;
|
||||||
case T_NEWLINE:
|
case T_NEWLINE:
|
||||||
@@ -1033,18 +1057,14 @@ getoneobj(long index, int symtype)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Routine to collect a set of variables for the specified object type
|
* Routine to assign a specified object-type value to each of a set of
|
||||||
* and initialize them as being that type of object.
|
* variables in a "global", "local" or "static" declaration, or, if
|
||||||
* Here
|
* symtype is SYM_UNDEFINED, to create one object value of the specified
|
||||||
* objlist = name initlist [ ',' name initlist ] ... ';'.
|
* type.
|
||||||
* If symtype is SYM_UNDEFINED, then this is an OBJ statement where the
|
|
||||||
* values can be any variable expression, and no symbols are to be defined.
|
|
||||||
* Otherwise this is part of a declaration, and the variables must be raw
|
|
||||||
* symbol names which are defined with the specified symbol type.
|
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* name object name
|
* name object name
|
||||||
* symtype type of symbol to collect for
|
* symtype declaration type
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
getobjvars(char *name, int symtype)
|
getobjvars(char *name, int symtype)
|
||||||
@@ -1058,6 +1078,8 @@ getobjvars(char *name, int symtype)
|
|||||||
}
|
}
|
||||||
for (;;) {
|
for (;;) {
|
||||||
getoneobj(index, symtype);
|
getoneobj(index, symtype);
|
||||||
|
if (symtype == SYM_UNDEFINED)
|
||||||
|
return;
|
||||||
if (gettoken() != T_COMMA) {
|
if (gettoken() != T_COMMA) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
return;
|
return;
|
||||||
@@ -1349,7 +1371,7 @@ getopassignment(void)
|
|||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
if (isrvalue(type)) {
|
if (isrvalue(type)) {
|
||||||
scanerror(T_NULL, "Illegal assignment in getopassignment");
|
scanerror(T_NULL, "Illegal assignment");
|
||||||
(void) getopassignment();
|
(void) getopassignment();
|
||||||
return (EXPR_RVALUE | EXPR_ASSIGN);
|
return (EXPR_RVALUE | EXPR_ASSIGN);
|
||||||
}
|
}
|
||||||
@@ -1442,7 +1464,7 @@ getassignment (void)
|
|||||||
return type;
|
return type;
|
||||||
}
|
}
|
||||||
if (isrvalue(type)) {
|
if (isrvalue(type)) {
|
||||||
scanerror(T_SEMICOLON, "Illegal assignment in getassignment");
|
scanerror(T_SEMICOLON, "Illegal assignment");
|
||||||
(void) getassignment();
|
(void) getassignment();
|
||||||
return (EXPR_RVALUE | EXPR_ASSIGN);
|
return (EXPR_RVALUE | EXPR_ASSIGN);
|
||||||
}
|
}
|
||||||
@@ -1901,11 +1923,6 @@ getterm(void)
|
|||||||
|
|
||||||
case T_MAT:
|
case T_MAT:
|
||||||
getonematrix(SYM_UNDEFINED);
|
getonematrix(SYM_UNDEFINED);
|
||||||
while (gettoken() == T_COMMA) {
|
|
||||||
addop(OP_POP);
|
|
||||||
getonematrix(SYM_UNDEFINED);
|
|
||||||
}
|
|
||||||
rescantoken();
|
|
||||||
type = EXPR_ASSIGN;
|
type = EXPR_ASSIGN;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
42
config.c
42
config.c
@@ -94,8 +94,8 @@ CONFIG oldstd = { /* backward compatible standard configuration */
|
|||||||
FALSE, /* skip duplicate block output lines */
|
FALSE, /* skip duplicate block output lines */
|
||||||
BLK_BASE_HEX, /* block octet print base */
|
BLK_BASE_HEX, /* block octet print base */
|
||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
3, /* calc library debug level */
|
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
|
3, /* calc library debug level */
|
||||||
0, /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
TRUE /* print Quit or abort executed messages */
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
@@ -130,8 +130,8 @@ CONFIG newstd = { /* new non-backward compatible configuration */
|
|||||||
FALSE, /* skip duplicate block output lines */
|
FALSE, /* skip duplicate block output lines */
|
||||||
BLK_BASE_HEX, /* block octet print base */
|
BLK_BASE_HEX, /* block octet print base */
|
||||||
BLK_FMT_HD_STYLE, /* block output format */
|
BLK_FMT_HD_STYLE, /* block output format */
|
||||||
3, /* calc library debug level */
|
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
|
3, /* calc library debug level */
|
||||||
0, /* user defined debug level */
|
0, /* user defined debug level */
|
||||||
TRUE /* print Quit or abort executed messages */
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
@@ -809,20 +809,6 @@ setconfig(int type, VALUE *vp)
|
|||||||
conf->blkfmt = temp;
|
conf->blkfmt = temp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_LIB_DEBUG:
|
|
||||||
if (vp->v_type != V_NUM) {
|
|
||||||
math_error("Non numeric for lib_debug");
|
|
||||||
/*NOTREACHED*/
|
|
||||||
}
|
|
||||||
q = vp->v_num;
|
|
||||||
temp = qtoi(q);
|
|
||||||
if (qisfrac(q) || !zistiny(q->num)) {
|
|
||||||
math_error("Illegal lib_debug parameter value");
|
|
||||||
/*NOTREACHED*/
|
|
||||||
}
|
|
||||||
conf->lib_debug = temp;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CONFIG_CALC_DEBUG:
|
case CONFIG_CALC_DEBUG:
|
||||||
if (vp->v_type != V_NUM) {
|
if (vp->v_type != V_NUM) {
|
||||||
math_error("Non numeric for calc_debug");
|
math_error("Non numeric for calc_debug");
|
||||||
@@ -837,6 +823,20 @@ setconfig(int type, VALUE *vp)
|
|||||||
conf->calc_debug = temp;
|
conf->calc_debug = temp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_LIB_DEBUG:
|
||||||
|
if (vp->v_type != V_NUM) {
|
||||||
|
math_error("Non numeric for lib_debug");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
q = vp->v_num;
|
||||||
|
temp = qtoi(q);
|
||||||
|
if (qisfrac(q) || !zistiny(q->num)) {
|
||||||
|
math_error("Illegal lib_debug parameter value");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
conf->lib_debug = temp;
|
||||||
|
break;
|
||||||
|
|
||||||
case CONFIG_USER_DEBUG:
|
case CONFIG_USER_DEBUG:
|
||||||
if (vp->v_type != V_NUM) {
|
if (vp->v_type != V_NUM) {
|
||||||
math_error("Non numeric for user_debug");
|
math_error("Non numeric for user_debug");
|
||||||
@@ -1125,14 +1125,14 @@ config_value(CONFIG *cfg, int type, VALUE *vp)
|
|||||||
i = cfg->blkfmt;
|
i = cfg->blkfmt;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CONFIG_LIB_DEBUG:
|
|
||||||
i = cfg->lib_debug;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CONFIG_CALC_DEBUG:
|
case CONFIG_CALC_DEBUG:
|
||||||
i = cfg->calc_debug;
|
i = cfg->calc_debug;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_LIB_DEBUG:
|
||||||
|
i = cfg->lib_debug;
|
||||||
|
break;
|
||||||
|
|
||||||
case CONFIG_USER_DEBUG:
|
case CONFIG_USER_DEBUG:
|
||||||
i = cfg->user_debug;
|
i = cfg->user_debug;
|
||||||
break;
|
break;
|
||||||
@@ -1214,8 +1214,8 @@ config_cmp(CONFIG *cfg1, CONFIG *cfg2)
|
|||||||
cfg1->blkverbose != cfg2->blkverbose ||
|
cfg1->blkverbose != cfg2->blkverbose ||
|
||||||
cfg1->blkbase != cfg2->blkbase ||
|
cfg1->blkbase != cfg2->blkbase ||
|
||||||
cfg1->blkfmt != cfg2->blkfmt ||
|
cfg1->blkfmt != cfg2->blkfmt ||
|
||||||
cfg1->lib_debug != cfg2->lib_debug ||
|
|
||||||
cfg1->calc_debug != cfg2->calc_debug ||
|
cfg1->calc_debug != cfg2->calc_debug ||
|
||||||
|
cfg1->lib_debug != cfg2->lib_debug ||
|
||||||
cfg1->user_debug != cfg2->user_debug ||
|
cfg1->user_debug != cfg2->user_debug ||
|
||||||
cfg1->verbose_quit != cfg2->verbose_quit;
|
cfg1->verbose_quit != cfg2->verbose_quit;
|
||||||
}
|
}
|
||||||
|
15
config.h
15
config.h
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -135,9 +135,9 @@ struct config {
|
|||||||
BOOL 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 */
|
long calc_debug; /* internal debug, see CALC_DEBUG_XXX below */
|
||||||
int calc_debug; /* internal debug, see CALC_DEBUG_XXX below */
|
long lib_debug; /* library debug, see LIB_DEBUG_XXX below */
|
||||||
int user_debug; /* user defined debug value: 0 default */
|
long user_debug; /* user defined debug value: 0 default */
|
||||||
BOOL verbose_quit; /* TRUE => print Quit or abort executed msg */
|
BOOL verbose_quit; /* TRUE => print Quit or abort executed msg */
|
||||||
};
|
};
|
||||||
typedef struct config CONFIG;
|
typedef struct config CONFIG;
|
||||||
@@ -158,7 +158,9 @@ typedef struct config CONFIG;
|
|||||||
#define CALCDBG_FUNC_QUIT (0x00000002) /* active functions when quit */
|
#define CALCDBG_FUNC_QUIT (0x00000002) /* active functions when quit */
|
||||||
#define CALCDBG_HASH_STATE (0x00000004) /* hash state details */
|
#define CALCDBG_HASH_STATE (0x00000004) /* hash state details */
|
||||||
#define CALCDBG_BLOCK (0x00000008) /* block debug */
|
#define CALCDBG_BLOCK (0x00000008) /* block debug */
|
||||||
#define CALCDBG_MASK (0x0000000f)
|
#define CALCDBG_TTY (0x00000010) /* report TTY state changes */
|
||||||
|
#define CALCDBG_RUNSTATE (0x00000020) /* report run_state changes */
|
||||||
|
#define CALCDBG_MASK (0x0000003f)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -167,6 +169,9 @@ typedef struct config CONFIG;
|
|||||||
extern CONFIG *conf; /* current configuration */
|
extern CONFIG *conf; /* current configuration */
|
||||||
extern CONFIG oldstd; /* backward compatible standard configuration */
|
extern CONFIG oldstd; /* backward compatible standard configuration */
|
||||||
extern CONFIG newstd; /* new non-backward compatible configuration */
|
extern CONFIG newstd; /* new non-backward compatible configuration */
|
||||||
|
extern char *calc_debug; /* !=NULL => value of config("calc_debug") */
|
||||||
|
extern char *lib_debug; /* !=NULL => value of config("lib_debug") */
|
||||||
|
extern char *user_debug; /* !=NULL => value of config("user_debug") */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
2
custom.c
2
custom.c
@@ -25,7 +25,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
2
custom.h
2
custom.h
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -19,7 +19,7 @@
|
|||||||
# OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
# OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
# PERFORMANCE OF THIS SOFTWARE.
|
# PERFORMANCE OF THIS SOFTWARE.
|
||||||
#
|
#
|
||||||
# chongo was here /\../\ http://reality.sgi.com/chongo
|
# chongo was here /\../\ http://reality.sgi.com/chongo/
|
||||||
|
|
||||||
The following custom calc library files are provided because they serve
|
The following custom calc library files are provided because they serve
|
||||||
as examples of how use the custom interface. The custom interface
|
as examples of how use the custom interface. The custom interface
|
||||||
|
@@ -27,7 +27,7 @@
|
|||||||
# Happy bit twiddling,
|
# Happy bit twiddling,
|
||||||
#
|
#
|
||||||
# Landon Curt Noll
|
# Landon Curt Noll
|
||||||
# http://reality.sgi.com/chongo
|
# http://reality.sgi.com/chongo/
|
||||||
#
|
#
|
||||||
# chongo <was here> /\../\
|
# chongo <was here> /\../\
|
||||||
|
|
||||||
@@ -310,6 +310,15 @@ libcustcalc.a: ${CUSTCALC_OBJ} ${MAKE_FILE} ../Makefile
|
|||||||
ar qc libcustcalc.a ${CUSTCALC_OBJ}
|
ar qc libcustcalc.a ${CUSTCALC_OBJ}
|
||||||
${RANLIB} libcustcalc.a
|
${RANLIB} libcustcalc.a
|
||||||
|
|
||||||
|
##
|
||||||
|
#
|
||||||
|
# Special .o files
|
||||||
|
#
|
||||||
|
##
|
||||||
|
|
||||||
|
c_sysinfo.o: c_sysinfo.c ${MAKE_FILE}
|
||||||
|
${CC} ${CFLAGS} c_sysinfo.c -c
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
# used by the upper level Makefile
|
# used by the upper level Makefile
|
||||||
@@ -337,15 +346,11 @@ libcustcalc.a: ${CUSTCALC_OBJ} ${MAKE_FILE} ../Makefile
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/custom/$$i; \
|
echo custom/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo custom
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/custom/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -419,12 +424,12 @@ depend:
|
|||||||
else \
|
else \
|
||||||
rm -f Makefile.tmp; \
|
rm -f Makefile.tmp; \
|
||||||
mv Makefile Makefile.tmp; \
|
mv Makefile Makefile.tmp; \
|
||||||
if [ -d RCS ]; then; \
|
if [ -d RCS ]; then \
|
||||||
co -l Makefile; \
|
co -l Makefile; \
|
||||||
fi ;\
|
fi ;\
|
||||||
mv Makefile.tmp Makefile; \
|
mv Makefile.tmp Makefile; \
|
||||||
if [ -d RCS ]; then; \
|
if [ -d RCS ]; then \
|
||||||
echo new custom Makefile formed '--' you need to check it in'; \
|
echo 'new custom Makefile formed -- you need to check it in'; \
|
||||||
fi; \
|
fi; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* chongo was here /\../\ http://reality.sgi.com/chongo
|
* chongo was here /\../\ http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* argv - print information about various args
|
* argv - print information about various args
|
||||||
|
@@ -16,7 +16,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -16,7 +16,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -16,7 +16,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -16,7 +16,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -33,6 +33,7 @@
|
|||||||
#include "../config.h"
|
#include "../config.h"
|
||||||
#include "../calc.h"
|
#include "../calc.h"
|
||||||
#include "../longbits.h"
|
#include "../longbits.h"
|
||||||
|
#define CHECK_L_FORMAT
|
||||||
#include "../longlong.h"
|
#include "../longlong.h"
|
||||||
#include "../block.h"
|
#include "../block.h"
|
||||||
#include "../calcerr.h"
|
#include "../calcerr.h"
|
||||||
@@ -108,7 +109,6 @@ static struct infoname sys_info[] = {
|
|||||||
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
||||||
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
||||||
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
||||||
{"MAXOBJECTS", "max number of object types", NULL, (FULL)MAXOBJECTS},
|
|
||||||
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
||||||
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
||||||
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
||||||
@@ -307,17 +307,33 @@ static void
|
|||||||
dump_name_value(void)
|
dump_name_value(void)
|
||||||
{
|
{
|
||||||
struct infoname *p; /* current infoname */
|
struct infoname *p; /* current infoname */
|
||||||
|
char *fmt; /* printf value format */
|
||||||
|
|
||||||
/* dump the entire table */
|
/* dump the entire table */
|
||||||
for (p = sys_info; p->name != NULL; ++p) {
|
for (p = sys_info; p->name != NULL; ++p) {
|
||||||
if (p->str == NULL) {
|
if (p->str == NULL) {
|
||||||
#if LONG_BITS == FULL_BITS || FULL_BITS == 32 || !defined(HAVE_LONGLONG)
|
#if LONG_BITS == FULL_BITS || FULL_BITS == 32 || !defined(HAVE_LONGLONG)
|
||||||
printf("%s%-23s\t%-8lu\t(0x%lx)\n",
|
fmt = "%s%-23s\t%-8lu\t(0x%lx)\n";
|
||||||
|
printf(fmt,
|
||||||
(conf->tab_ok ? "\t" : ""), p->name,
|
(conf->tab_ok ? "\t" : ""), p->name,
|
||||||
(unsigned long)p->nmbr,
|
(unsigned long)p->nmbr,
|
||||||
(unsigned long)p->nmbr);
|
(unsigned long)p->nmbr);
|
||||||
#else
|
#else
|
||||||
printf("%s%-23s\t%-8llu\t(0x%llx)\n",
|
/*
|
||||||
|
* Determine of %ld can print a 64 bit long long.
|
||||||
|
*
|
||||||
|
* Some systems that can make use of %ld to print a
|
||||||
|
* a 64 bit value do not support the %lld type.
|
||||||
|
* So we will only try %lld if %ld does not work.
|
||||||
|
*/
|
||||||
|
if (l_format < 0) {
|
||||||
|
/* %ld prints lower 32 bits only, use %lld */
|
||||||
|
fmt = "%s%-23s\t%-8llu\t(0x%llx)\n";
|
||||||
|
} else {
|
||||||
|
/* %ld prints all 64 bits, use %ld */
|
||||||
|
fmt = "%s%-23s\t%-8lu\t(0x%lx)\n";
|
||||||
|
}
|
||||||
|
printf(fmt,
|
||||||
(conf->tab_ok ? "\t" : ""), p->name,
|
(conf->tab_ok ? "\t" : ""), p->name,
|
||||||
(unsigned long long)p->nmbr,
|
(unsigned long long)p->nmbr,
|
||||||
(unsigned long long)p->nmbr);
|
(unsigned long long)p->nmbr);
|
||||||
@@ -338,17 +354,33 @@ static void
|
|||||||
dump_mening_value(void)
|
dump_mening_value(void)
|
||||||
{
|
{
|
||||||
struct infoname *p; /* current infoname */
|
struct infoname *p; /* current infoname */
|
||||||
|
char *fmt; /* printf value format */
|
||||||
|
|
||||||
/* dump the entire table */
|
/* dump the entire table */
|
||||||
for (p = sys_info; p->name != NULL; ++p) {
|
for (p = sys_info; p->name != NULL; ++p) {
|
||||||
if (p->str == NULL) {
|
if (p->str == NULL) {
|
||||||
#if LONG_BITS == FULL_BITS || FULL_BITS == 32 || !defined(HAVE_LONGLONG)
|
#if LONG_BITS == FULL_BITS || FULL_BITS == 32 || !defined(HAVE_LONGLONG)
|
||||||
printf("%s%-36.36s\t%-8lu\t(0x%lx)\n",
|
fmt = "%s%-36.36s\t%-8lu\t(0x%lx)\n";
|
||||||
|
printf(fmt,
|
||||||
(conf->tab_ok ? "\t" : ""), p->meaning,
|
(conf->tab_ok ? "\t" : ""), p->meaning,
|
||||||
(unsigned long)p->nmbr,
|
(unsigned long)p->nmbr,
|
||||||
(unsigned long)p->nmbr);
|
(unsigned long)p->nmbr);
|
||||||
#else
|
#else
|
||||||
printf("%s%-36.36s\t%-8llu\t(0x%llx)\n",
|
/*
|
||||||
|
* Determine of %ld can print a 64 bit long long.
|
||||||
|
*
|
||||||
|
* Some systems that can make use of %ld to print a
|
||||||
|
* a 64 bit value do not support the %lld type.
|
||||||
|
* So we will only try %lld if %ld does not work.
|
||||||
|
*/
|
||||||
|
if (l_format < 0) {
|
||||||
|
/* %ld prints lower 32 bits only, use %lld */
|
||||||
|
fmt = "%s%-36.36s\t%-8llu\t(0x%llx)\n";
|
||||||
|
} else {
|
||||||
|
/* %ld prints all 64 bits, use %ld */
|
||||||
|
fmt = "%s%-36.36s\t%-8lu\t(0x%lx)\n";
|
||||||
|
}
|
||||||
|
printf(fmt,
|
||||||
(conf->tab_ok ? "\t" : ""), p->meaning,
|
(conf->tab_ok ? "\t" : ""), p->meaning,
|
||||||
(unsigned long long)p->nmbr,
|
(unsigned long long)p->nmbr,
|
||||||
(unsigned long long)p->nmbr);
|
(unsigned long long)p->nmbr);
|
||||||
|
@@ -25,7 +25,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* chongo was here /\../\ http://reality.sgi.com/chongo
|
* chongo was here /\../\ http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* halflen - determine the length of numeric value in HALFs
|
* halflen - determine the length of numeric value in HALFs
|
||||||
|
92
func.c
92
func.c
@@ -10,6 +10,7 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
#if defined(FUNCLIST)
|
#if defined(FUNCLIST)
|
||||||
|
|
||||||
@@ -17,8 +18,6 @@
|
|||||||
|
|
||||||
#else /* FUNCLIST */
|
#else /* FUNCLIST */
|
||||||
|
|
||||||
#include "calc_errno.h"
|
|
||||||
|
|
||||||
#include "have_unistd.h"
|
#include "have_unistd.h"
|
||||||
#if defined(HAVE_UNISTD_H)
|
#if defined(HAVE_UNISTD_H)
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@@ -29,16 +28,24 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "have_string.h"
|
||||||
|
#if defined(HAVE_STRING_H)
|
||||||
|
#include <string.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "have_times.h"
|
#include "have_times.h"
|
||||||
#if defined(HAVE_TIME_H)
|
#if defined(HAVE_TIME_H)
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_TIMES_H)
|
#if defined(HAVE_TIMES_H)
|
||||||
#include <times.h>
|
#include <times.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_SYS_TIME_H)
|
#if defined(HAVE_SYS_TIME_H)
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_SYS_TIMES_H)
|
#if defined(HAVE_SYS_TIMES_H)
|
||||||
#include <sys/times.h>
|
#include <sys/times.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -155,6 +162,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 +176,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 +192,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 +215,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*/
|
||||||
@@ -4623,6 +4635,7 @@ f_strerror(int count, VALUE **vals)
|
|||||||
long i;
|
long i;
|
||||||
char *cp;
|
char *cp;
|
||||||
|
|
||||||
|
/* parse args */
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
vp = vals[0];
|
vp = vals[0];
|
||||||
if (vp->v_type < 0) {
|
if (vp->v_type < 0) {
|
||||||
@@ -4634,36 +4647,44 @@ f_strerror(int count, VALUE **vals)
|
|||||||
if (i < 0 || i > 32767)
|
if (i < 0 || i > 32767)
|
||||||
return error_value(E_STRERROR2);
|
return error_value(E_STRERROR2);
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else
|
|
||||||
i = set_errno(-1);
|
i = set_errno(-1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* setup return type */
|
||||||
result.v_type = V_STR;
|
result.v_type = V_STR;
|
||||||
|
|
||||||
|
/* change the meaning of error 0 */
|
||||||
if (i == 0)
|
if (i == 0)
|
||||||
i = E__BASE;
|
i = E__BASE;
|
||||||
|
|
||||||
|
/* firewall - return generic error string if it is not assigned */
|
||||||
if (i >= nexterrnum || (i > E__HIGHEST && i < E_USERDEF)
|
if (i >= nexterrnum || (i > E__HIGHEST && i < E_USERDEF)
|
||||||
|| (i < E__BASE && i >= sys_nerr)) {
|
|| (i < E__BASE && strerror(i) == NULL)) {
|
||||||
cp = (char *) malloc(12);
|
cp = (char *) malloc(sizeof("Error 1234567890")+1);
|
||||||
if (cp == NULL) {
|
if (cp == NULL) {
|
||||||
math_error("Out of memory for strerror");
|
math_error("Out of memory for strerror");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
sprintf(cp, "Error %ld", i);
|
sprintf(cp, "Unknown error %ld", i);
|
||||||
result.v_str = makestring(cp);
|
result.v_str = makestring(cp);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i < E__BASE) /* system error */
|
/* system error */
|
||||||
cp = (char *) sys_errlist[i];
|
if (i < E__BASE) {
|
||||||
|
cp = strerror(i);
|
||||||
|
|
||||||
else if (i >= E_USERDEF) /* user-described error */
|
/* user-described error */
|
||||||
|
} else if (i >= E_USERDEF) {
|
||||||
cp = namestr(&newerrorstr, i - E_USERDEF);
|
cp = namestr(&newerrorstr, i - E_USERDEF);
|
||||||
|
|
||||||
else /* calc-described error */
|
/* calc-described error */
|
||||||
|
} else {
|
||||||
cp = (char *)error_table[i - E__BASE];
|
cp = (char *)error_table[i - E__BASE];
|
||||||
|
}
|
||||||
|
|
||||||
|
/* return result as a V_STR */
|
||||||
result.v_str = makenewstring(cp);
|
result.v_str = makenewstring(cp);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -5893,6 +5914,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 +6850,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,
|
||||||
@@ -7316,12 +7350,33 @@ static CONST struct builtin builtins[] = {
|
|||||||
*
|
*
|
||||||
* When FUNCLIST is defined, we are being compiled by rules from the help
|
* When FUNCLIST is defined, we are being compiled by rules from the help
|
||||||
* sub-directory to form a program that will produce the main part of the
|
* sub-directory to form a program that will produce the main part of the
|
||||||
* buiiltin help file. These rules will convert the following function
|
* buiiltin help file.
|
||||||
* name into main and remove the 'sed me out' line.
|
|
||||||
*
|
*
|
||||||
* See the builtin rule in the help/Makefile for details.
|
* See the builtin rule in the help/Makefile for details.
|
||||||
*/
|
*/
|
||||||
void /* sed me out */
|
#if defined(FUNCLIST)
|
||||||
|
/*ARGSUSED*/
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
CONST struct builtin *bp; /* current function */
|
||||||
|
|
||||||
|
printf("\nName\tArgs\tDescription\n\n");
|
||||||
|
for (bp = builtins; bp->b_name; bp++) {
|
||||||
|
printf("%-9s ", bp->b_name);
|
||||||
|
if (bp->b_maxargs == IN)
|
||||||
|
printf("%d+ ", bp->b_minargs);
|
||||||
|
else if (bp->b_minargs == bp->b_maxargs)
|
||||||
|
printf("%-6d", bp->b_minargs);
|
||||||
|
else
|
||||||
|
printf("%d-%-4d", bp->b_minargs, bp->b_maxargs);
|
||||||
|
printf("%s\n", bp->b_desc);
|
||||||
|
}
|
||||||
|
printf("\n");
|
||||||
|
return 0; /* exit(0); */
|
||||||
|
}
|
||||||
|
#else /* FUNCLIST */
|
||||||
|
void
|
||||||
showbuiltins(void)
|
showbuiltins(void)
|
||||||
{
|
{
|
||||||
CONST struct builtin *bp; /* current function */
|
CONST struct builtin *bp; /* current function */
|
||||||
@@ -7339,6 +7394,7 @@ showbuiltins(void)
|
|||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
#endif /* FUNCLIST */
|
||||||
|
|
||||||
|
|
||||||
#if !defined(FUNCLIST)
|
#if !defined(FUNCLIST)
|
||||||
|
62
have_rusage.c
Normal file
62
have_rusage.c
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* have_rusage - Determine if we getrusage()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_rusage
|
||||||
|
*
|
||||||
|
* Not all systems have the getrusage() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_GETRUSAGE
|
||||||
|
* defined ==> use getrusage()
|
||||||
|
* undefined ==> do not call or cannot call getrusage()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and distribute this software and
|
||||||
|
* its documentation for any purpose and without fee is hereby granted,
|
||||||
|
* provided that the above copyright, this permission notice and text
|
||||||
|
* this comment, and the disclaimer below appear in all of the following:
|
||||||
|
*
|
||||||
|
* supporting documentation
|
||||||
|
* source copies
|
||||||
|
* source works derived from this source
|
||||||
|
* binaries derived from this source or from derived source
|
||||||
|
*
|
||||||
|
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||||
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO
|
||||||
|
* EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||||
|
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||||
|
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*
|
||||||
|
* chongo was here /\../\
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/resource.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_GETRUSAGE)
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETRUSAGE /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_GETRUSAGE */
|
||||||
|
|
||||||
|
struct rusage rusage; /* resource utilization */
|
||||||
|
|
||||||
|
(void) getrusage(RUSAGE_SELF, &rusage);
|
||||||
|
|
||||||
|
printf("#define HAVE_GETRUSAGE /* yes */\n");
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_GETRUSAGE */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
62
have_strdup.c
Normal file
62
have_strdup.c
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/*
|
||||||
|
* have_strdup - Determine if we strdup()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_strdup
|
||||||
|
*
|
||||||
|
* Not all systems have the strdup() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_STRDUP
|
||||||
|
* defined ==> use strdup()
|
||||||
|
* undefined ==> do not call or cannot call strdup()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and distribute this software and
|
||||||
|
* its documentation for any purpose and without fee is hereby granted,
|
||||||
|
* provided that the above copyright, this permission notice and text
|
||||||
|
* this comment, and the disclaimer below appear in all of the following:
|
||||||
|
*
|
||||||
|
* supporting documentation
|
||||||
|
* source copies
|
||||||
|
* source works derived from this source
|
||||||
|
* binaries derived from this source or from derived source
|
||||||
|
*
|
||||||
|
* LANDON CURT NOLL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
|
||||||
|
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO
|
||||||
|
* EVENT SHALL LANDON CURT NOLL BE LIABLE FOR ANY SPECIAL, INDIRECT OR
|
||||||
|
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF
|
||||||
|
* USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
||||||
|
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
||||||
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*
|
||||||
|
* chongo was here /\../\
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_STRDUP)
|
||||||
|
|
||||||
|
printf("#undef HAVE_STRDUP /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_STRDUP */
|
||||||
|
|
||||||
|
char *p;
|
||||||
|
|
||||||
|
p = strdup("#define HAVE_STRDUP /* yes */");
|
||||||
|
if (p != NULL) {
|
||||||
|
printf("%s\n", p);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_STRDUP */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -35,13 +35,12 @@ Q=@
|
|||||||
|
|
||||||
# standard tools
|
# standard tools
|
||||||
#
|
#
|
||||||
NATIVE_CC= cc
|
LCC= cc
|
||||||
NATIVE_CFLAGS=
|
ICFLAGS=
|
||||||
|
ILDFLAGS=
|
||||||
SED= sed
|
SED= sed
|
||||||
SORT= sort
|
SORT= sort
|
||||||
FMT= fmt
|
FMT= fmt
|
||||||
CMP= cmp
|
|
||||||
CAT= cat
|
|
||||||
|
|
||||||
# Standard and Builtin help files
|
# Standard and Builtin help files
|
||||||
#
|
#
|
||||||
@@ -105,29 +104,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.
|
||||||
@@ -233,7 +233,7 @@ bugs: ../BUGS
|
|||||||
|
|
||||||
errorcodes: ../calcerr.h errorcodes.hdr errorcodes.sed
|
errorcodes: ../calcerr.h errorcodes.hdr errorcodes.sed
|
||||||
rm -f $@
|
rm -f $@
|
||||||
${CAT} errorcodes.hdr > $@
|
cat errorcodes.hdr > $@
|
||||||
${SED} -n -f errorcodes.sed < ../calcerr.h >> $@
|
${SED} -n -f errorcodes.sed < ../calcerr.h >> $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
@@ -358,17 +358,13 @@ ${SINGULAR_FILES}: ${PLURAL_FILES}
|
|||||||
#
|
#
|
||||||
builtin: builtin.top builtin.end ../func.c funclist.sed
|
builtin: builtin.top builtin.end ../func.c funclist.sed
|
||||||
${Q}echo "forming builtin help file"
|
${Q}echo "forming builtin help file"
|
||||||
-${Q}rm -f builtin
|
|
||||||
${Q}cat builtin.top > builtin
|
|
||||||
-${Q}rm -f funclist.c
|
-${Q}rm -f funclist.c
|
||||||
${Q}${SED} -n -f funclist.sed ../func.c > funclist.c
|
${Q}${SED} -n -f funclist.sed ../func.c > funclist.c
|
||||||
|
-${Q}rm -f funclist.o funclist
|
||||||
-${Q}rm -f ../funclist.c ../funclist.o ../funclist funclist
|
${Q}${LCC} ${ICFLAGS} -DFUNCLIST -I/usr/include -I.. funclist.c -c
|
||||||
${Q}cp funclist.c ..
|
${Q}${LCC} ${ILDFLAGS} funclist.o -o funclist
|
||||||
-${Q}(cd ..; \
|
-${Q}rm -f builtin
|
||||||
${NATIVE_CC} ${NATIVE_CFLAGS} -DFUNCLIST funclist.c -o funclist; \
|
${Q}cat builtin.top > builtin
|
||||||
mv funclist help; \
|
|
||||||
rm -f funclist.c funclist.o funclist)
|
|
||||||
${Q}./funclist | \
|
${Q}./funclist | \
|
||||||
${SED} -e 's/^/ /' -e 's/[ ][ ]*$$//' >> builtin
|
${SED} -e 's/^/ /' -e 's/[ ][ ]*$$//' >> builtin
|
||||||
${Q}cat builtin.end >> builtin
|
${Q}cat builtin.end >> builtin
|
||||||
@@ -393,15 +389,11 @@ builtin: builtin.top builtin.end ../func.c funclist.sed
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/help/$$i; \
|
echo help/$$i; \
|
||||||
done | ${SORT}
|
done | ${SORT}
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo help
|
||||||
bsdilist: ${DISTLIST} ${BLT_HELP_FILES}
|
|
||||||
${Q}for i in ${DISTLIST} ${BLT_HELP_FILES}; do \
|
|
||||||
echo calc/help/$$i; \
|
|
||||||
done | ${SORT}
|
|
||||||
|
|
||||||
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
# The BSDI cdrom makefile expects all help files to be pre-built. This rule
|
||||||
# creats these fils so that the release can be shipped off to BSDI. You can
|
# creats these fils so that the release can be shipped off to BSDI. You can
|
||||||
@@ -416,8 +408,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; \
|
||||||
|
@@ -11,6 +11,6 @@ Where to get the the latest versions of calc
|
|||||||
for information on how to obtain up a recent version of calc.
|
for information on how to obtain up a recent version of calc.
|
||||||
|
|
||||||
Landon Curt Noll
|
Landon Curt Noll
|
||||||
http://reality.sgi.com/chongo
|
http://reality.sgi.com/chongo/
|
||||||
|
|
||||||
chongo <was here> /\../\
|
chongo <was here> /\../\
|
||||||
|
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
|
65
help/config
65
help/config
@@ -40,8 +40,8 @@ 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" controls library script debug information
|
|
||||||
"calc_debug" controls internal calc debug information
|
"calc_debug" controls internal calc debug information
|
||||||
|
"lib_debug" controls library script 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
|
"verbose_quit" TRUE=>print message on empty quit or abort
|
||||||
|
|
||||||
@@ -317,29 +317,6 @@ Configuration parameters
|
|||||||
|
|
||||||
The default "blkfmt" is "hd".
|
The default "blkfmt" is "hd".
|
||||||
|
|
||||||
The "lib_debug" parameter is intended for controlling the possible
|
|
||||||
display of special information relating to functions, objects, and
|
|
||||||
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:
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
||||||
The "calc_debug" is intended for controlling internal calc routines
|
The "calc_debug" is intended for controlling internal calc routines
|
||||||
that test its operation, or collect or display information that
|
that test its operation, or collect or display information that
|
||||||
might be useful for debug purposes. Much of the output from these
|
might be useful for debug purposes. Much of the output from these
|
||||||
@@ -364,7 +341,42 @@ Configuration parameters
|
|||||||
block is not NULL, and that its "length" is not negative.
|
block is not NULL, and that its "length" is not negative.
|
||||||
A failure will result in a runtime error.
|
A failure will result in a runtime error.
|
||||||
|
|
||||||
Bits >= 4 are reserved for future use and should not be used at this time.
|
4 Report on changes to the state of stdin as well as changes
|
||||||
|
to internal variables that control the setting and restoring
|
||||||
|
of stdin.
|
||||||
|
|
||||||
|
5 Report on changes to the run state of calc.
|
||||||
|
|
||||||
|
Bits >= 6 are reserved for future use and should not be used at this time.
|
||||||
|
|
||||||
|
By default, "calc_debug" is 0. The initial value may be overridden
|
||||||
|
by the -D command line option.
|
||||||
|
|
||||||
|
The "lib_debug" parameter is intended for controlling the possible
|
||||||
|
display of special information relating to functions, objects, and
|
||||||
|
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:
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
By default, "lib_debug" is 3. The -d flag changes this default to 0.
|
||||||
|
The initial value may be overridden by the -D command line option.
|
||||||
|
|
||||||
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").
|
||||||
@@ -376,6 +388,9 @@ 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".
|
||||||
|
|
||||||
|
By default, "user_debug" is 0. The initial value may be overridden
|
||||||
|
by the -D command line option.
|
||||||
|
|
||||||
The "verbose_quit" controls the print of the message:
|
The "verbose_quit" controls the print of the message:
|
||||||
|
|
||||||
Quit or abort executed
|
Quit or abort executed
|
||||||
|
@@ -58,6 +58,6 @@ One may join the calc testing group by sending a request to:
|
|||||||
is your full name.
|
is your full name.
|
||||||
|
|
||||||
Landon Curt Noll
|
Landon Curt Noll
|
||||||
http://reality.sgi.com/chongo
|
http://reality.sgi.com/chongo/
|
||||||
|
|
||||||
chongo <was here> /\../\
|
chongo <was here> /\../\
|
||||||
|
@@ -58,6 +58,10 @@ Environment variables
|
|||||||
a terminal, then calc will still run, but fancy command line
|
a terminal, then calc will still run, but fancy command line
|
||||||
editing is disabled.
|
editing is disabled.
|
||||||
|
|
||||||
|
NOTE: If calc was compiled with GNU-readline support, the
|
||||||
|
CALCBINDINGS facility is ignored and the standard
|
||||||
|
readline mechanisms (see readline(3)) are used.
|
||||||
|
|
||||||
HOME
|
HOME
|
||||||
|
|
||||||
This value is taken to be the home directory of the
|
This value is taken to be the home directory of the
|
||||||
|
@@ -3,7 +3,5 @@ s/NUMBER[ ]*\*/int /
|
|||||||
s/NUMBER/int/
|
s/NUMBER/int/
|
||||||
s/STRINGHEAD/int/
|
s/STRINGHEAD/int/
|
||||||
s/\(".*",.*,.*\),.*,.*,.*,.*,/\1, 0, 0, 0, 0,/
|
s/\(".*",.*,.*\),.*,.*,.*,.*,/\1, 0, 0, 0, 0,/
|
||||||
/sed me out/d
|
|
||||||
s/showbuiltins/main/
|
|
||||||
s/[ ][ ]*$//
|
s/[ ][ ]*$//
|
||||||
p
|
p
|
||||||
|
@@ -15,12 +15,12 @@ DESCRIPTION
|
|||||||
The basis of this hash algorithm was taken from an idea sent
|
The basis of this hash algorithm was taken from an idea sent
|
||||||
as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
||||||
|
|
||||||
Phong Vo (http://www.research.att.com/info/kpv)
|
Phong Vo (http://www.research.att.com/info/kpv/)
|
||||||
Glenn Fowler (http://www.research.att.com/~gsf/)
|
Glenn Fowler (http://www.research.att.com/~gsf/)
|
||||||
|
|
||||||
In a subsequent ballot round:
|
In a subsequent ballot round:
|
||||||
|
|
||||||
Landon Curt Noll (http://reality.sgi.com/chongo)
|
Landon Curt Noll (http://reality.sgi.com/chongo/)
|
||||||
|
|
||||||
improved on their algorithm. Some people tried this hash
|
improved on their algorithm. Some people tried this hash
|
||||||
and found that it worked rather well. In an EMail message
|
and found that it worked rather well. In an EMail message
|
||||||
|
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
|
@@ -19,9 +19,9 @@ DESCRIPTION
|
|||||||
is almost certainly non-chaotic. This function is likely not
|
is almost certainly non-chaotic. This function is likely not
|
||||||
suitable for applications (such as cryptographic applications)
|
suitable for applications (such as cryptographic applications)
|
||||||
where the unpredictability of seeds is critical. For such critical
|
where the unpredictability of seeds is critical. For such critical
|
||||||
applications, lavarand should be used. Seed:
|
applications, lavarand should be used. See the URL:
|
||||||
|
|
||||||
http://lavarand.sgi.com
|
http://lavarand.sgi.com/index.html
|
||||||
|
|
||||||
for information about seeding a pseudo-random number generator
|
for information about seeding a pseudo-random number generator
|
||||||
(such as rand() or random()) with the cryptographic hash of the
|
(such as rand() or random()) with the cryptographic hash of the
|
||||||
|
@@ -222,8 +222,7 @@ DESCRIPTION
|
|||||||
The pre-defined Blum moduli and quadratic residues were selected
|
The pre-defined Blum moduli and quadratic residues were selected
|
||||||
by lavarand, a hardware random number generator. See the URL:
|
by lavarand, a hardware random number generator. See the URL:
|
||||||
|
|
||||||
http://lavarand.sgi.com
|
http://lavarand.sgi.com/index.html
|
||||||
XXX - This URL is not available on 17Feb97 ... but will be soon.
|
|
||||||
|
|
||||||
for an explanation of how the lavarand random number generator works.
|
for an explanation of how the lavarand random number generator works.
|
||||||
For more information, see the comments at the top of the calc
|
For more information, see the comments at the top of the calc
|
||||||
|
11
help/todo
11
help/todo
@@ -13,8 +13,6 @@ 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.
|
||||||
@@ -52,6 +50,8 @@ Very High priority items:
|
|||||||
* 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'.
|
||||||
|
|
||||||
|
* Copyleft calc and place it under a LGPL.
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
High priority items:
|
High priority items:
|
||||||
@@ -81,10 +81,9 @@ High priority items:
|
|||||||
then a $PAGER should be forked and execed after doing things such
|
then a $PAGER should be forked and execed after doing things such
|
||||||
as closing open file descriptors that the $PAGER does not need.
|
as closing open file descriptors that the $PAGER does not need.
|
||||||
|
|
||||||
* Inspect changes made since the last major calc release (the
|
* The arg passdown to the lower level Makfiles should be reviewed
|
||||||
initial x.y.z version ... prior to any t sub-version) to help
|
to determine which items really need to be passed down. The lower
|
||||||
ensure that they have not introduced new or re-introduced old bugs
|
level Makefiles should default to the shipped values.
|
||||||
into calc.
|
|
||||||
|
|
||||||
* Consider using configure to build the calc Makefile.
|
* Consider using configure to build the calc Makefile.
|
||||||
|
|
||||||
|
20
help/usage
20
help/usage
@@ -2,8 +2,8 @@ Calc command line
|
|||||||
|
|
||||||
Calc has the following command line:
|
Calc has the following command line:
|
||||||
|
|
||||||
calc [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]
|
calc [-c] [-C] [-d] [-D calc_debug[:lib_debug:[user_debug]]]
|
||||||
[-n] [-p] [-q] [-u] [-v] [calc_cmd ...]
|
[-e] [-h] [-i] [-m mode] [-n] [-p] [-q] [-u] [-v] [calc_cmd ...]
|
||||||
|
|
||||||
-c Continue reading command lines even after an execution
|
-c Continue reading command lines even after an execution
|
||||||
error has caused the abandonment of a line.
|
error has caused the abandonment of a line.
|
||||||
@@ -55,6 +55,22 @@ Calc command line
|
|||||||
This flag disables the reporting of missing calc
|
This flag disables the reporting of missing calc
|
||||||
startup scripts ($CALCRC).
|
startup scripts ($CALCRC).
|
||||||
|
|
||||||
|
-D calc_debug[:lib_debug:[user_debug]]
|
||||||
|
|
||||||
|
Force the initial value of config("calc_debug"),
|
||||||
|
config("lib_debug") and config("user_debug").
|
||||||
|
|
||||||
|
The : separated strings are interpreted as signed 32 bit values.
|
||||||
|
After an optional leading sign a leading zero indicates octal
|
||||||
|
conversion, and a leading ``0x'' or ``0X'' hexadecimal
|
||||||
|
conversion. Otherwise, decimal conversion is assumed.
|
||||||
|
|
||||||
|
By default, calc_debug is 0, lib_debug is 3 and lib_debug is 0.
|
||||||
|
|
||||||
|
For more information use the following calc command:
|
||||||
|
|
||||||
|
help config
|
||||||
|
|
||||||
-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.
|
||||||
|
|
||||||
|
181
hist.c
181
hist.c
@@ -5,6 +5,8 @@
|
|||||||
*
|
*
|
||||||
* Adapted from code written by Stephen Rothwell.
|
* Adapted from code written by Stephen Rothwell.
|
||||||
*
|
*
|
||||||
|
* GNU readline support added by Martin Buck <mbuck@debian.org>
|
||||||
|
*
|
||||||
* Interactive readline module. This is called to read lines of input,
|
* Interactive readline module. This is called to read lines of input,
|
||||||
* while using emacs-like editing commands within a command stack.
|
* while using emacs-like editing commands within a command stack.
|
||||||
* The key bindings for the editing commands are (slightly) configurable.
|
* The key bindings for the editing commands are (slightly) configurable.
|
||||||
@@ -29,6 +31,11 @@
|
|||||||
#include "terminal.h"
|
#include "terminal.h"
|
||||||
#include "have_string.h"
|
#include "have_string.h"
|
||||||
|
|
||||||
|
#include "have_strdup.h"
|
||||||
|
#if !defined(HAVE_STRDUP)
|
||||||
|
# define strdup(x) calc_strdup((CONST char *)(x))
|
||||||
|
#endif /* HAVE_STRDUP */
|
||||||
|
|
||||||
|
|
||||||
#if defined(USE_TERMIOS)
|
#if defined(USE_TERMIOS)
|
||||||
# include <termios.h>
|
# include <termios.h>
|
||||||
@@ -48,6 +55,8 @@
|
|||||||
# include <string.h>
|
# include <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(USE_READLINE)
|
||||||
|
|
||||||
extern FILE *curstream(void);
|
extern FILE *curstream(void);
|
||||||
|
|
||||||
#define STDIN 0
|
#define STDIN 0
|
||||||
@@ -283,11 +292,16 @@ hist_init(char *filename)
|
|||||||
{
|
{
|
||||||
TTYSTRUCT newtty;
|
TTYSTRUCT newtty;
|
||||||
|
|
||||||
if (inited)
|
if (inited) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: inited already set in hist_init\n");
|
||||||
return HIST_INITED;
|
return HIST_INITED;
|
||||||
|
}
|
||||||
|
|
||||||
inited = 1;
|
inited = 1;
|
||||||
canedit = 0;
|
canedit = 0;
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Set inited, cleared canedit in hist_init\n");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* open the bindings file
|
* open the bindings file
|
||||||
@@ -309,20 +323,31 @@ hist_init(char *filename)
|
|||||||
closeinput();
|
closeinput();
|
||||||
|
|
||||||
#ifdef USE_SGTTY
|
#ifdef USE_SGTTY
|
||||||
if (ioctl(STDIN, TIOCGETP, &oldtty) < 0)
|
if (ioctl(STDIN, TIOCGETP, &oldtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot TIOCGETP stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
|
||||||
newtty = oldtty;
|
newtty = oldtty;
|
||||||
newtty.sg_flags &= ~ECHO;
|
newtty.sg_flags &= ~ECHO;
|
||||||
newtty.sg_flags |= CBREAK;
|
newtty.sg_flags |= CBREAK;
|
||||||
|
|
||||||
if (ioctl(STDIN, TIOCSETP, &newtty) < 0)
|
if (ioctl(STDIN, TIOCSETP, &newtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot TIOCSETP stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: stty -ECHO +CBREAK in hist_init\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_TERMIO
|
#ifdef USE_TERMIO
|
||||||
if (ioctl(STDIN, TCGETA, &oldtty) < 0)
|
if (ioctl(STDIN, TCGETA, &oldtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot TCGETA stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
|
||||||
newtty = oldtty;
|
newtty = oldtty;
|
||||||
newtty.c_lflag &= ~(ECHO | ECHOE | ECHOK);
|
newtty.c_lflag &= ~(ECHO | ECHOE | ECHOK);
|
||||||
@@ -331,13 +356,22 @@ hist_init(char *filename)
|
|||||||
newtty.c_cc[VMIN] = 1;
|
newtty.c_cc[VMIN] = 1;
|
||||||
newtty.c_cc[VTIME] = 0;
|
newtty.c_cc[VTIME] = 0;
|
||||||
|
|
||||||
if (ioctl(STDIN, TCSETAW, &newtty) < 0)
|
if (ioctl(STDIN, TCSETAW, &newtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot TCSETAW stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: stty -ECHO -ECHOE -ECHOK -ICANON +ISTRIP "
|
||||||
|
"VMIN=1 VTIME=0 in hist_init\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_TERMIOS
|
#ifdef USE_TERMIOS
|
||||||
if (tcgetattr(STDIN, &oldtty) < 0)
|
if (tcgetattr(STDIN, &oldtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot tcgetattr stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
|
||||||
newtty = oldtty;
|
newtty = oldtty;
|
||||||
newtty.c_lflag &= ~(ECHO | ECHOE | ECHOK);
|
newtty.c_lflag &= ~(ECHO | ECHOE | ECHOK);
|
||||||
@@ -346,11 +380,19 @@ hist_init(char *filename)
|
|||||||
newtty.c_cc[VMIN] = 1;
|
newtty.c_cc[VMIN] = 1;
|
||||||
newtty.c_cc[VTIME] = 0;
|
newtty.c_cc[VTIME] = 0;
|
||||||
|
|
||||||
if (tcsetattr(STDIN, TCSANOW, &newtty) < 0)
|
if (tcsetattr(STDIN, TCSANOW, &newtty) < 0) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cannot tcsetattr stdin in hist_init\n");
|
||||||
return HIST_NOTTY;
|
return HIST_NOTTY;
|
||||||
|
}
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: stty -ECHO -ECHOE -ECHOK -ICANON +ISTRIP "
|
||||||
|
"VMIN=1 VTIME=0 in hist_init\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
canedit = 1;
|
canedit = 1;
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Set canedit in hist_init\n");
|
||||||
|
|
||||||
return HIST_SUCCESS;
|
return HIST_SUCCESS;
|
||||||
}
|
}
|
||||||
@@ -363,20 +405,36 @@ void
|
|||||||
hist_term(void)
|
hist_term(void)
|
||||||
{
|
{
|
||||||
if (!inited || !canedit) {
|
if (!inited || !canedit) {
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY) {
|
||||||
|
if (!inited)
|
||||||
|
printf("DEBUG: inited already cleared "
|
||||||
|
"in hist_term\n");
|
||||||
|
if (!canedit)
|
||||||
|
printf("DEBUG: canedit already cleared "
|
||||||
|
"in hist_term\n");
|
||||||
|
}
|
||||||
inited = 0;
|
inited = 0;
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: Cleared inited in hist_term\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_SGTTY
|
#ifdef USE_SGTTY
|
||||||
(void) ioctl(STDIN, TIOCSETP, &oldtty);
|
(void) ioctl(STDIN, TIOCSETP, &oldtty);
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: TIOCSETP restored stdin in hist_term\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_TERMIO
|
#ifdef USE_TERMIO
|
||||||
(void) ioctl(STDIN, TCSETAW, &oldtty);
|
(void) ioctl(STDIN, TCSETAW, &oldtty);
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: TCSETAW restored stdin in hist_term\n");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_TERMIOS
|
#ifdef USE_TERMIOS
|
||||||
(void) tcsetattr(STDIN, TCSANOW, &oldtty);
|
(void) tcsetattr(STDIN, TCSANOW, &oldtty);
|
||||||
|
if (conf->calc_debug & CALCDBG_TTY)
|
||||||
|
printf("DEBUG: TCSANOW restored stdin in hist_term\n");
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1384,8 +1442,112 @@ quit_calc(void)
|
|||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else /* USE_READLINE */
|
||||||
|
|
||||||
#ifdef HIST_TEST
|
|
||||||
|
#define HISTORY_LEN (1024) /* number of entries to save */
|
||||||
|
|
||||||
|
|
||||||
|
#include <readline/readline.h>
|
||||||
|
#include <readline/history.h>
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The readline/history libs do most of the dirty work for us, so we can
|
||||||
|
* replace hist_init() and hist_term() with dummies when using readline.
|
||||||
|
* For hist_getline() we have to add a newline that readline removed but
|
||||||
|
* calc expects. For hist_saveline(), we have to undo this. hist_getline()
|
||||||
|
* also has to cope with the different memory management schemes of calc and
|
||||||
|
* readline.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* name of history file */
|
||||||
|
char *my_calc_history = NULL;
|
||||||
|
|
||||||
|
int
|
||||||
|
hist_getline(char *prompt, char *buf, int len)
|
||||||
|
{
|
||||||
|
char *line;
|
||||||
|
|
||||||
|
buf[0] = '\0';
|
||||||
|
line = readline(prompt);
|
||||||
|
if (!line)
|
||||||
|
return 0;
|
||||||
|
strncpy(buf, line, len - 1);
|
||||||
|
buf[len - 2] = '\0';
|
||||||
|
len = strlen(buf);
|
||||||
|
buf[len] = '\n';
|
||||||
|
buf[len + 1] = '\0';
|
||||||
|
free(line);
|
||||||
|
return len + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
hist_term(void)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
my_stifle_history (void)
|
||||||
|
{
|
||||||
|
/* only save last number of entries */
|
||||||
|
stifle_history(HISTORY_LEN);
|
||||||
|
|
||||||
|
if (my_calc_history)
|
||||||
|
write_history(my_calc_history);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
hist_init(char *filename)
|
||||||
|
{
|
||||||
|
/* used when parsing conditionals in ~/.inputrc */
|
||||||
|
rl_readline_name = "calc";
|
||||||
|
|
||||||
|
/* initialize interactive variables */
|
||||||
|
using_history();
|
||||||
|
|
||||||
|
/* name of history file */
|
||||||
|
my_calc_history = tilde_expand("~/.calc_history");
|
||||||
|
|
||||||
|
/* read previous history */
|
||||||
|
read_history(my_calc_history);
|
||||||
|
|
||||||
|
atexit(my_stifle_history);
|
||||||
|
|
||||||
|
return HIST_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
hist_saveline(char *line, int len)
|
||||||
|
{
|
||||||
|
static char *prev = NULL;
|
||||||
|
|
||||||
|
if (!len)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* ignore if identical with previous line */
|
||||||
|
if (prev != NULL && strcmp(prev, line) == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
free (prev);
|
||||||
|
|
||||||
|
/* fail silently */
|
||||||
|
prev = strdup(line);
|
||||||
|
|
||||||
|
line[len - 1] = '\0';
|
||||||
|
add_history(line);
|
||||||
|
line[len - 1] = '\n';
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* USE_READLINE */
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(HIST_TEST)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Main routine to test history.
|
* Main routine to test history.
|
||||||
@@ -1426,6 +1588,5 @@ main(int argc, char **argv)
|
|||||||
hist_term();
|
hist_term();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/* END CODE */
|
#endif /* HIST_TEST */
|
||||||
|
10
lib/Makefile
10
lib/Makefile
@@ -73,15 +73,11 @@ all: ${CALC_FILES} ${MAKE_FILE} .all
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/lib/$$i; \
|
echo lib/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo lib
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/lib/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
|
|
||||||
|
12
lib/README
12
lib/README
@@ -273,10 +273,18 @@ pell.cal
|
|||||||
pi.cal
|
pi.cal
|
||||||
|
|
||||||
qpi(epsilon)
|
qpi(epsilon)
|
||||||
|
piforever()
|
||||||
|
|
||||||
Calculate pi within the specified epsilon using the quartic convergence
|
The qpi() calculate pi within the specified epsilon using the quartic
|
||||||
iteration.
|
convergence iteration.
|
||||||
|
|
||||||
|
The piforever() prints digits of pi, nicely formatted, for as long
|
||||||
|
as your free memory space and system up time allows.
|
||||||
|
|
||||||
|
The piforever() funcion (written by Klaus Alexander Seistrup
|
||||||
|
<klaus@seistrup.dk>) was inspired by an algorithm conceived by
|
||||||
|
Lambert Meertens. See also the ABC Programmer's Handbook, by Geurts,
|
||||||
|
Meertens & Pemberton, published by Prentice-Hall (UK) Ltd., 1990.
|
||||||
|
|
||||||
pix.cal
|
pix.cal
|
||||||
|
|
||||||
|
@@ -1,4 +1,8 @@
|
|||||||
# Alternate key bindings for calc line editing functions
|
# Alternate key bindings for calc line editing functions
|
||||||
|
#
|
||||||
|
# NOTE: This facility is ignored if calc was compiled with GNU-readline.
|
||||||
|
# In that case, the standard readline mechanisms (see readline(3))
|
||||||
|
# are used in place of those found below.
|
||||||
|
|
||||||
map base-map
|
map base-map
|
||||||
default insert-char
|
default insert-char
|
||||||
|
@@ -1,4 +1,8 @@
|
|||||||
# Default key bindings for calc line editing functions
|
# Default key bindings for calc line editing functions
|
||||||
|
#
|
||||||
|
# NOTE: This facility is ignored if calc was compiled with GNU-readline.
|
||||||
|
# In that case, the standard readline mechanisms (see readline(3))
|
||||||
|
# are used in place of those found below.
|
||||||
|
|
||||||
map base-map
|
map base-map
|
||||||
default insert-char
|
default insert-char
|
||||||
|
@@ -86,7 +86,7 @@
|
|||||||
* i.e., any value that is 301 mod 420.
|
* i.e., any value that is 301 mod 420.
|
||||||
*
|
*
|
||||||
* Written by: Ernest W Bowen <ernie@neumann.une.edu.au>
|
* Written by: Ernest W Bowen <ernie@neumann.une.edu.au>
|
||||||
* Interface by: Landon Curt Noll http://reality.sgi.com/chongo
|
* Interface by: Landon Curt Noll http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static defaultmlist = list(2,3,5,7,11,13,17,19); /* The first eight primes */
|
static defaultmlist = list(2,3,5,7,11,13,17,19); /* The first eight primes */
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
72
lib/pi.cal
72
lib/pi.cal
@@ -47,3 +47,75 @@ define qpi(epsilon)
|
|||||||
}
|
}
|
||||||
return (bround(1/an, bits));
|
return (bround(1/an, bits));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Print digits of PI forever, neatly formatted, using calc.
|
||||||
|
*
|
||||||
|
* Written by Klaus Alexander Seistrup <klaus@seistrup.dk>
|
||||||
|
* on a dull Friday evening in November 1999.
|
||||||
|
*
|
||||||
|
* Inspired by an algorithm conceived by Lambert Meertens.
|
||||||
|
*
|
||||||
|
* See also the ABC Programmer's Handbook, by Geurts, Meertens & Pemberton,
|
||||||
|
* published by Prentice-Hall (UK) Ltd., 1990.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
define piforever()
|
||||||
|
{
|
||||||
|
local k = 2;
|
||||||
|
local a = 4;
|
||||||
|
local b = 1;
|
||||||
|
local a1 = 12;
|
||||||
|
local b1 = 4;
|
||||||
|
local a2, b2, p, q, d, d1;
|
||||||
|
local stdout = files(1);
|
||||||
|
local first = 1, row = -1, col = 0;
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
/*
|
||||||
|
* Next approximation
|
||||||
|
*/
|
||||||
|
p = k * k;
|
||||||
|
q = k + k++;
|
||||||
|
|
||||||
|
a2 = a;
|
||||||
|
b2 = b;
|
||||||
|
|
||||||
|
a = a1;
|
||||||
|
a1 = p * a2 + q * a1;
|
||||||
|
b = b1;
|
||||||
|
b1 = p * b2 + q * b1;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Print common digits
|
||||||
|
*/
|
||||||
|
d = a // b;
|
||||||
|
d1 = a1 // b1;
|
||||||
|
|
||||||
|
while (d == d1) {
|
||||||
|
if (first) {
|
||||||
|
printf("%d.", d);
|
||||||
|
first = 0;
|
||||||
|
} else {
|
||||||
|
if (!(col % 50)) {
|
||||||
|
printf("\n");
|
||||||
|
col = 0;
|
||||||
|
if (!(++row % 20)) {
|
||||||
|
printf("\n");
|
||||||
|
row = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf("%d", d);
|
||||||
|
if (!(++col % 10))
|
||||||
|
printf(" ");
|
||||||
|
}
|
||||||
|
a = 10 * (a % b);
|
||||||
|
a1 = 10 * (a1 % b1);
|
||||||
|
d = a // b;
|
||||||
|
d1 = a1 // b1;
|
||||||
|
}
|
||||||
|
fflush(stdout);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@@ -7,7 +7,7 @@
|
|||||||
* utc_hr_offset Offset from UTC in hours.
|
* utc_hr_offset Offset from UTC in hours.
|
||||||
*
|
*
|
||||||
* Written by: Klaus Alexander Seistrup <kseis@magnetic-ink.dk>
|
* Written by: Klaus Alexander Seistrup <kseis@magnetic-ink.dk>
|
||||||
* With minor mods by: Landon Curt Noll <http://reality.sgi.com/chongo>
|
* With minor mods by: Landon Curt Noll <http://reality.sgi.com/chongo/>
|
||||||
*
|
*
|
||||||
* See:
|
* See:
|
||||||
* http://www.magnetic-ink.dk/download/qtime.html
|
* http://www.magnetic-ink.dk/download/qtime.html
|
||||||
|
@@ -22,7 +22,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -20,18 +20,17 @@ print '002: Within each section, output should be numbered sequentially';
|
|||||||
global prob; /* libregress.cal problem counter */
|
global prob; /* libregress.cal problem counter */
|
||||||
prob = 0; /* clear problem counter */
|
prob = 0; /* clear problem counter */
|
||||||
|
|
||||||
global junk; /* throw away value */
|
errcount(0),; /* clear error count */
|
||||||
junk = errcount(0); /* clear error count */
|
errmax(-1),; /* prevent errcount from abouting */
|
||||||
junk = errmax(-1); /* prevent errcount from abouting */
|
|
||||||
|
|
||||||
global ecnt; /* expected value of errcount() */
|
global ecnt; /* expected value of errcount() */
|
||||||
ecnt = 0; /* clear expected errcount() value */
|
ecnt = 0; /* clear expected errcount() value */
|
||||||
|
|
||||||
initcfg = config("all", "oldstd"); /* set config to startup default */
|
initcfg = config("all", "oldstd"); /* set config to startup default */
|
||||||
initcfg = config("lib_debug", 0); /* disable lib startup messages */
|
config("lib_debug", 0),; /* disable lib startup messages */
|
||||||
initcfg = config("calc_debug", 0); /* disable internal debugging */
|
config("calc_debug", 0),; /* disable internal debugging */
|
||||||
initcnf = config("verbose_quit", 0); /* disable quit messages */
|
config("verbose_quit", 0),; /* disable quit messages */
|
||||||
initcfg = config("all"); /* save state for later use */
|
startcfg = config("all"); /* save state for later use */
|
||||||
|
|
||||||
print '003: parsed global definitions';
|
print '003: parsed global definitions';
|
||||||
|
|
||||||
@@ -292,7 +291,7 @@ define test_arithmetic()
|
|||||||
vrfy(8/4==2, '404: 8 / 4 == 2');
|
vrfy(8/4==2, '404: 8 / 4 == 2');
|
||||||
vrfy(2^3==8, '405: 2 ^ 3 == 8');
|
vrfy(2^3==8, '405: 2 ^ 3 == 8');
|
||||||
vrfy(9-4-2==3, '406: 9-4-2 == 3');
|
vrfy(9-4-2==3, '406: 9-4-2 == 3');
|
||||||
vrfy(9-4+2==7, '407: 9-4+2 == 6');
|
vrfy(9-4+2==7, '407: 9-4+2 == 7');
|
||||||
vrfy(-5+2==-3, '408: -5+2 == -3');
|
vrfy(-5+2==-3, '408: -5+2 == -3');
|
||||||
vrfy(2*3+1==7, '409: 2*3+1 == 7');
|
vrfy(2*3+1==7, '409: 2*3+1 == 7');
|
||||||
vrfy(1+2*3==7, '410: 1+2*3 == 7');
|
vrfy(1+2*3==7, '410: 1+2*3 == 7');
|
||||||
@@ -359,7 +358,7 @@ define test_config()
|
|||||||
print '502: callcfg = config("all","oldstd")';
|
print '502: callcfg = config("all","oldstd")';
|
||||||
oldcfg = config("all", "newstd");
|
oldcfg = config("all", "newstd");
|
||||||
print '503: oldcfg = config("all","newstd")';
|
print '503: oldcfg = config("all","newstd")';
|
||||||
vrfy(callcfg == initcfg, '504: callcfg == initcfg');
|
vrfy(callcfg == startcfg, '504: callcfg == startcfg');
|
||||||
newcfg = config("all");
|
newcfg = config("all");
|
||||||
print '505: newcfg = config("all")';
|
print '505: newcfg = config("all")';
|
||||||
vrfy(config("all") == newcfg, '506: config("all") == newcfg');
|
vrfy(config("all") == newcfg, '506: config("all") == newcfg');
|
||||||
@@ -457,7 +456,7 @@ define test_config()
|
|||||||
vrfy(config("all",callcfg) == oldcfg,
|
vrfy(config("all",callcfg) == oldcfg,
|
||||||
'550: config("all",callcfg) == oldcfg');
|
'550: config("all",callcfg) == oldcfg');
|
||||||
vrfy(config("all") == callcfg, '551: config("all") == callcfg');
|
vrfy(config("all") == callcfg, '551: config("all") == callcfg');
|
||||||
vrfy(config("all") == initcfg, '552: config("all") == initcfg');
|
vrfy(config("all") == startcfg, '552: config("all") == startcfg');
|
||||||
|
|
||||||
print '553: Ending test_config';
|
print '553: Ending test_config';
|
||||||
}
|
}
|
||||||
@@ -965,7 +964,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');
|
||||||
@@ -1695,6 +1694,7 @@ define test_obj()
|
|||||||
{
|
{
|
||||||
static obj surd a;
|
static obj surd a;
|
||||||
static obj surd b;
|
static obj surd b;
|
||||||
|
local PP;
|
||||||
|
|
||||||
print '1800: Beginning object test';
|
print '1800: Beginning object test';
|
||||||
|
|
||||||
@@ -1732,7 +1732,10 @@ define test_obj()
|
|||||||
vrfy(a <= a, '1828: a < a');
|
vrfy(a <= a, '1828: a < a');
|
||||||
vrfy(isobj(a) == 1, '1829: isobj(a) == 1');
|
vrfy(isobj(a) == 1, '1829: isobj(a) == 1');
|
||||||
|
|
||||||
print '1830: Ending object test';
|
obj pt {x,y}, PP = obj pair {A,B} = {obj pt, obj pt};
|
||||||
|
print '1830: obj pt {x,y}, PP = obj pair {A,B} = {obj pt, obj pt}';
|
||||||
|
|
||||||
|
print '1831: Ending object test';
|
||||||
}
|
}
|
||||||
print '028: parsed test_obj()';
|
print '028: parsed test_obj()';
|
||||||
|
|
||||||
@@ -2868,7 +2871,7 @@ print '053: parsed test_frem()';
|
|||||||
*/
|
*/
|
||||||
define test_error()
|
define test_error()
|
||||||
{
|
{
|
||||||
local strx, e99, list1, e999;
|
local strx, e99, list1, e9999;
|
||||||
local a, b, c, n, x; /* used by newerror() */
|
local a, b, c, n, x; /* used by newerror() */
|
||||||
|
|
||||||
print '3600: Beginning test_error';
|
print '3600: Beginning test_error';
|
||||||
@@ -3041,11 +3044,12 @@ define test_error()
|
|||||||
'3710: newerror() == newerror("???")');
|
'3710: newerror() == newerror("???")');
|
||||||
vrfy(newerror("") == newerror(),
|
vrfy(newerror("") == newerror(),
|
||||||
'3711: newerror("") == newerror()');
|
'3711: newerror("") == newerror()');
|
||||||
e999 = error(999);
|
e9999 = error(9999);
|
||||||
print '3712: e999 = error(999)';
|
print '3712: e9999 = error(9999)';
|
||||||
vrfy(errno() == 999, '3713: errno() == 999');
|
vrfy(errno() == 9999, '3713: errno() == 9999');
|
||||||
vrfy(error() == e999, '3714: error() == e999');
|
vrfy(error() == e9999, '3714: error() == e9999');
|
||||||
vrfy(strerror() == "Error 999", '3715: strerror() == "Error 999"');
|
vrfy(strerror() == "Unknown error 9999",
|
||||||
|
'3715: strerror() == "Unknown error 9999"');
|
||||||
x = newerror("Alpha");
|
x = newerror("Alpha");
|
||||||
print '3716: x = newerror("Alpha")';
|
print '3716: x = newerror("Alpha")';
|
||||||
n = iserror(x);
|
n = iserror(x);
|
||||||
@@ -3053,10 +3057,11 @@ define test_error()
|
|||||||
vrfy(errno() == n, '3718: errno() == n');
|
vrfy(errno() == n, '3718: errno() == n');
|
||||||
vrfy(error() == x, '3719: error() == x');
|
vrfy(error() == x, '3719: error() == x');
|
||||||
vrfy(strerror() == "Alpha", '3720: strerror() == "Alpha"');
|
vrfy(strerror() == "Alpha", '3720: strerror() == "Alpha"');
|
||||||
vrfy(errno(999) == n, '3721: errno() == n');
|
vrfy(errno(9999) == n, '3721: errno() == n');
|
||||||
vrfy(errno() == 999, '3722: errno() == 999');
|
vrfy(errno() == 9999, '3722: errno() == 9999');
|
||||||
vrfy(error() == e999, '3723: error() == e999');
|
vrfy(error() == e9999, '3723: error() == e9999');
|
||||||
vrfy(strerror() == "Error 999", '3724: strerror() == "Error 999"');
|
vrfy(strerror() == "Unknown error 9999",
|
||||||
|
'3724: strerror() == "Unknown error 9999"');
|
||||||
a = 1/0;
|
a = 1/0;
|
||||||
print '3725: a = 1/0';
|
print '3725: a = 1/0';
|
||||||
vrfy(strerror() == "Division by zero",
|
vrfy(strerror() == "Division by zero",
|
||||||
@@ -4688,8 +4693,8 @@ define test_commaeq()
|
|||||||
/*
|
/*
|
||||||
* matrix assignment
|
* matrix assignment
|
||||||
*/
|
*/
|
||||||
mat A[3] = {1,2,3}, B[2] = {1,2};
|
mat A[3] = {1,2,3}, mat B[2] = {1,2};
|
||||||
print '5625: mat A[3] = {1,2,3}, B[2] = {1,2}';
|
print '5625: mat A[3] = {1,2,3}, mat B[2] = {1,2}';
|
||||||
vrfy(A[0] == 1, '5626: A[0] == 1');
|
vrfy(A[0] == 1, '5626: A[0] == 1');
|
||||||
vrfy(B[1] == 2, '5627: B[1] == 2');
|
vrfy(B[1] == 2, '5627: B[1] == 2');
|
||||||
|
|
||||||
@@ -4917,8 +4922,8 @@ define test_assign(base, work)
|
|||||||
print base+3: ': X5800 = base+3';
|
print base+3: ': X5800 = base+3';
|
||||||
Y5800 = base+4;
|
Y5800 = base+4;
|
||||||
print base+4: ': Y5800 = base+4';
|
print base+4: ': Y5800 = base+4';
|
||||||
obj xy5800 A={1,2}, B={3,4};
|
obj xy5800 A={1,2}, obj xy5800 B={3,4};
|
||||||
print base+5: ': obj xy5800 A={1,2}, B={3,4}';
|
print base+5: ': obj xy5800 A={1,2}, obj xy5000 B={3,4}';
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* test assignment
|
* test assignment
|
||||||
@@ -5107,7 +5112,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';
|
||||||
@@ -7121,9 +7126,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';
|
||||||
|
|
||||||
@@ -7155,9 +7162,18 @@ define test_somenew()
|
|||||||
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()';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -7165,6 +7181,9 @@ print '189: parsed test_somenew()';
|
|||||||
*/
|
*/
|
||||||
define test_quit()
|
define test_quit()
|
||||||
{
|
{
|
||||||
|
local x8400 = 23209; /* watch for lost memory */
|
||||||
|
static s8400 = 21701; /* watch for lost memory */
|
||||||
|
|
||||||
print '8400: Starting test_quit';
|
print '8400: Starting test_quit';
|
||||||
|
|
||||||
quit;
|
quit;
|
||||||
@@ -7172,7 +7191,7 @@ define test_quit()
|
|||||||
|
|
||||||
/* 8400 serise continued after return, do not print end here */
|
/* 8400 serise continued after return, do not print end here */
|
||||||
}
|
}
|
||||||
print '190: parsed test_quit()';
|
print '191: parsed test_quit()';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -7359,7 +7378,7 @@ vrfy(X5800 == (obj xy5800 = {3,9}),
|
|||||||
'5859: X5800 == (obj xy5800 = {3,9})');
|
'5859: X5800 == (obj xy5800 = {3,9})');
|
||||||
vrfy(errno() > 0, '5860: errno() > 0');
|
vrfy(errno() > 0, '5860: errno() > 0');
|
||||||
vrfy(strerror() == "Incompatible types for =",
|
vrfy(strerror() == "Incompatible types for =",
|
||||||
'5861: strerror() == "Incompatible types for ="');
|
'5861: strerror() == "Incompatible types for ="');
|
||||||
X5800 = 2;
|
X5800 = 2;
|
||||||
print '5862: X5800 = 2';
|
print '5862: X5800 = 2';
|
||||||
vrfy(X5800 == (obj xy5800 = {2,0}),
|
vrfy(X5800 == (obj xy5800 = {2,0}),
|
||||||
@@ -7368,7 +7387,10 @@ X5800 = obj xy5800 = {1,2};
|
|||||||
print '5864: X5800 = obj xy5800 = {1,2}';
|
print '5864: X5800 = obj xy5800 = {1,2}';
|
||||||
vrfy(X5800 == (obj xy5800 = {1,2}),
|
vrfy(X5800 == (obj xy5800 = {1,2}),
|
||||||
'5865: X5800 == (obj xy5800 = {1,2})');
|
'5865: X5800 == (obj xy5800 = {1,2})');
|
||||||
print '5866: End of 5800 sequence';
|
define f5800(a8500 = mat[2] = {3,4}) = 5 * a8500;
|
||||||
|
print '5866: define f5800(a8500 = mat[2] = {3,4}) = 5 * a8500;'
|
||||||
|
vrfy(f5800() == (mat[] = {15,20}),'5867: f5800() == (mat[] = {15,20})');
|
||||||
|
print '5868: End of 5800 sequence';
|
||||||
|
|
||||||
print;
|
print;
|
||||||
return test_is();
|
return test_is();
|
||||||
@@ -7464,8 +7486,9 @@ print '8310: Ending define tests';
|
|||||||
print;
|
print;
|
||||||
return test_quit();
|
return test_quit();
|
||||||
read -once test8400;
|
read -once test8400;
|
||||||
print '8402: read -once test8400';
|
print '8404: read -once test8400';
|
||||||
print '8403: Ending test_quit';
|
vrfy(test8400() == 64434, '8405: test8400() == 64434');
|
||||||
|
print '8406: Ending test_quit';
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Landon Curt Noll
|
* By: Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Landon Curt Noll
|
* By: Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 2600 series of the regress.cal test suite.
|
* This library is used by the 2600 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 2700 series of the regress.cal test suite.
|
* This library is used by the 2700 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 3100 series of the regress.cal test suite.
|
* This library is used by the 3100 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 3300 series of the regress.cal test suite.
|
* This library is used by the 3300 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 3400 series of the regress.cal test suite.
|
* This library is used by the 3400 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 3500 series of the regress.cal test suite.
|
* This library is used by the 3500 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 4000 series of the regress.cal test suite.
|
* This library is used by the 4000 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 4100 series of the regress.cal test suite.
|
* This library is used by the 4100 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 4600 series of the regress.cal test suite.
|
* This library is used by the 4600 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 5100 series of the regress.cal test suite.
|
* This library is used by the 5100 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* This library is used by the 5200 series of the regress.cal test suite.
|
* This library is used by the 5200 series of the regress.cal test suite.
|
||||||
*/
|
*/
|
||||||
|
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Landon Curt Noll
|
* By: Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
@@ -12,5 +12,19 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
print "8401: in test8400.cal";
|
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;
|
quit;
|
||||||
prob('quit did not end test8400.cal');
|
prob('quit did not end test8400.cal');
|
||||||
|
121
lib_calc.c
121
lib_calc.c
@@ -34,6 +34,11 @@
|
|||||||
#include "symbol.h"
|
#include "symbol.h"
|
||||||
#include "func.h"
|
#include "func.h"
|
||||||
|
|
||||||
|
#include "have_strdup.h"
|
||||||
|
#if !defined(HAVE_STRDUP)
|
||||||
|
# define strdup(x) calc_strdup((CONST char *)(x))
|
||||||
|
#endif /* HAVE_STRDUP */
|
||||||
|
|
||||||
#include "have_unistd.h"
|
#include "have_unistd.h"
|
||||||
#if defined(HAVE_UNISTD_H)
|
#if defined(HAVE_UNISTD_H)
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@@ -63,9 +68,9 @@ int new_std = FALSE; /* TRUE (-n) => use newstd configuration */
|
|||||||
int abortlevel; /* current level of aborts */
|
int abortlevel; /* current level of aborts */
|
||||||
BOOL inputwait; /* TRUE if in a terminal input wait */
|
BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
jmp_buf jmpbuf; /* for errors */
|
jmp_buf jmpbuf; /* for errors */
|
||||||
run run_state = RUN_UNKNOWN; /* calc startup and run state */
|
|
||||||
char *program = "calc"; /* our name */
|
char *program = "calc"; /* our name */
|
||||||
char cmdbuf[MAXCMD+1+1+1]; /* command line expression + "\n\0" + guard */
|
char cmdbuf[MAXCMD+1+1+1]; /* command line expression + "\n\0" + guard */
|
||||||
|
run run_state = RUN_UNKNOWN; /* calc startup and run state */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -86,6 +91,7 @@ int d_flag = FALSE; /* TRUE => disable heading, lib_debug == 0 */
|
|||||||
int c_flag = FALSE; /* TRUE => continue on error if permitted */
|
int c_flag = FALSE; /* TRUE => continue on error if permitted */
|
||||||
int i_flag = FALSE; /* TRUE => go interactive if permitted */
|
int i_flag = FALSE; /* TRUE => go interactive if permitted */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* global values
|
* global values
|
||||||
*/
|
*/
|
||||||
@@ -106,6 +112,10 @@ 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 */
|
||||||
|
|
||||||
|
char *calc_debug = NULL; /* !=NULL => value of config("calc_debug") */
|
||||||
|
char *lib_debug = NULL; /* !=NULL => value of config("lib_debug") */
|
||||||
|
char *user_debug = NULL; /* !=NULL => value of config("user_debug") */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialization functions
|
* initialization functions
|
||||||
@@ -173,6 +183,19 @@ libcalc_call_me_first(void)
|
|||||||
conf->tab_ok = 0;
|
conf->tab_ok = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* -D flags can change calc_debug, lib_debug of user_debug
|
||||||
|
*/
|
||||||
|
if (calc_debug) {
|
||||||
|
conf->calc_debug = strtol(calc_debug, NULL, 0);
|
||||||
|
}
|
||||||
|
if (lib_debug) {
|
||||||
|
conf->lib_debug = strtol(lib_debug, NULL, 0);
|
||||||
|
}
|
||||||
|
if (user_debug) {
|
||||||
|
conf->user_debug = strtol(user_debug, NULL, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialize
|
* initialize
|
||||||
*/
|
*/
|
||||||
@@ -181,6 +204,11 @@ libcalc_call_me_first(void)
|
|||||||
/*
|
/*
|
||||||
* ready to rock & roll ..
|
* ready to rock & roll ..
|
||||||
*/
|
*/
|
||||||
|
if (conf->calc_debug & CALCDBG_RUNSTATE) {
|
||||||
|
printf("DEBUG: run_state from %s to %s\n",
|
||||||
|
run_state_name(run_state),
|
||||||
|
run_state_name(RUN_BEGIN));
|
||||||
|
}
|
||||||
run_state = RUN_BEGIN;
|
run_state = RUN_BEGIN;
|
||||||
init_done = 1;
|
init_done = 1;
|
||||||
return;
|
return;
|
||||||
@@ -287,14 +315,17 @@ static void
|
|||||||
initenv(void)
|
initenv(void)
|
||||||
{
|
{
|
||||||
struct passwd *ent; /* our password entry */
|
struct passwd *ent; /* our password entry */
|
||||||
|
char *c;
|
||||||
|
|
||||||
/* determine the $CALCPATH value */
|
/* determine the $CALCPATH value */
|
||||||
calcpath = (no_env ? NULL : getenv(CALCPATH));
|
c = getenv(CALCPATH);
|
||||||
|
calcpath = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (calcpath == NULL)
|
if (calcpath == NULL)
|
||||||
calcpath = DEFAULTCALCPATH;
|
calcpath = DEFAULTCALCPATH;
|
||||||
|
|
||||||
/* determine the $CALCRC value */
|
/* determine the $CALCRC value */
|
||||||
calcrc = (no_env ? NULL : getenv(CALCRC));
|
c = getenv(CALCRC);
|
||||||
|
calcrc = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (calcrc == NULL) {
|
if (calcrc == NULL) {
|
||||||
calcrc = DEFAULTCALCRC;
|
calcrc = DEFAULTCALCRC;
|
||||||
}
|
}
|
||||||
@@ -305,13 +336,15 @@ initenv(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* determine the $CALCBINDINGS value */
|
/* determine the $CALCBINDINGS value */
|
||||||
calcbindings = (no_env ? NULL : getenv(CALCBINDINGS));
|
c = getenv(CALCBINDINGS);
|
||||||
|
calcbindings = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (calcbindings == NULL) {
|
if (calcbindings == NULL) {
|
||||||
calcbindings = DEFAULTCALCBINDINGS;
|
calcbindings = DEFAULTCALCBINDINGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* determine the $HOME value */
|
/* determine the $HOME value */
|
||||||
home = (no_env ? NULL : getenv(HOME));
|
c = getenv(HOME);
|
||||||
|
home = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (home == NULL || home[0] == '\0') {
|
if (home == NULL || home[0] == '\0') {
|
||||||
ent = (struct passwd *)getpwuid(geteuid());
|
ent = (struct passwd *)getpwuid(geteuid());
|
||||||
if (ent == NULL) {
|
if (ent == NULL) {
|
||||||
@@ -323,13 +356,15 @@ initenv(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* determine the $PAGER value */
|
/* determine the $PAGER value */
|
||||||
pager = (no_env ? NULL : getenv(PAGER));
|
c = getenv(PAGER);
|
||||||
|
pager = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (pager == NULL || *pager == '\0') {
|
if (pager == NULL || *pager == '\0') {
|
||||||
pager = DEFAULTCALCPAGER;
|
pager = DEFAULTCALCPAGER;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* determine the $SHELL value */
|
/* determine the $SHELL value */
|
||||||
shell = (no_env ? NULL : getenv(SHELL));
|
c = getenv(SHELL);
|
||||||
|
shell = ((no_env || c == NULL) ? NULL : strdup(c));
|
||||||
if (shell == NULL)
|
if (shell == NULL)
|
||||||
shell = DEFAULTSHELL;
|
shell = DEFAULTSHELL;
|
||||||
}
|
}
|
||||||
@@ -371,3 +406,75 @@ libcalc_call_me_last(void)
|
|||||||
init_done = 0;
|
init_done = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* run_state_name - return a constant string given a run_state
|
||||||
|
*/
|
||||||
|
char *
|
||||||
|
run_state_name(run state)
|
||||||
|
{
|
||||||
|
switch (state) {
|
||||||
|
case RUN_UNKNOWN:
|
||||||
|
return "RUN_UNKNOWN";
|
||||||
|
case RUN_BEGIN:
|
||||||
|
return "RUN_BEGIN";
|
||||||
|
case RUN_RCFILES:
|
||||||
|
return "RUN_RCFILES";
|
||||||
|
case RUN_PRE_CMD_ARGS:
|
||||||
|
return "RUN_PRE_CMD_ARGS";
|
||||||
|
case RUN_CMD_ARGS:
|
||||||
|
return "RUN_CMD_ARGS";
|
||||||
|
case RUN_PRE_TOP_LEVEL:
|
||||||
|
return "RUN_PRE_TOP_LEVEL";
|
||||||
|
case RUN_TOP_LEVEL:
|
||||||
|
return "RUN_TOP_LEVEL";
|
||||||
|
case RUN_EXIT:
|
||||||
|
return "RUN_EXIT";
|
||||||
|
case RUN_EXIT_WITH_ERROR:
|
||||||
|
return "RUN_EXIT_WITH_ERROR";
|
||||||
|
}
|
||||||
|
return "RUN_invalid";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* calc_strdup - calc interface to provide or simulate strdup()
|
||||||
|
*/
|
||||||
|
char *
|
||||||
|
calc_strdup(CONST char *s1)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_STRDUP)
|
||||||
|
|
||||||
|
return strdup(s1);
|
||||||
|
|
||||||
|
#else /* HAVE_STRDUP */
|
||||||
|
|
||||||
|
char *ret; /* return string */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* firewall
|
||||||
|
*/
|
||||||
|
if (s1 == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* allocate duplicate storage
|
||||||
|
*/
|
||||||
|
ret = (char *)malloc(sizeof(char) * (strlen(s1)+1));
|
||||||
|
|
||||||
|
/*
|
||||||
|
* if we have storage, duplicate the string
|
||||||
|
*/
|
||||||
|
if (ret != NULL) {
|
||||||
|
strcpy(ret, s1);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* return the new string, or NULL if malloc failed
|
||||||
|
*/
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
#endif /* HAVE_STRDUP */
|
||||||
|
}
|
||||||
|
14
longlong.c
14
longlong.c
@@ -62,8 +62,8 @@
|
|||||||
/*
|
/*
|
||||||
* have the compiler try its hand with unsigned and signed long longs
|
* have the compiler try its hand with unsigned and signed long longs
|
||||||
*/
|
*/
|
||||||
unsigned long long val = 4294967297ULL;
|
unsigned long long val = 0x1234567890123456ULL;
|
||||||
long long val2 = -4294967297LL;
|
long long val2 = -1311768467284833366LL; /* -0x1234567890123456 */
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
@@ -90,14 +90,20 @@ main(int argc, char **argv)
|
|||||||
if (longlong_bits > 0) {
|
if (longlong_bits > 0) {
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* if size is longer than an unsigned long, use it
|
* if size is longer than an unsigned long,
|
||||||
|
* and the negative 'long long' works, then use long long's
|
||||||
*/
|
*/
|
||||||
if (longlong_bits > sizeof(unsigned long)*8) {
|
if (longlong_bits > sizeof(unsigned long)*8 && val2 < 0) {
|
||||||
|
|
||||||
/* use long long length */
|
/* use long long length */
|
||||||
printf("#define HAVE_LONGLONG\n");
|
printf("#define HAVE_LONGLONG\n");
|
||||||
printf("#define LONGLONG_BITS %d /* yes */\n",
|
printf("#define LONGLONG_BITS %d /* yes */\n",
|
||||||
longlong_bits);
|
longlong_bits);
|
||||||
|
|
||||||
|
printf("\n/* does %%lld work or does %%ld? */\n");
|
||||||
|
printf("#if defined(CHECK_L_FORMAT)\n");
|
||||||
|
printf("long long l_format = %ld;\n", val);
|
||||||
|
printf("#endif /* CHECK_L_FORMAT */\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
|
@@ -28,7 +28,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
46
obj.c
46
obj.c
@@ -96,8 +96,10 @@ static struct objectinfo {
|
|||||||
|
|
||||||
static STRINGHEAD objectnames; /* names of objects */
|
static STRINGHEAD objectnames; /* names of objects */
|
||||||
static STRINGHEAD elements; /* element names for parts of objects */
|
static STRINGHEAD elements; /* element names for parts of objects */
|
||||||
static OBJECTACTIONS *objects[MAXOBJECTS]; /* table of actions for objects */
|
static OBJECTACTIONS **objects; /* table of actions for objects */
|
||||||
|
|
||||||
|
#define OBJALLOC 16
|
||||||
|
static long maxobjcount = 0;
|
||||||
|
|
||||||
static VALUE objpowi(VALUE *vp, NUMBER *q);
|
static VALUE objpowi(VALUE *vp, NUMBER *q);
|
||||||
static BOOL objtest(OBJECT *op);
|
static BOOL objtest(OBJECT *op);
|
||||||
@@ -456,11 +458,12 @@ objpowi(VALUE *vp, NUMBER *q)
|
|||||||
* indices table of indices for elements
|
* indices table of indices for elements
|
||||||
* count number of elements defined for the object
|
* count number of elements defined for the object
|
||||||
*/
|
*/
|
||||||
void
|
int
|
||||||
defineobject(char *name, int indices[], int count)
|
defineobject(char *name, int indices[], int count)
|
||||||
{
|
{
|
||||||
OBJECTACTIONS *oap; /* object definition structure */
|
OBJECTACTIONS *oap; /* object definition structure */
|
||||||
STRINGHEAD *hp;
|
STRINGHEAD *hp;
|
||||||
|
OBJECTACTIONS **newobjects;
|
||||||
int index;
|
int index;
|
||||||
|
|
||||||
hp = &objectnames;
|
hp = &objectnames;
|
||||||
@@ -476,21 +479,32 @@ defineobject(char *name, int indices[], int count)
|
|||||||
if (oap->count == count) {
|
if (oap->count == count) {
|
||||||
for (index = 0; ; index++) {
|
for (index = 0; ; index++) {
|
||||||
if (index >= count)
|
if (index >= count)
|
||||||
return;
|
return 0;
|
||||||
if (oap->elements[index] != indices[index])
|
if (oap->elements[index] != indices[index])
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
math_error("Object type \"%s\" is already defined", name);
|
return 1;
|
||||||
/*NOTREACHED*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hp->h_count >= MAXOBJECTS) {
|
if (hp->h_count >= maxobjcount) {
|
||||||
math_error("Too many object types in use");
|
if (maxobjcount == 0) {
|
||||||
/*NOTREACHED*/
|
newobjects = (OBJECTACTIONS **) malloc(
|
||||||
|
OBJALLOC * sizeof(OBJECTACTIONS *));
|
||||||
|
maxobjcount = OBJALLOC;
|
||||||
|
} else {
|
||||||
|
maxobjcount += OBJALLOC;
|
||||||
|
newobjects = (OBJECTACTIONS **) realloc(objects,
|
||||||
|
maxobjcount * sizeof(OBJECTACTIONS *));
|
||||||
|
}
|
||||||
|
if (newobjects == NULL) {
|
||||||
|
math_error("Allocation failure for new object type");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
objects = newobjects;
|
||||||
}
|
}
|
||||||
|
|
||||||
oap = (OBJECTACTIONS *) malloc(objectactionsize(count));
|
oap = (OBJECTACTIONS *) malloc(objectactionsize(count));
|
||||||
if (oap)
|
|
||||||
name = addstr(hp, name);
|
name = addstr(hp, name);
|
||||||
if ((oap == NULL) || (name == NULL)) {
|
if ((oap == NULL) || (name == NULL)) {
|
||||||
math_error("Cannot allocate object type");
|
math_error("Cannot allocate object type");
|
||||||
@@ -504,7 +518,7 @@ defineobject(char *name, int indices[], int count)
|
|||||||
oap->elements[index] = indices[index];
|
oap->elements[index] = indices[index];
|
||||||
index = findstr(hp, name);
|
index = findstr(hp, name);
|
||||||
objects[index] = oap;
|
objects[index] = oap;
|
||||||
return;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -565,6 +579,16 @@ findelement(char *name)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns the name of object type with specified index
|
||||||
|
*/
|
||||||
|
char *
|
||||||
|
objtypename(unsigned long index)
|
||||||
|
{
|
||||||
|
return namestr(&objectnames, (long)index);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Return the value table offset to be used for an object element name.
|
* Return the value table offset to be used for an object element name.
|
||||||
* This converts the element index from the element table into an offset
|
* This converts the element index from the element table into an offset
|
||||||
@@ -596,7 +620,7 @@ objalloc(long index)
|
|||||||
VALUE *vp;
|
VALUE *vp;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if ((unsigned) index >= MAXOBJECTS) {
|
if (index < 0 || index > maxobjcount) {
|
||||||
math_error("Allocating bad object index");
|
math_error("Allocating bad object index");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
|
36
opcodes.c
36
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();
|
||||||
@@ -3140,7 +3143,7 @@ o_quit(FUNC *fp, long index)
|
|||||||
printf("%s\n", cp);
|
printf("%s\n", cp);
|
||||||
else if (conf->verbose_quit)
|
else if (conf->verbose_quit)
|
||||||
printf("Quit or abort 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;
|
||||||
}
|
}
|
||||||
@@ -3576,7 +3579,7 @@ calculate(FUNC *fp, int argcount)
|
|||||||
funcname = fp->f_name;
|
funcname = fp->f_name;
|
||||||
funcline = 0;
|
funcline = 0;
|
||||||
go = TRUE;
|
go = TRUE;
|
||||||
abort_now = FALSE;
|
++calc_depth;
|
||||||
origargcount = argcount;
|
origargcount = argcount;
|
||||||
while (argcount < fp->f_paramcount) {
|
while (argcount < fp->f_paramcount) {
|
||||||
stack++;
|
stack++;
|
||||||
@@ -3692,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 */
|
||||||
@@ -3713,14 +3717,7 @@ calculate(FUNC *fp, int argcount)
|
|||||||
freevalue(stack--);
|
freevalue(stack--);
|
||||||
funcname = oldname;
|
funcname = oldname;
|
||||||
funcline = oldline;
|
funcline = oldline;
|
||||||
if (abort_now && stack == stackarray) {
|
--calc_depth;
|
||||||
if (!stdin_tty)
|
|
||||||
run_state = RUN_EXIT;
|
|
||||||
else if (run_state < RUN_PRE_TOP_LEVEL)
|
|
||||||
run_state = RUN_PRE_TOP_LEVEL;
|
|
||||||
freefunc(curfunc);
|
|
||||||
longjmp(jmpbuf, 1);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3776,11 +3773,14 @@ dumpop(unsigned long *pc)
|
|||||||
return 3;
|
return 3;
|
||||||
case OP_PRINT: case OP_JUMPZ: case OP_JUMPNZ: case OP_JUMP:
|
case OP_PRINT: case OP_JUMPZ: case OP_JUMPNZ: case OP_JUMP:
|
||||||
case OP_CONDORJUMP: case OP_CONDANDJUMP: case OP_CASEJUMP:
|
case OP_CONDORJUMP: case OP_CONDANDJUMP: case OP_CASEJUMP:
|
||||||
case OP_INITSTATIC: case OP_MATCREATE: case OP_OBJCREATE:
|
case OP_INITSTATIC: case OP_MATCREATE:
|
||||||
case OP_SHOW: case OP_ELEMINIT: case OP_ELEMADDR:
|
case OP_SHOW: case OP_ELEMINIT: case OP_ELEMADDR:
|
||||||
case OP_ELEMVALUE: case OP_JUMPNN:
|
case OP_ELEMVALUE: case OP_JUMPNN:
|
||||||
printf(" %ld\n", *pc);
|
printf(" %ld\n", *pc);
|
||||||
return 2;
|
return 2;
|
||||||
|
case OP_OBJCREATE:
|
||||||
|
printf(" %s\n", objtypename(*pc));
|
||||||
|
return 2;
|
||||||
case OP_NUMBER: case OP_IMAGINARY:
|
case OP_NUMBER: case OP_IMAGINARY:
|
||||||
qprintf(" %r", constvalue(*pc));
|
qprintf(" %r", constvalue(*pc));
|
||||||
printf("\n");
|
printf("\n");
|
||||||
@@ -3857,3 +3857,13 @@ freenumbers(FUNC *fp)
|
|||||||
}
|
}
|
||||||
trimconstants();
|
trimconstants();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
long
|
||||||
|
calclevel(void)
|
||||||
|
{
|
||||||
|
return calc_depth - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* END CODE */
|
||||||
|
2
poly.c
2
poly.c
@@ -4,7 +4,7 @@
|
|||||||
* provided that this copyright notice remains intact.
|
* provided that this copyright notice remains intact.
|
||||||
*
|
*
|
||||||
* By: Ernest Bowen and Landon Curt Noll
|
* By: Ernest Bowen and Landon Curt Noll
|
||||||
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
@@ -20,7 +20,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -80,12 +80,12 @@ static QCKHASH blk_hash(BLOCK *blk, QCKHASH val);
|
|||||||
* The basis of this hash algorithm was taken from an idea sent
|
* The basis of this hash algorithm was taken from an idea sent
|
||||||
* as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
* as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
||||||
*
|
*
|
||||||
* Phong Vo (http://www.research.att.com/info/kpv)
|
* Phong Vo (http://www.research.att.com/info/kpv/)
|
||||||
* Glenn Fowler (http://www.research.att.com/~gsf/)
|
* Glenn Fowler (http://www.research.att.com/~gsf/)
|
||||||
*
|
*
|
||||||
* In a subsequent ballot round:
|
* In a subsequent ballot round:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll (http://reality.sgi.com/chongo)
|
* Landon Curt Noll (http://reality.sgi.com/chongo/)
|
||||||
*
|
*
|
||||||
* improved on their algorithm. Some people tried this hash
|
* improved on their algorithm. Some people tried this hash
|
||||||
* and found that it worked rather well. In an EMail message
|
* and found that it worked rather well. In an EMail message
|
||||||
@@ -404,8 +404,8 @@ config_hash(CONFIG *cfg, QCKHASH val)
|
|||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkverbose);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkverbose);
|
||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkbase);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkbase);
|
||||||
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkfmt);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->blkfmt);
|
||||||
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->lib_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);
|
value = (((value>>5) | (value<<27)) ^ (USB32)cfg->verbose_quit);
|
||||||
|
|
||||||
|
@@ -27,7 +27,7 @@
|
|||||||
# Happy bit twiddling,
|
# Happy bit twiddling,
|
||||||
#
|
#
|
||||||
# Landon Curt Noll
|
# Landon Curt Noll
|
||||||
# http://reality.sgi.com/chongo
|
# http://reality.sgi.com/chongo/
|
||||||
#
|
#
|
||||||
# chongo <was here> /\../\
|
# chongo <was here> /\../\
|
||||||
|
|
||||||
@@ -321,15 +321,11 @@ many_random: many_random.o ../libcalc.a
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/sample/$$i; \
|
echo sample/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo sample
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/sample/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -402,11 +398,11 @@ depend:
|
|||||||
else \
|
else \
|
||||||
rm -f Makefile.tmp; \
|
rm -f Makefile.tmp; \
|
||||||
mv Makefile Makefile.tmp; \
|
mv Makefile Makefile.tmp; \
|
||||||
if [ -d RCS ]; then; \
|
if [ -d RCS ]; then \
|
||||||
co -l Makefile; \
|
co -l Makefile; \
|
||||||
fi; \
|
fi; \
|
||||||
mv Makefile.tmp Makefile; \
|
mv Makefile.tmp Makefile; \
|
||||||
if [ -d RCS ]; then; \
|
if [ -d RCS ]; then \
|
||||||
echo new sample Makefile formed, you need to check it in; \
|
echo new sample Makefile formed, you need to check it in; \
|
||||||
fi; \
|
fi; \
|
||||||
fi
|
fi
|
||||||
|
38
seed.c
38
seed.c
@@ -6,7 +6,7 @@
|
|||||||
* NOTE: This is not a good source of chaotic data. The lavarand
|
* NOTE: This is not a good source of chaotic data. The lavarand
|
||||||
* system does a much better job of that. See:
|
* system does a much better job of that. See:
|
||||||
*
|
*
|
||||||
* http://lavarand.sgi.com
|
* http://lavarand.sgi.com/index.html
|
||||||
*
|
*
|
||||||
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
* Copyright (c) 1999 by Landon Curt Noll. All Rights Reserved.
|
||||||
*
|
*
|
||||||
@@ -29,7 +29,7 @@
|
|||||||
* PERFORMANCE OF THIS SOFTWARE.
|
* PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
@@ -53,16 +53,11 @@
|
|||||||
*/
|
*/
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
#include <time.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <sys/times.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
#include <setjmp.h>
|
#include <setjmp.h>
|
||||||
#if !defined(__bsdi)
|
|
||||||
#include <ustat.h>
|
|
||||||
#endif /* __bsdi */
|
|
||||||
#if defined(__linux)
|
|
||||||
# include <fcntl.h>
|
|
||||||
# define DEV_URANDOM "/dev/urandom"
|
|
||||||
# define DEV_URANDOM_POOL 128
|
|
||||||
#endif /* __linux */
|
|
||||||
#include "qmath.h"
|
#include "qmath.h"
|
||||||
#include "longbits.h"
|
#include "longbits.h"
|
||||||
#include "have_ustat.h"
|
#include "have_ustat.h"
|
||||||
@@ -71,6 +66,15 @@
|
|||||||
#include "have_gettime.h"
|
#include "have_gettime.h"
|
||||||
#include "have_getprid.h"
|
#include "have_getprid.h"
|
||||||
#include "have_urandom.h"
|
#include "have_urandom.h"
|
||||||
|
#include "have_rusage.h"
|
||||||
|
#if defined(HAVE_USTAT)
|
||||||
|
# include <ustat.h>
|
||||||
|
#endif /* HAVE_USTAT */
|
||||||
|
#if defined(HAVE_URANDOM)
|
||||||
|
# include <fcntl.h>
|
||||||
|
# define DEV_URANDOM "/dev/urandom"
|
||||||
|
# define DEV_URANDOM_POOL 16
|
||||||
|
#endif /* HAVE_URANDOM */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -157,12 +161,12 @@ hash_buf(char *buf, unsigned len)
|
|||||||
* The basis of this hash algorithm was taken from an idea sent
|
* The basis of this hash algorithm was taken from an idea sent
|
||||||
* as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
* as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
||||||
*
|
*
|
||||||
* Phong Vo (http://www.research.att.com/info/kpv)
|
* Phong Vo (http://www.research.att.com/info/kpv/)
|
||||||
* Glenn Fowler (http://www.research.att.com/~gsf/)
|
* Glenn Fowler (http://www.research.att.com/~gsf/)
|
||||||
*
|
*
|
||||||
* In a subsequent ballot round:
|
* In a subsequent ballot round:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll (http://reality.sgi.com/chongo)
|
* Landon Curt Noll (http://reality.sgi.com/chongo/)
|
||||||
*
|
*
|
||||||
* improved on their algorithm. Some people tried this hash
|
* improved on their algorithm. Some people tried this hash
|
||||||
* and found that it worked rather well. In an EMail message
|
* and found that it worked rather well. In an EMail message
|
||||||
@@ -248,7 +252,7 @@ hash_buf(char *buf, unsigned len)
|
|||||||
* NOTE: This is not a good source of chaotic data. The lavarand
|
* NOTE: This is not a good source of chaotic data. The lavarand
|
||||||
* system does a much better job of that. See:
|
* system does a much better job of that. See:
|
||||||
*
|
*
|
||||||
* http://lavarand.sgi.com
|
* http://lavarand.sgi.com/index.html
|
||||||
*
|
*
|
||||||
* PORTING NOTE:
|
* PORTING NOTE:
|
||||||
* If when porting this code to your system and something
|
* If when porting this code to your system and something
|
||||||
@@ -308,9 +312,13 @@ pseudo_seed(void)
|
|||||||
#if defined(HAVE_GETPGID)
|
#if defined(HAVE_GETPGID)
|
||||||
pid_t getpgid; /* process group ID */
|
pid_t getpgid; /* process group ID */
|
||||||
#endif /* HAVE_GETPGID */
|
#endif /* HAVE_GETPGID */
|
||||||
|
#if defined(HAVE_GETRUSAGE)
|
||||||
struct rusage rusage; /* resource utilization */
|
struct rusage rusage; /* resource utilization */
|
||||||
struct rusage rusage_chld; /* resource utilization of children */
|
struct rusage rusage_chld; /* resource utilization of children */
|
||||||
|
#endif /* HAVE_GETRUSAGE */
|
||||||
struct timeval tp2; /* time of day again */
|
struct timeval tp2; /* time of day again */
|
||||||
|
struct tms times; /* process times */
|
||||||
|
time_t time; /* local time */
|
||||||
size_t size; /* size of this data structure */
|
size_t size; /* size of this data structure */
|
||||||
jmp_buf env; /* setjmp() context */
|
jmp_buf env; /* setjmp() context */
|
||||||
char *sdata_p; /* address of this structure */
|
char *sdata_p; /* address of this structure */
|
||||||
@@ -377,9 +385,13 @@ pseudo_seed(void)
|
|||||||
#if defined(HAVE_GETPGID)
|
#if defined(HAVE_GETPGID)
|
||||||
sdata.getpgid = getpgid((pid_t)0);
|
sdata.getpgid = getpgid((pid_t)0);
|
||||||
#endif /* HAVE_GETPGID */
|
#endif /* HAVE_GETPGID */
|
||||||
|
#if defined(HAVE_GETRUSAGE)
|
||||||
(void) getrusage(RUSAGE_SELF, &sdata.rusage);
|
(void) getrusage(RUSAGE_SELF, &sdata.rusage);
|
||||||
(void) getrusage(RUSAGE_CHILDREN, &sdata.rusage_chld);
|
(void) getrusage(RUSAGE_CHILDREN, &sdata.rusage_chld);
|
||||||
|
#endif /* HAVE_GETRUSAGE */
|
||||||
(void) gettimeofday(&sdata.tp2, NULL);
|
(void) gettimeofday(&sdata.tp2, NULL);
|
||||||
|
(void) times(&sdata.times);
|
||||||
|
sdata.time = time(NULL);
|
||||||
sdata.size = sizeof(sdata);
|
sdata.size = sizeof(sdata);
|
||||||
(void) setjmp(sdata.env);
|
(void) setjmp(sdata.env);
|
||||||
sdata.sdata_p = (char *)&sdata;
|
sdata.sdata_p = (char *)&sdata;
|
||||||
|
4
shs.c
4
shs.c
@@ -12,7 +12,7 @@
|
|||||||
* This file was Modified/Re-written by:
|
* This file was Modified/Re-written by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
@@ -29,7 +29,7 @@
|
|||||||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
*
|
*
|
||||||
* Based on Version 2.11 (09 Mar 1995) from Landon Curt Noll's
|
* Based on Version 2.11 (09 Mar 1995) from Landon Curt Noll's
|
||||||
* (http://reality.sgi.com/chongo) shs hash program.
|
* (http://reality.sgi.com/chongo/) shs hash program.
|
||||||
*
|
*
|
||||||
****
|
****
|
||||||
*
|
*
|
||||||
|
2
shs.h
2
shs.h
@@ -12,7 +12,7 @@
|
|||||||
* This file was Modified by:
|
* This file was Modified by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
2
shs1.c
2
shs1.c
@@ -6,7 +6,7 @@
|
|||||||
* This file was Modified/Re-written by:
|
* This file was Modified/Re-written by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
2
shs1.h
2
shs1.h
@@ -6,7 +6,7 @@
|
|||||||
* This file was Modified by:
|
* This file was Modified by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
|
5
symbol.c
5
symbol.c
@@ -175,7 +175,10 @@ showglobals(void)
|
|||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
printf(count ? "\n" : "No real-valued global variables\n");
|
if (count == 0) {
|
||||||
|
printf("No real-valued global variables\n");
|
||||||
|
}
|
||||||
|
putchar('\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
14
token.c
14
token.c
@@ -335,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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
4
value.c
4
value.c
@@ -22,8 +22,6 @@
|
|||||||
|
|
||||||
#define LINELEN 80 /* length of a typical tty line */
|
#define LINELEN 80 /* length of a typical tty line */
|
||||||
|
|
||||||
extern int sys_nerr;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Free a value and set its type to undefined.
|
* Free a value and set its type to undefined.
|
||||||
*
|
*
|
||||||
@@ -2694,7 +2692,7 @@ printvalue(VALUE *vp, int flags)
|
|||||||
if (type < 0) {
|
if (type < 0) {
|
||||||
if (userfunc("error_print", vp))
|
if (userfunc("error_print", vp))
|
||||||
return;
|
return;
|
||||||
if (-type >= sys_nerr)
|
if (-type >= E__BASE)
|
||||||
printf("Error %d", -type);
|
printf("Error %d", -type);
|
||||||
else
|
else
|
||||||
printf("System error %d", -type);
|
printf("System error %d", -type);
|
||||||
|
3
value.h
3
value.h
@@ -446,11 +446,12 @@ extern VALUE objcall(int action, VALUE *v1, VALUE *v2, VALUE *v3);
|
|||||||
extern void objfree(OBJECT *op);
|
extern void objfree(OBJECT *op);
|
||||||
extern void objuncache(void);
|
extern void objuncache(void);
|
||||||
extern int addelement(char *name);
|
extern int addelement(char *name);
|
||||||
extern void defineobject(char *name, int indices[], int count);
|
extern int defineobject(char *name, int indices[], int count);
|
||||||
extern int checkobject(char *name);
|
extern int checkobject(char *name);
|
||||||
extern void showobjfuncs(void);
|
extern void showobjfuncs(void);
|
||||||
extern void showobjtypes(void);
|
extern void showobjtypes(void);
|
||||||
extern int findelement(char *name);
|
extern int findelement(char *name);
|
||||||
|
extern char *objtypename(unsigned long index);
|
||||||
extern int objoffset(OBJECT *op, long index);
|
extern int objoffset(OBJECT *op, long index);
|
||||||
|
|
||||||
|
|
||||||
|
27
version.c
27
version.c
@@ -7,12 +7,18 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include "calc.h"
|
#if defined(CALC_VER)
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
static char *program;
|
||||||
|
#else
|
||||||
|
# include "calc.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#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.9.1" /* test number or empty string if no patch */
|
#define MINOR_PATCH "9.4.3" /* test number or empty string if no patch */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version constants
|
* calc version constants
|
||||||
@@ -80,3 +86,20 @@ version(void)
|
|||||||
*/
|
*/
|
||||||
return stored_version;
|
return stored_version;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(CALC_VER)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* version - print the calc version
|
||||||
|
*/
|
||||||
|
/*ARGSUSED*/
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
program = argv[0];
|
||||||
|
printf("%s\n", version());
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CALC_VER */
|
||||||
|
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)
|
||||||
|
2
zrand.c
2
zrand.c
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
2
zrand.h
2
zrand.h
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
@@ -29,7 +29,7 @@
|
|||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
* http://reality.sgi.com/chongo
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo <was here> /\../\
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
@@ -365,8 +365,7 @@
|
|||||||
* were selected by lavarand, a hardware random number generator.
|
* were selected by lavarand, a hardware random number generator.
|
||||||
* See the URL:
|
* See the URL:
|
||||||
*
|
*
|
||||||
* http://lavarand.sgi.com
|
* http://lavarand.sgi.com/index.html
|
||||||
* XXX - This URL is not available on 17Feb97 ... but will be soon.
|
|
||||||
*
|
*
|
||||||
* for an explination of how the lavarand random number generator works.
|
* for an explination of how the lavarand random number generator works.
|
||||||
*
|
*
|
||||||
|
Reference in New Issue
Block a user