mirror of
https://github.com/lcn2/calc.git
synced 2025-08-19 01:13:27 +03:00
Compare commits
31 Commits
2.11.0t5
...
2.11.0t9.4
Author | SHA1 | Date | |
---|---|---|---|
|
7cb0a77c25 | ||
|
afb0e5c32a | ||
|
df32e3956d | ||
|
75e742c716 | ||
|
1b42111665 | ||
|
ea6b3904be | ||
|
f3fceff1b6 | ||
|
69d4a17187 | ||
|
a99a3400e7 | ||
|
9b6c308b42 | ||
|
8927373965 | ||
|
478d68fca9 | ||
|
e6e2556893 | ||
|
a7e363da8b | ||
|
8db10967e8 | ||
|
49be672338 | ||
|
a7d401cd65 | ||
|
5cc680fe42 | ||
|
2c72ea9339 | ||
|
0ffc341b10 | ||
|
2251281027 | ||
|
45a4b8469d | ||
|
9204d2fb8c | ||
|
35982c7cc8 | ||
|
4c0f2691e9 | ||
|
0d37ccb019 | ||
|
d7d31e9246 | ||
|
2dc364ee9f | ||
|
b54d8fc510 | ||
|
8cabbd6fb4 | ||
|
ea64a95b90 |
143
BUGS
143
BUGS
@@ -20,11 +20,11 @@ configuration, try backing them out and see if things get better.
|
|||||||
|
|
||||||
To be sure that your version of calc is up to date, check out:
|
To be sure that your version of calc is up to date, check out:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc/calc-download.html
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
The calc web site is located at:
|
The calc web site is located at:
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/index.html
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
@@ -46,7 +46,7 @@ When you send your report, please include the following information:
|
|||||||
|
|
||||||
* the type of compiler you were using
|
* the type of compiler you were using
|
||||||
|
|
||||||
* any compiler warnings or erros that you saw
|
* any compiler warnings or errors that you saw
|
||||||
|
|
||||||
* cd to the calc source directory, and type:
|
* cd to the calc source directory, and type:
|
||||||
|
|
||||||
@@ -66,98 +66,75 @@ importantly, fixes (in the form of a context diff patch) to:
|
|||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
Known problems or mis-features:
|
Known bugs:
|
||||||
|
|
||||||
* Many of and SEE ALSO sections of help files
|
* Calc does not support the #! exec method. For example of the
|
||||||
for builtins are either inconsistent or missing information.
|
following is placed in an executable file (assume the path to
|
||||||
|
calc is correct) called /tmp/xyzzy:
|
||||||
|
|
||||||
* Many of the LIBRARY sections are incorrect now that libcalc.a
|
#!/usr/local/bin/calc
|
||||||
contains most of the calc system.
|
/*
|
||||||
|
* comment
|
||||||
|
*/
|
||||||
|
print 2+3;
|
||||||
|
|
||||||
* There is some places in the source with obscure variable names
|
Will result in '"tmp" is undefined' and '"xyzzy" is undefined'
|
||||||
and not much in the way of comments. We need some major cleanup
|
error messages because calc considers $0 as an expression to
|
||||||
and documentation.
|
evaluate.
|
||||||
|
|
||||||
* On Solaris cc when compile with -Xc (which results in BASEB=16
|
* The following file:
|
||||||
because it eliminates the long long type), some of the hash
|
|
||||||
functions fail.
|
|
||||||
|
|
||||||
NOTE: As a work-a-round, Solaris cc users should compile
|
/* this is bugdemo.cal */
|
||||||
with -DFORCE_STDC and without -Xc.
|
x = eval(prompt(">>> "));
|
||||||
|
print x;
|
||||||
|
|
||||||
From: "Dr.D.J.Picton" <dave@aps5.ph.bham.ac.uk>
|
when executed as:
|
||||||
Subject: Re: calc version 2.11.0t4
|
|
||||||
Date: Fri, 1 Oct 1999 16:12:30 +0100 (BST)
|
|
||||||
|
|
||||||
**** Non-true result (0): 7120: sha(sha(isqrt(2e1000)==0x6db8d9cf0b018b8f9cbbf5aa1edb8066d19e1bb0
|
calc read bugdemo.cal
|
||||||
7120 result came out as 0x2f19f0baa7824cb8da5e9908044a3f648e992
|
|
||||||
**** Non-true result (0): 7122: sha(sha("this is", 7^19-8, ..., "hash")) == 0x21e4...
|
|
||||||
7122 result came out as 0xa050ece371eda88a461afcb807091f7613aa4488
|
|
||||||
7123: z = sha(list(1,2,3), "curds and whey", 2^21701-1, pi());
|
|
||||||
**** Non-true result (0): 7124: sha(z) == 0x36dcca3e51865c30a2cf738023cda446f1368340
|
|
||||||
7124 result came out as 0xccaff4f97187821018d983cc0ce51787fb96a73c
|
|
||||||
**** Non-true result (0): 7209: sha1(sha1("this is",7^19-8,"a composit",3i+4.5,"hash")) == ...
|
|
||||||
7209 result came out as 0xb9631fea54a3e999521efa99745d2e2a5f65cd3b
|
|
||||||
7210: z = sha1(list(1,2,3), "curds and whey", 2^21701-1, pi());
|
|
||||||
**** Non-true result (0): 7211: sha1(z) == 0xc19e7317675dbf71e293b4c41e117169e9da5b6f
|
|
||||||
7211result came out as 0xb8e5c8fdbbe4539cf601b0f6eb874f9662edb50c
|
|
||||||
**** Non-true result (0): 7227: sha1(sha1(isqrt(2e1000)))==0x6852a1365c51050c3d039e3c5d9cf29c12283ef4
|
|
||||||
7227 result came out as 0x91018a59d87c7d945451538412cadd56b7ec4681
|
|
||||||
**** Non-true result (0): 7310: md5(md5("this is", 7^19-8, "a composit", 3i+4.5, "hash")) == ...
|
|
||||||
7310 result came out as 0x65c29173098713fdec0f319551355243
|
|
||||||
7311: z = md5(list(1,2,3), "curds and whey", 2^21701-1, pi());
|
|
||||||
**** Non-true result (0): 7312: md5(z) == 0x63d2b2fccae2de265227c30b05abb6b5
|
|
||||||
7311 result came out as 0x1ba0c3eb5ba11dfe11394c0837f52d85
|
|
||||||
**** Non-true result (0): 7328: md5(md5(isqrt(2e1000))) == 0xe56ac4b8cad869e738a04fedc97058f3
|
|
||||||
7328 result came out as 0x5afae12a1db610da2846c35f2bf144b0
|
|
||||||
|
|
||||||
**** 9 error(s) found \/++\/
|
will obtain a prompt from the terminal, print the value but leave
|
||||||
9999: Ending regression tests
|
the terminal in a 'bad' state, as if stty -icanon -echo -echoe
|
||||||
|
had been executed.
|
||||||
|
|
||||||
* On a Dec Alpha, make check for version 2.11.0t1 core dumps:
|
* Dec Alpha Linux compiling with gcc-2.95.1 (or gcc-2.95.2) and
|
||||||
|
-O2 fails the version 2.11.0t8.10 regression test with:
|
||||||
|
|
||||||
From vandermj@molbio.sbphrd.com Fri Sep 24 06:15:28 1999
|
make -s check
|
||||||
Subject: Re: calc version 2.11.0t1
|
000: Beginning regression tests
|
||||||
Date: Fri, 24 Sep 1999 09:15:02 -0400
|
001: Some of these tests may take a while ...
|
||||||
|
002: Within each section, output should be numbered sequentially
|
||||||
|
003: parsed global definitions
|
||||||
|
004: parsed vrfy()
|
||||||
|
005: parsed prob(str)
|
||||||
|
006: parsed getglobalvar()
|
||||||
|
007: parsed test_booleans()
|
||||||
|
008: parsed test_variables()
|
||||||
|
make: *** [check] Segmentation fault (core dumped)
|
||||||
|
|
||||||
It dies as follows:
|
Other programs have reported problems when compiling -O2 with
|
||||||
|
gcc-2.95.1 on the Alpha and Mips.
|
||||||
|
|
||||||
|
One work-a-round is to not compile with -O2 (perhaps just -O).
|
||||||
|
Another work-a-round is not use gcc-2.95.1.
|
||||||
|
|
||||||
|
* On a Digital UNIX V4.0F (Rev. 1229) on a 500 Mhz 21264, make check
|
||||||
|
dies a horrible death starting in test 600 and 622 gives 100s of
|
||||||
|
messages for calc version 2.11.0t9.2 using the Dec's cc with -O2
|
||||||
|
and without -std0:
|
||||||
|
|
||||||
|
600: Beginning test_bignums
|
||||||
|
601: muldivcheck 1
|
||||||
|
**** abc != acb: 602: muldivcheck 2
|
||||||
|
**** acb != bac: 602: muldivcheck 2
|
||||||
|
...
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
|
**** t5 != a5: 622: algcheck 1
|
||||||
|
**** t6 != a6: 622: algcheck 1
|
||||||
|
**** t4 != a4: 622: algcheck 1
|
||||||
...
|
...
|
||||||
1802: a = surd(2,3)
|
|
||||||
1803: a == surd(2,3)
|
|
||||||
1804: surd_value(a) == 2+3i
|
|
||||||
Segmentation fault
|
|
||||||
|
|
||||||
dbx shows:
|
it finally hangs at test 2000.
|
||||||
signal Segmentation fault at [objcall:155 +0xc,0x1200507b4] index = oap->actions[action];
|
|
||||||
(dbx) where
|
|
||||||
> 0 objcall(action = 14, v1 = 0x1400203d0, v2 = 0x1400203e0, v3 = (nil)) ["obj.c":155, 0x1200507b4]
|
|
||||||
1 comparevalue(v1 = 0x1400203d0, v2 = 0x1400203e0) ["value.c":2329, 0x12007f250]
|
|
||||||
2 o_eq() ["opcodes.c":2659, 0x12003728c]
|
|
||||||
3 calculate(fp = 0x14007fce0) ["opcodes.c":3614, 0x12003942c]
|
|
||||||
4 o_usercall(fp = 0x14007fce0, index = 39, argcount = 0) ["opcodes.c":2602, 0x120037080]
|
|
||||||
5 calculate(fp = 0x14003bfa0) ["opcodes.c":3622, 0x120039488]
|
|
||||||
6 evaluate(nestflag = 14) ["codegen.c":210, 0x120028768]
|
|
||||||
7 getcommands(toplevel = 536864560) ["codegen.c":158, 0x1200285bc]
|
|
||||||
8 getcommands(toplevel = 536864560) ["codegen.c":122, 0x1200284dc]
|
|
||||||
9 main() ["calc.c":279, 0x12001f61c]
|
|
||||||
|
|
||||||
Michel van der List reports that he was using the Dec compiler.
|
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
|
||||||
However On 25-Sep-99 9:18, Ernest Bowen wrote:
|
EMail your bug reports and hopefully patches to fix them.
|
||||||
|
|
||||||
Last night I downloaded 2.11.0t1 and without changing Makefile
|
|
||||||
or anything else did a make and make check. Absolutely no
|
|
||||||
reported errors or warnings and the check "passed all tests".
|
|
||||||
The machine I'm using is a Dec 20 alpha running Digitial
|
|
||||||
UNIX V4.0B (Rev 564).
|
|
||||||
|
|
||||||
Ernest Bowen was using gcc.
|
|
||||||
|
|
||||||
We definitely want to hunt down this Dec's cc compiler issue. It
|
|
||||||
could very well be that gcc is letting something slide where as
|
|
||||||
Dec's cc compiler is compiling it faithfully into core dumping code.
|
|
||||||
The fault could very well be the calc code and not the compiler.
|
|
||||||
|
|
||||||
Any more information on calc core dumps compiled with Dec's cc compiler
|
|
||||||
would be most appreciated!
|
|
||||||
|
551
CHANGES
551
CHANGES
@@ -1,4 +1,465 @@
|
|||||||
Following is the change from calc version 2.11.0t1 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 message to a
|
||||||
|
scanerror message.
|
||||||
|
|
||||||
|
Removed the limit on the number of object types.
|
||||||
|
|
||||||
|
Calc tarballs are now named calc-version.tar.gz and untar into
|
||||||
|
a sub-directory called calc-version.
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
|
||||||
|
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
|
||||||
|
help/wishlist file. Ordered, by priority, help/todo items into
|
||||||
|
Very High, High and Medium priority items.
|
||||||
|
|
||||||
|
The BUGS file now has a 'bugs' section as well as a 'mis-features'
|
||||||
|
section.
|
||||||
|
|
||||||
|
Improved how calc internally dealt with reading EOF or '\0' characters.
|
||||||
|
|
||||||
|
Calc now allows multiple defines to occur on the same line:
|
||||||
|
(Thanks goes to Ernest Bowen <ernie@turing.une.edu.au>)
|
||||||
|
|
||||||
|
define f8300(x) = x^2; define g8300(x) = 1 - x;
|
||||||
|
|
||||||
|
Improved calc's ability to deal with and recover from errors.
|
||||||
|
|
||||||
|
Added inputlevel() builtin to return the input processing level.
|
||||||
|
In an interact mode, inputlevel() returns 0. When directly reading
|
||||||
|
a calc script, inputlevel() returns 1. When reading a script which
|
||||||
|
in turn reads another script, inputlevel() returns 2. etc...
|
||||||
|
|
||||||
|
If $CALCRC has more than one file as in file1:file2 and an error
|
||||||
|
occurs in file1, then calc -c will not read file2.
|
||||||
|
|
||||||
|
Fixed some of the old EMail addresses found in calc documentation.
|
||||||
|
|
||||||
|
Added HAVE_USTAT, HAVE_GETSID, HAVE_GETPGID, HAVE_GETTIME, HAVE_GETPRID
|
||||||
|
and HAVE_URANDOM symbols to the Makefile. These symbols, along with
|
||||||
|
have_ustat.c, have_getsid.c, have_getpgid.c, have_gettime.c and
|
||||||
|
have_getprid.c form: have_ustat.h, have_getsid.h, have_getpgid.h,
|
||||||
|
have_gettime.h, have_getprid.h and have_urandom.h which in turn
|
||||||
|
are used by pseudo_seed() in seed.c to determine what types of
|
||||||
|
system services can be used to form a pseudo-random seed.
|
||||||
|
|
||||||
|
Fixed the way calc -c will continue processing $CALCRC when errors
|
||||||
|
are encountered. Unless -d is also given, calc -c will report
|
||||||
|
when calc is unable to open a $CALCRC file.
|
||||||
|
|
||||||
|
Fixed the lower level make depend rules.
|
||||||
|
|
||||||
|
Misc cleanup on the have_*.c support source files.
|
||||||
|
|
||||||
|
Misc source file cleanup for things such as } else { style consistency.
|
||||||
|
|
||||||
|
Fixed the basis for FNV-1 hashes. Piror to this fix, the hash()
|
||||||
|
builtin produced FNV hash values that did not match the FNV-1
|
||||||
|
algorithm as specified in:
|
||||||
|
|
||||||
|
http://reality.sgi.com/chongo/tech/comp/fnv/index.html
|
||||||
|
|
||||||
|
Removed an unused argument in the function getbody() in codegen.c.
|
||||||
|
|
||||||
|
Encountering of EOF in getbody() will cause a scanerror rather then
|
||||||
|
stop activity. This will now result in a scanerror:
|
||||||
|
|
||||||
|
echo 'define f(x) { ' > myfile
|
||||||
|
calc -i read myfile
|
||||||
|
|
||||||
|
A '{' at the start of a command and a later matching '}' surrounding zero
|
||||||
|
or more statements (and possibly newlines) results in a function body to
|
||||||
|
be "evaluated". This permits another command to follow on the same
|
||||||
|
line as the '}' as in:
|
||||||
|
|
||||||
|
{display(5)} read something;
|
||||||
|
and:
|
||||||
|
{static a = 5} define f(x) = a + x;
|
||||||
|
|
||||||
|
String constants can now be concatenated. For exmaple:
|
||||||
|
|
||||||
|
s = "curds" ' and ' "whey";
|
||||||
|
|
||||||
|
Added FNV hash to the regression test suite.
|
||||||
|
|
||||||
|
Added Ernest Bowen's <ernie@turing.une.edu.au> fix for the
|
||||||
|
FNV regression test of the hash() builtin function.
|
||||||
|
|
||||||
|
Added Ernest Bowen's <ernie@turing.une.edu.au> patch to improve
|
||||||
|
the way config("calc_debug"). Now the lower 4 bits of the
|
||||||
|
config("calc_debug") parameter have the following meaning:
|
||||||
|
|
||||||
|
n Meaning of bit n of config("calc_debug")
|
||||||
|
|
||||||
|
0 Outputs shell commands prior to execution.
|
||||||
|
|
||||||
|
1 Outputs currently active functions when a quit instruction
|
||||||
|
is executed.
|
||||||
|
|
||||||
|
2 Some details of shs, shs1 and md5 hash states are included
|
||||||
|
in the output when these are printed.
|
||||||
|
|
||||||
|
3 When a function constructs a block value, tests are
|
||||||
|
made that the result has the properties required for use of
|
||||||
|
that block, e.g. that the pointer to the start of the
|
||||||
|
block is not NULL, and that its "length" is not negative.
|
||||||
|
A failure will result in a runtime error.
|
||||||
|
|
||||||
|
Changed the meaning of (config("calc_debug") & 1) from only printing
|
||||||
|
the shell commands (and pausing) while displaying help files into
|
||||||
|
the printing of any shell command prior to execution.
|
||||||
|
|
||||||
|
Documented the meaning of config("lib_debug"):
|
||||||
|
|
||||||
|
n Meaning of bit n of config("lib_debug")
|
||||||
|
|
||||||
|
0 When a function is defined, redefined or undefined at
|
||||||
|
interactive level, a message saying what has been done
|
||||||
|
is displayed.
|
||||||
|
|
||||||
|
1 When a function is defined, redefined or undefined during
|
||||||
|
the reading of a file, a message saying what has been done
|
||||||
|
is displayed.
|
||||||
|
|
||||||
|
The value for config("lib_debug") in both oldstd and newstd is
|
||||||
|
3, but if calc is invoked with the -d flag, its initial value
|
||||||
|
is zero. Thus, if calc is started without the -d flag, until
|
||||||
|
config("lib_debug") is changed, a message will be output when a
|
||||||
|
function is defined either interactively or during the reading
|
||||||
|
of a file.
|
||||||
|
|
||||||
|
Changed the calc lib files to reflect the new config("lib_debug")
|
||||||
|
bit field meaning. Calc lib files that need to print extra information
|
||||||
|
should now do something such as:
|
||||||
|
|
||||||
|
if (config("lib_debug") & 3) {
|
||||||
|
print "obj xyz defined";
|
||||||
|
print "funcA([val1 [, val2]]) defined";
|
||||||
|
print "funcB(size, mass, ...) defined";
|
||||||
|
}
|
||||||
|
|
||||||
|
Fixed the help/custom_cal, help/new_custom, and help/copy files so
|
||||||
|
that they contain the correct contents instead of the 'usage' file.
|
||||||
|
|
||||||
|
Fixed problem with loss of bindings when calc -i args runs into
|
||||||
|
an error while processing 'args' and drops into interactive mode
|
||||||
|
without the terminal bindings being set.
|
||||||
|
|
||||||
|
Added patch from Ernest Bowen to extablish the abort command as
|
||||||
|
well as to clarify the roles of quit and exit. See the help/command
|
||||||
|
file for details.
|
||||||
|
|
||||||
|
Updated to some extend, the help/statement and help/command help
|
||||||
|
files with new information about SHOW, QUIT, EXIT and ABORT.
|
||||||
|
|
||||||
|
Added show sizes to pzasusb8.cal.
|
||||||
|
|
||||||
|
Updated calc man page and help/usage file to reflect recent
|
||||||
|
command line changes.
|
||||||
|
|
||||||
|
Fixed a bug, reported by Michael Somos <somos@grail.cba.csuohio.edu>,
|
||||||
|
which prevented calc -m from being used.
|
||||||
|
|
||||||
|
Fixed misc compiler warnings.
|
||||||
|
|
||||||
|
|
||||||
|
Following is the change from calc version 2.11.0t7 to 2.11.0t7.5:
|
||||||
|
|
||||||
|
Calc has some new command line flags / command line meaning:
|
||||||
|
(Thanks goes to Ernest Bowen <ernie@turing.une.edu.au>)
|
||||||
|
|
||||||
|
-i Go into interactive mode if possible.
|
||||||
|
|
||||||
|
-c Continue reading command lines even after an execution
|
||||||
|
error has caused the abandonment of a line
|
||||||
|
|
||||||
|
To understand the -i and -c effects, consider the following
|
||||||
|
file (call it myfile.cal) which has deliberate errors in it:
|
||||||
|
|
||||||
|
print 1;
|
||||||
|
mat A[1] = {2,3};
|
||||||
|
print 2;
|
||||||
|
epsilon(-1);
|
||||||
|
print 3;
|
||||||
|
|
||||||
|
calc read myfile
|
||||||
|
|
||||||
|
Reports an error on the 2nd line and exits; prints 1 only.
|
||||||
|
|
||||||
|
calc -c read myfile
|
||||||
|
|
||||||
|
Report errors on the 2nd and 4th lines and exits; prints 1,2 and 3.
|
||||||
|
|
||||||
|
calc -i read myfile
|
||||||
|
|
||||||
|
Report errors on the 2nd and gives you a prompt; prints 1 only.
|
||||||
|
|
||||||
|
calc -i -c read myfile
|
||||||
|
|
||||||
|
Report errors on the 2nd and 4th and gives you a prompt;
|
||||||
|
prints 1, 2 and 3.
|
||||||
|
|
||||||
|
cat myfile | calc
|
||||||
|
|
||||||
|
Reports an error on the 2nd line and exits; prints 1 only.
|
||||||
|
|
||||||
|
cat myfile | calc -c
|
||||||
|
|
||||||
|
Report errors on the 2nd and 4th lines and exits; prints 1,2 and 3.
|
||||||
|
|
||||||
|
Note that continuation refers to command lines, not to statements. So:
|
||||||
|
|
||||||
|
calc -c 'print "start"; mat A[1] = {2,3}; print "end";'
|
||||||
|
|
||||||
|
since it contains no newline, the whole string is compiled,
|
||||||
|
but execution is abandoned when the error is encountered and
|
||||||
|
the string ``end'' is not printed.
|
||||||
|
|
||||||
|
You can use your shell to supply newlines in your command line
|
||||||
|
arguments. For example in sh, ksh, bash:
|
||||||
|
|
||||||
|
calc -c 'print "start";
|
||||||
|
mat A[1] = {2,3};
|
||||||
|
print "end";'
|
||||||
|
|
||||||
|
will print both ``start'' and ``end''. C-shell users can do:
|
||||||
|
|
||||||
|
calc -c 'print "start"; \
|
||||||
|
mat A[1] = {2,3}; \
|
||||||
|
print "end";'
|
||||||
|
|
||||||
|
however sh, ksh, bash will not see ``end'' printed because their
|
||||||
|
shell will remove the internal newlines.
|
||||||
|
|
||||||
|
Added display(n) builtin which does almost the same as config("display",n)
|
||||||
|
except that rather than causing an execution with an out-of-range or
|
||||||
|
bad-type argument type, it simply writes a message to stderr. This
|
||||||
|
also now happens to the errmax() builtin.
|
||||||
|
|
||||||
|
Added qtime.cal to the standard calc library.
|
||||||
|
|
||||||
|
Added another command line flag to calc:
|
||||||
|
|
||||||
|
-d Disable display of the opening title and config("lib_debug",0)
|
||||||
|
|
||||||
|
The command:
|
||||||
|
|
||||||
|
calc 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will output something like:
|
||||||
|
|
||||||
|
qtime(utc_hr_offset) defined
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
whereas:
|
||||||
|
|
||||||
|
calc -d 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will just say:
|
||||||
|
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
A call of errmax(-1) will prevent errcount from aborting calc.
|
||||||
|
|
||||||
|
Add the function stoponerror(n) which, as the name implies, controls
|
||||||
|
if calc stop on an error based on the value of n:
|
||||||
|
|
||||||
|
n > 0 stop on error even if -c was given on the command line
|
||||||
|
n == 0 if -c, continue, without -c, stop
|
||||||
|
n < 0 continue on error, even if -c was given on the command line
|
||||||
|
|
||||||
|
Calc compilation now stops at the first scanerror.
|
||||||
|
|
||||||
|
Restored the feature where -p disables the printing of leading tabs
|
||||||
|
as of config("tab",0) had been executed. So using calc in a pipe:
|
||||||
|
|
||||||
|
calc -p 2+17 | whey
|
||||||
|
|
||||||
|
will write '19' instead of '\t19' to the whey command.
|
||||||
|
|
||||||
|
Updated calc man page and help/usage file to reflect recent
|
||||||
|
command line changes.
|
||||||
|
|
||||||
|
Converted start_done into a general calc run state enum called
|
||||||
|
run_state within the calc source.
|
||||||
|
|
||||||
|
Removed README.OLD.
|
||||||
|
|
||||||
|
Added the Makefile variable ${LCC} to invoke the local c compiler.
|
||||||
|
By default, ${CC} also run the ${LCC} compiler. The distinction is
|
||||||
|
useful when using something such as purify. In the case of ${LCC},
|
||||||
|
only the local C compiler is invoked. In the case of ${CC} a purify
|
||||||
|
compile is invoked. Only the source that must be compiled and run
|
||||||
|
on the local machine use ${LCC}; everything else uses ${CC}.
|
||||||
|
|
||||||
|
Fixed memory buffer ovreread problem in eatstring() in token.c.
|
||||||
|
|
||||||
|
Fixed memory leaks related to putenv().
|
||||||
|
|
||||||
|
Fixed memory leaks realted to srandom().
|
||||||
|
|
||||||
|
Fixed compilation warnings and problems on BSDI.
|
||||||
|
|
||||||
|
Removed ${CCMAIN} as a variable from the Makefile. Now files
|
||||||
|
use either ${CFLAGS} for general C source and ${ICFLAGS} for
|
||||||
|
intermediate C source (e.g., special code for building hsrc files).
|
||||||
|
|
||||||
|
The main calc URL is now:
|
||||||
|
|
||||||
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
|
||||||
|
Misc calc man page fixes.
|
||||||
|
|
||||||
|
|
||||||
|
Following is the change from calc version 2.11.0t1 to 2.11.0t6.3:
|
||||||
|
|
||||||
Removed the makefile symbol MAIN. Now forcing all functions to correctly
|
Removed the makefile symbol MAIN. Now forcing all functions to correctly
|
||||||
be declared main. To satisfy some old broken compilers, a return 0;
|
be declared main. To satisfy some old broken compilers, a return 0;
|
||||||
@@ -25,17 +486,19 @@ Following is the change from calc version 2.11.0t1 to date:
|
|||||||
porting calc to C++! We will NOT support C++ compilation of calc.
|
porting calc to C++! We will NOT support C++ compilation of calc.
|
||||||
Calc will written ANSI C. We just compiled with a suggestion from
|
Calc will written ANSI C. We just compiled with a suggestion from
|
||||||
Love-Jensen, John <jlove-jensen@globalmt.com> to make calc's version
|
Love-Jensen, John <jlove-jensen@globalmt.com> to make calc's version
|
||||||
of C a little more to C++ compilers. Avoiding symbols such as new
|
of C a little more to C++ compilers. We are simply avoiding symbols
|
||||||
or try for example.
|
such as new or try for example.
|
||||||
|
|
||||||
Updated README.FIRST and BUGS to reflect new URLs and addresses.
|
Renamed README to README.OLD. Renamed README.FIRST to README.
|
||||||
|
Updated README, lib/README and BUGS to reflect new URLs and addresses.
|
||||||
|
|
||||||
Added a HOWTO.INSTALL file.
|
Added a HOWTO.INSTALL file.
|
||||||
|
|
||||||
Reordered cc Makefile variable sets in the main Makefile.
|
Reordered cc Makefile variable sets in the main Makefile.
|
||||||
|
|
||||||
Fixed a bug and applied a fix that was reported by Ernest Bowen
|
Fixed a bug in hnrmod() and applied a fix that was reported by Ernest
|
||||||
<ernie@turing.une.edu.au>. Added regression tests 1103 to 1112.
|
Bowen <ernie@turing.une.edu.au>. Added regression tests 1103 to
|
||||||
|
1112 to confirm the fix.
|
||||||
|
|
||||||
Fixed a bug in version.c related to MINOR_PATCHs in both the
|
Fixed a bug in version.c related to MINOR_PATCHs in both the
|
||||||
empty and non-empty MINOR_PATCH cases.
|
empty and non-empty MINOR_PATCH cases.
|
||||||
@@ -78,15 +541,6 @@ Following is the change from calc version 2.11.0t1 to date:
|
|||||||
|
|
||||||
The custom.c file is now compiled with full ${CFLAGS}.
|
The custom.c file is now compiled with full ${CFLAGS}.
|
||||||
|
|
||||||
### XXX - this change has been backed out:
|
|
||||||
#
|
|
||||||
# Thanks to the efforts of Ernest Bowen <ernie@neumann.une.edu.au> and
|
|
||||||
# Dr.D.J.Picton <dave@aps5.ph.bham.ac.uk>, a nasty endian-ness bug
|
|
||||||
# in the sha and sha1 hash functions that showed up on machines such
|
|
||||||
# as the Sparc was fixed.
|
|
||||||
#
|
|
||||||
###
|
|
||||||
|
|
||||||
Rewrote command line / argument processing code. Calc is now
|
Rewrote command line / argument processing code. Calc is now
|
||||||
using getopt(3) argument processing.
|
using getopt(3) argument processing.
|
||||||
|
|
||||||
@@ -113,14 +567,12 @@ Following is the change from calc version 2.11.0t1 to date:
|
|||||||
|
|
||||||
Fixed memory leaks in zsrand() in zrand.c.
|
Fixed memory leaks in zsrand() in zrand.c.
|
||||||
|
|
||||||
Fixed a memory leak in zsrandom1() in zrandom.c.
|
Fixed a memory leak in zsrandom1() in zrandom.c. Fixed memory
|
||||||
|
leaks associated with replacing the internal random state with
|
||||||
|
another random state.
|
||||||
|
|
||||||
Added seed() builtin to return a 64 bit seed for a
|
Added seed() builtin to return a 64 bit seed for a
|
||||||
psuedo-random generator.
|
pseudo-random generator.
|
||||||
|
|
||||||
Added functionality from Ernest Bowen <ernie@turing.une.edu.au>
|
|
||||||
to give arguments as well as function names after definitions when
|
|
||||||
calc_debug >= 0.
|
|
||||||
|
|
||||||
Added functionality from Ernest Bowen <ernie@turing.une.edu.au> to
|
Added functionality from Ernest Bowen <ernie@turing.une.edu.au> to
|
||||||
permit nested "= {...}" assignments for lists as well as matrices
|
permit nested "= {...}" assignments for lists as well as matrices
|
||||||
@@ -145,6 +597,57 @@ Following is the change from calc version 2.11.0t1 to date:
|
|||||||
freeglobals() at the end of the test suite to free storage
|
freeglobals() at the end of the test suite to free storage
|
||||||
consumed during the regression.
|
consumed during the regression.
|
||||||
|
|
||||||
|
Added custom function custom("pzasusb8", n) and lib/pzasusb8.cal based on
|
||||||
|
Ernest Bowen's diagnostic patch.
|
||||||
|
|
||||||
|
Thanks to the efforts of Ernest Bowen <ernie@neumann.une.edu.au> and
|
||||||
|
Dr.D.J.Picton <dave@aps5.ph.bham.ac.uk>, a nasty endian-ness bug
|
||||||
|
in the sha and sha1 hash functions that showed up on machines such
|
||||||
|
as the Sparc was fixed.
|
||||||
|
|
||||||
|
Added functionality from Ernest Bowen <ernie@turing.une.edu.au>
|
||||||
|
to give arguments as well as function names after definitions when
|
||||||
|
config("lib_debug") >= 0.
|
||||||
|
|
||||||
|
Removed if (config("lib_debug") >= 0) { ... } the ends of most
|
||||||
|
of the calc library scripts because it was redundant with the
|
||||||
|
new config("lib_debug") >= 0 functionality. Some of the calc
|
||||||
|
library still has a partial section because some useful
|
||||||
|
additional information was being printed:
|
||||||
|
|
||||||
|
chrem.cal deg.cal lucas_tbl.cal randrun.cal
|
||||||
|
mfactor.cal mod.cal poly.cal seedrandom.cal
|
||||||
|
surd.cal varargs.cal
|
||||||
|
|
||||||
|
Fixed ellip.cal so that its defined function does not conflict with
|
||||||
|
the factor() builtin function.
|
||||||
|
|
||||||
|
Fixed mod.cal so that a defined function does not conflict with
|
||||||
|
the mod() builtin function.
|
||||||
|
|
||||||
|
The regression test suite now reads in most calc libs. A few
|
||||||
|
libs are not read because they, by design, produce output
|
||||||
|
when read even when config("lib_debug") is set to -1.
|
||||||
|
|
||||||
|
Increased the maximum number of object types that one can define
|
||||||
|
from 10 to 128.
|
||||||
|
|
||||||
|
Added a patch from Ernest Bowen <ernie@turing.une.edu.au>
|
||||||
|
to correctly hash a V_STR value-type that has an \0 byte
|
||||||
|
inside it.
|
||||||
|
|
||||||
|
A patch from Ernest Bowen <ernie@turing.une.edu.au> now defines
|
||||||
|
special meaning to the first 2 bits of config("lib_debug"):
|
||||||
|
|
||||||
|
bit 0 set => messages printed when inputisterminal
|
||||||
|
bit 1 set => messages printed when reading from a file
|
||||||
|
|
||||||
|
The lib/regress.cal regression suite does:
|
||||||
|
|
||||||
|
config("lib_debug", -4);
|
||||||
|
|
||||||
|
to eliminate lib messages (both bit 0 and bit 1 are not set).
|
||||||
|
|
||||||
Fixed misc compile warnings and notices.
|
Fixed misc compile warnings and notices.
|
||||||
|
|
||||||
|
|
||||||
@@ -3529,9 +4032,6 @@ Following is the change from calc version 2.9.3t8 to 2.9.3t9.2:
|
|||||||
|
|
||||||
Following is the change from calc version 2.9.3t7 to 2.9.3t7:
|
Following is the change from calc version 2.9.3t7 to 2.9.3t7:
|
||||||
|
|
||||||
WARNING: This patch is an beta test patch by chongo@toad.com
|
|
||||||
(Landon Curt Noll).
|
|
||||||
|
|
||||||
The 'show' command by itself will issue an error message
|
The 'show' command by itself will issue an error message
|
||||||
that will remind one of the possible show arguments.
|
that will remind one of the possible show arguments.
|
||||||
(thanks to Ha S. Lam <hl@kuhep4.phsx.ukans.edu>)
|
(thanks to Ha S. Lam <hl@kuhep4.phsx.ukans.edu>)
|
||||||
@@ -3579,9 +4079,6 @@ Following is the change from calc version 2.9.3t7 to 2.9.3t7:
|
|||||||
|
|
||||||
Following is the change from calc version 2.9.2 to 2.9.3t7:
|
Following is the change from calc version 2.9.2 to 2.9.3t7:
|
||||||
|
|
||||||
WARNING: This patch is an beta test patch by chongo@toad.com
|
|
||||||
(Landon Curt Noll).
|
|
||||||
|
|
||||||
Calc can now compile on OSF/1, SGI and IBM RS6000 systems.
|
Calc can now compile on OSF/1, SGI and IBM RS6000 systems.
|
||||||
|
|
||||||
A number of systems that have both <varargs.h> and <stdarg.h> do
|
A number of systems that have both <varargs.h> and <stdarg.h> do
|
||||||
|
@@ -50,3 +50,6 @@ Installing calc in 4 easy steps:
|
|||||||
4) install calc:
|
4) install calc:
|
||||||
|
|
||||||
make install
|
make install
|
||||||
|
|
||||||
|
We suggest that you might want to read the README file and look at
|
||||||
|
the calc help subsystem. See the README file for details.
|
||||||
|
125
README
125
README
@@ -1,73 +1,90 @@
|
|||||||
# Copyright (c) 1997 David I. Bell
|
Dear calc user,
|
||||||
# Permission is granted to use, distribute, or modify this source,
|
|
||||||
# provided that this copyright notice remains intact.
|
|
||||||
#
|
|
||||||
# Arbitrary precision calculator.
|
|
||||||
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
See the HOWTO.INSTALL file for information on how to build and install calc.
|
||||||
NOTE: This is an old historic README. We recommend that you
|
|
||||||
read README.FIRST and HOWTO.INSTALL for more info.
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
I am allowing this calculator to be freely distributed for your enjoyment.
|
To be sure that your version of calc is up to date, check out:
|
||||||
Like all multi-precision programs, you should not depend absolutely on
|
|
||||||
its results, since bugs in such programs can be insidious and only rarely
|
|
||||||
show up.
|
|
||||||
|
|
||||||
-dbell-
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
p.s. By Landon Curt Noll:
|
We are interested in any/all feedback on recent versions of calc.
|
||||||
|
In particular we would like to hear about:
|
||||||
|
|
||||||
Building calc in 3 easy steps:
|
* compiler warnings
|
||||||
|
* compile problems
|
||||||
|
* regression test problems (try: make check)
|
||||||
|
* special compile flags/options that you needed
|
||||||
|
* Makefile problems
|
||||||
|
* help file problems
|
||||||
|
* misc nits and typos
|
||||||
|
|
||||||
1) Look at the makefile, and adjust it to suit your needs.
|
We would like to offer a clean compile across a wide verity of platforms,
|
||||||
|
so if you can test on several, so much the better!
|
||||||
|
|
||||||
Here are some Makefile hints:
|
If you run into problems, see the BUGS file.
|
||||||
|
|
||||||
In the past, some people have had to adjust the VARARG or
|
|
||||||
TERMCONTROL because the Makefile cannot always guess
|
|
||||||
correctly for certain systems. You may need to play with
|
|
||||||
these values if you experience problems.
|
|
||||||
|
|
||||||
The default compiler used is 'cc'. The default compiler flag
|
|
||||||
is '-O'. If you have gcc, or gcc v2 (or better) you should use
|
|
||||||
that instead. Some compilers allow for optimization beyond
|
|
||||||
just -O (gcc v2 has -O2, mips cc has -O3). You should select
|
|
||||||
the best flag for speed optimization. Calc can be cpu intensive
|
|
||||||
so selecting a quality compiler and good optimization level can
|
|
||||||
really pay off.
|
|
||||||
|
|
||||||
2) build calc:
|
|
||||||
|
|
||||||
make all
|
|
||||||
|
|
||||||
3) test calc:
|
|
||||||
|
|
||||||
make check
|
|
||||||
|
|
||||||
==>>>If you run into problems, follow the instructions in the BUGS file<<<==
|
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
For further reading:
|
Calc is distributed with an extensive collection of help files that
|
||||||
|
are accessible from the command line. The following assume that you
|
||||||
|
are running calc from the distribution directory or that you have
|
||||||
|
installed calc. In these examples, the ">" is the calc prompt, not
|
||||||
|
something that you type in.
|
||||||
|
|
||||||
LIBRARY
|
For list of help topics:
|
||||||
explains how programs can use libcalc.a to take advantage
|
|
||||||
of the calc multi-precision routines.
|
> help
|
||||||
|
|
||||||
|
For overview of calc overview:
|
||||||
|
|
||||||
|
> help intro
|
||||||
|
> help overview
|
||||||
|
> help command
|
||||||
|
> help define
|
||||||
|
> help statement
|
||||||
|
> help variable
|
||||||
|
> help usage
|
||||||
|
|
||||||
|
For list of builtin functions:
|
||||||
|
|
||||||
|
> help builtin
|
||||||
|
|
||||||
|
C programmers should note some unexpected differences in the calc syntax:
|
||||||
|
|
||||||
|
> help unexpected
|
||||||
|
|
||||||
|
Calc is shipped with a library of calc scripts. For a list see:
|
||||||
|
|
||||||
|
> help stdlib
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
See the file:
|
||||||
|
|
||||||
help/todo
|
help/todo
|
||||||
current wish list for calc
|
help/wishlist
|
||||||
|
|
||||||
CHANGES
|
or run:
|
||||||
recent changes to calc
|
|
||||||
|
|
||||||
BUGS
|
calc help todo
|
||||||
known bugs, mis-features and how to report problems
|
calc help wishlist
|
||||||
|
|
||||||
help/full
|
for a wish/todo list. Code contributions are welcome.
|
||||||
full set of calc documentation
|
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
David I. Bell dbell@auug.org.au
|
To join the calc-tester mailing list. Send a request to:
|
||||||
chongo@toad.com <Landon Curt Noll -- chongo@toad.com> /\../\
|
|
||||||
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
|
|
||||||
|
Your message body (not the subject) should consist of:
|
||||||
|
|
||||||
|
subscribe calc-tester address
|
||||||
|
end
|
||||||
|
name your_full_name
|
||||||
|
|
||||||
|
where ``address'' is your EMail address and ``your_full_name'' is
|
||||||
|
your full name.
|
||||||
|
|
||||||
|
The calc web site is located at:
|
||||||
|
|
||||||
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
54
README.FIRST
54
README.FIRST
@@ -1,54 +0,0 @@
|
|||||||
Dear calc user,
|
|
||||||
|
|
||||||
See the HOWTO.INSTALL file for information on how to build and install calc.
|
|
||||||
|
|
||||||
To be sure that your version of calc is up to date, check out:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc/calc-download.html
|
|
||||||
|
|
||||||
We are interested in any/all feedback on recent versions of calc.
|
|
||||||
In particular we would like to hear about:
|
|
||||||
|
|
||||||
* compiler warnings
|
|
||||||
* compile problems
|
|
||||||
* regression test problems (try: make check)
|
|
||||||
* special compile flags/options that you needed
|
|
||||||
* Makefile problems
|
|
||||||
* help file problems
|
|
||||||
* misc nits and typos
|
|
||||||
|
|
||||||
We would like to offer a clean compile across a wide verity of platforms,
|
|
||||||
so if you can test on several, so much the better!
|
|
||||||
|
|
||||||
If you run into problems, see the BUGS file.
|
|
||||||
|
|
||||||
=-=
|
|
||||||
|
|
||||||
See the file:
|
|
||||||
|
|
||||||
help/todo
|
|
||||||
|
|
||||||
or run:
|
|
||||||
|
|
||||||
calc 'help todo'
|
|
||||||
|
|
||||||
for a wish/todo list. Code contributions are welcome.
|
|
||||||
|
|
||||||
=-=
|
|
||||||
|
|
||||||
To join the calc-tester mailing list. Send a request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
|
||||||
|
|
||||||
subscribe calc-tester address
|
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where ``address'' is your EMail address and ``your_full_name'' is
|
|
||||||
your full name.
|
|
||||||
|
|
||||||
The calc web site is located at:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc
|
|
11
addop.c
11
addop.c
@@ -164,7 +164,8 @@ endfunc(void)
|
|||||||
size += dumpop(&fp->f_opcodes[size]);
|
size += dumpop(&fp->f_opcodes[size]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (inputisterminal() || conf->lib_debug >= 0) {
|
if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
|
||||||
|
(!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC)) {
|
||||||
printf("%s(", fp->f_name);
|
printf("%s(", fp->f_name);
|
||||||
for (index = 0; index < fp->f_paramcount; index++) {
|
for (index = 0; index < fp->f_paramcount; index++) {
|
||||||
if (index)
|
if (index)
|
||||||
@@ -237,7 +238,8 @@ rmuserfunc(char *name)
|
|||||||
return;
|
return;
|
||||||
freenumbers(functions[index]);
|
freenumbers(functions[index]);
|
||||||
free(functions[index]);
|
free(functions[index]);
|
||||||
if (!inputisterminal() && conf->lib_debug >= 0)
|
if ((inputisterminal() && conf->lib_debug & LIBDBG_STDIN_FUNC) ||
|
||||||
|
(!inputisterminal() && conf->lib_debug & LIBDBG_FILE_FUNC))
|
||||||
printf("%s() undefined\n", name);
|
printf("%s() undefined\n", name);
|
||||||
functions[index] = NULL;
|
functions[index] = NULL;
|
||||||
}
|
}
|
||||||
@@ -447,6 +449,11 @@ addop(long op)
|
|||||||
case OP_GLOBALADDR:
|
case OP_GLOBALADDR:
|
||||||
diff = 1 + PTR_SIZE;
|
diff = 1 + PTR_SIZE;
|
||||||
break;
|
break;
|
||||||
|
case OP_UNDEF:
|
||||||
|
fp->f_opcodecount -= 1;
|
||||||
|
oldop = OP_NOP;
|
||||||
|
oldoldop = OP_NOP;
|
||||||
|
return;
|
||||||
default:
|
default:
|
||||||
cut = FALSE;
|
cut = FALSE;
|
||||||
}
|
}
|
||||||
|
@@ -3,7 +3,10 @@
|
|||||||
*
|
*
|
||||||
* This file was written by:
|
* This file was written by:
|
||||||
*
|
*
|
||||||
* Landon Curt Noll (chongo@toad.com) chongo <was here> /\../\
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
*
|
*
|
||||||
* This code has been placed in the public domain. Please do not
|
* This code has been placed in the public domain. Please do not
|
||||||
* copyright this code.
|
* copyright this code.
|
||||||
|
@@ -57,7 +57,7 @@ associndex(ASSOC *ap, BOOL create, long dim, VALUE *indices)
|
|||||||
* so that we can first select the correct hash chain, and
|
* so that we can first select the correct hash chain, and
|
||||||
* also so we can quickly compare each element for a match.
|
* also so we can quickly compare each element for a match.
|
||||||
*/
|
*/
|
||||||
hash = (QCKHASH)0;
|
hash = FNV1_32_BASIS;
|
||||||
for (i = 0; i < dim; i++)
|
for (i = 0; i < dim; i++)
|
||||||
hash = hashvalue(&indices[i], hash);
|
hash = hashvalue(&indices[i], hash);
|
||||||
|
|
||||||
|
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 chongo@toad.com
|
* ernie@neumann.une.edu.au and http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
28
block.c
28
block.c
@@ -27,12 +27,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@@ -106,7 +104,7 @@ blkalloc(int len, int chunk)
|
|||||||
/*
|
/*
|
||||||
* return BLOCK
|
* return BLOCK
|
||||||
*/
|
*/
|
||||||
if (conf->calc_debug > 0) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(nblk);
|
blkchk(nblk);
|
||||||
}
|
}
|
||||||
return nblk;
|
return nblk;
|
||||||
@@ -147,13 +145,11 @@ blk_free(BLOCK *blk)
|
|||||||
* debug time, we plan to call this function often. Once we are satisfied,
|
* debug time, we plan to call this function often. Once we are satisfied,
|
||||||
* we will normally call this code only in a few places.
|
* we will normally call this code only in a few places.
|
||||||
*
|
*
|
||||||
* This function is normally called whenever the following builtins are called:
|
* If "calc_debug" has the bit corresponding to CALCDBG_BLOCK set, this
|
||||||
|
* function is called during execution of the following builtins:
|
||||||
*
|
*
|
||||||
* alloc(), realloc(), free()
|
* alloc(), realloc(), free()
|
||||||
*
|
*
|
||||||
* unless the "calc_debug" is set to -1. If "calc_debug" is > 0, then
|
|
||||||
* most blk builtins will call this function.
|
|
||||||
*
|
|
||||||
* given:
|
* given:
|
||||||
* blk - the BLOCK to check
|
* blk - the BLOCK to check
|
||||||
*
|
*
|
||||||
@@ -168,7 +164,7 @@ blkchk(BLOCK *blk)
|
|||||||
/*
|
/*
|
||||||
* firewall - general sanity check
|
* firewall - general sanity check
|
||||||
*/
|
*/
|
||||||
if (conf->calc_debug == -1) {
|
if ((conf->calc_debug & CALCDBG_BLOCK) == 0) {
|
||||||
/* do nothing when debugging is disabled */
|
/* do nothing when debugging is disabled */
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -233,7 +229,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
|
|||||||
/*
|
/*
|
||||||
* firewall
|
* firewall
|
||||||
*/
|
*/
|
||||||
if (conf->calc_debug != -1) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(blk);
|
blkchk(blk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -292,7 +288,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
|
|||||||
memset(blk->data, 0, blk->maxsize);
|
memset(blk->data, 0, blk->maxsize);
|
||||||
}
|
}
|
||||||
blk->datalen = 0;
|
blk->datalen = 0;
|
||||||
if (conf->calc_debug > 0) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(blk);
|
blkchk(blk);
|
||||||
}
|
}
|
||||||
return blk;
|
return blk;
|
||||||
@@ -323,7 +319,7 @@ blkrealloc(BLOCK *blk, int newlen, int newchunk)
|
|||||||
/*
|
/*
|
||||||
* return realloced type
|
* return realloced type
|
||||||
*/
|
*/
|
||||||
if (conf->calc_debug > 0) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(blk);
|
blkchk(blk);
|
||||||
}
|
}
|
||||||
return blk;
|
return blk;
|
||||||
@@ -351,7 +347,7 @@ blktrunc(BLOCK *blk)
|
|||||||
/*
|
/*
|
||||||
* firewall
|
* firewall
|
||||||
*/
|
*/
|
||||||
if (conf->calc_debug != -1) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(blk);
|
blkchk(blk);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -372,7 +368,7 @@ blktrunc(BLOCK *blk)
|
|||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
blk->data[0] = (USB8)0;
|
blk->data[0] = (USB8)0;
|
||||||
if (conf->calc_debug > 0) {
|
if (conf->calc_debug & CALCDBG_BLOCK) {
|
||||||
blkchk(blk);
|
blkchk(blk);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
8
block.h
8
block.h
@@ -27,12 +27,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
267
calc.c
267
calc.c
@@ -11,7 +11,6 @@
|
|||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <setjmp.h>
|
|
||||||
|
|
||||||
#define CALC_C
|
#define CALC_C
|
||||||
#include "calc.h"
|
#include "calc.h"
|
||||||
@@ -37,33 +36,12 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* external definitions and functions
|
|
||||||
*/
|
|
||||||
extern int abortlevel; /* current level of aborts */
|
|
||||||
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
|
||||||
extern jmp_buf jmpbuf; /* for errors */
|
|
||||||
extern int isatty(int tty); /* TRUE if fd is a tty */
|
|
||||||
|
|
||||||
extern int p_flag; /* TRUE => pipe mode */
|
|
||||||
extern int q_flag; /* TRUE => don't execute rc files */
|
|
||||||
extern int u_flag; /* TRUE => unbuffer stdin and stdout */
|
|
||||||
|
|
||||||
extern char *pager; /* $PAGER or default */
|
|
||||||
extern int stdin_tty; /* TRUE if stdin is a tty */
|
|
||||||
extern int interactive; /* TRUE if interactive session (no cmd args) */
|
|
||||||
extern char *program; /* our name */
|
|
||||||
extern char cmdbuf[]; /* command line expression */
|
|
||||||
|
|
||||||
extern char *version(void); /* return version string */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* static definitions and functions
|
* static definitions and functions
|
||||||
*/
|
*/
|
||||||
static char *usage = "usage: %s [-C] [-e] [-h] [-i] [-m mode] [-n] [-p]\n"
|
static char *usage = "usage: %s [-c] [-C] [-d] [-e] [-h] [-i] [-m mode]\n"
|
||||||
"\t[-q] [-u] [[--] calc_cmd ...]\n";
|
"\t[-D calc_debug[:lib_debug:[user_debug]]]\n"
|
||||||
|
"\t[-n] [-p] [-q] [-u] [-v] [[--] calc_cmd ...]\n";
|
||||||
static void intint(int arg); /* interrupt routine */
|
static void intint(int arg); /* interrupt routine */
|
||||||
|
|
||||||
|
|
||||||
@@ -78,13 +56,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:npquv")) != -1) {
|
while ((c = getopt(argc, argv, "Cehim:npquvcdD:")) != -1) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
case 'C':
|
case 'C':
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
@@ -107,10 +86,10 @@ main(int argc, char **argv)
|
|||||||
want_defhelp = 1;
|
want_defhelp = 1;
|
||||||
break;
|
break;
|
||||||
case 'i':
|
case 'i':
|
||||||
ign_errmax = TRUE;
|
i_flag = TRUE;
|
||||||
break;
|
break;
|
||||||
case 'm':
|
case 'm':
|
||||||
if (optarg[1] == '\0' || *optarg<'0' || *optarg>'7') {
|
if (optarg[1] != '\0' || *optarg<'0' || *optarg>'7') {
|
||||||
/*
|
/*
|
||||||
* we are too early in processing to
|
* we are too early in processing to
|
||||||
* call libcalc_call_me_last()
|
* call libcalc_call_me_last()
|
||||||
@@ -136,6 +115,12 @@ main(int argc, char **argv)
|
|||||||
case 'u':
|
case 'u':
|
||||||
u_flag = TRUE;
|
u_flag = TRUE;
|
||||||
break;
|
break;
|
||||||
|
case 'c':
|
||||||
|
c_flag = TRUE;
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
d_flag = TRUE;
|
||||||
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
/*
|
/*
|
||||||
* we are too early in processing to call
|
* we are too early in processing to call
|
||||||
@@ -143,6 +128,26 @@ 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
|
||||||
@@ -152,7 +157,7 @@ main(int argc, char **argv)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
interactive = (optind >= argc);
|
havecommands = (optind < argc);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* look at the length of any trailing command args
|
* look at the length of any trailing command args
|
||||||
@@ -201,8 +206,9 @@ main(int argc, char **argv)
|
|||||||
* initialize
|
* initialize
|
||||||
*/
|
*/
|
||||||
libcalc_call_me_first();
|
libcalc_call_me_first();
|
||||||
stdin_tty = TRUE; /* assume internactive default */
|
stdin_tty = isatty(0); /* assume stdin is on fd 0 */
|
||||||
conf->tab_ok = TRUE; /* assume internactive default */
|
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();
|
||||||
@@ -212,22 +218,13 @@ main(int argc, char **argv)
|
|||||||
/*
|
/*
|
||||||
* if allowed or needed, print version and setup bindings
|
* if allowed or needed, print version and setup bindings
|
||||||
*/
|
*/
|
||||||
if (interactive) {
|
if (!havecommands && stdin_tty) {
|
||||||
/*
|
if (!d_flag) {
|
||||||
* check for pipe mode and/or non-tty stdin
|
|
||||||
*/
|
|
||||||
if (!p_flag) {
|
|
||||||
stdin_tty = isatty(0); /* assume stdin is on fd 0 */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* if tty, setup bindings
|
|
||||||
*/
|
|
||||||
if (stdin_tty) {
|
|
||||||
printf("%s (version %s)\n", CALC_TITLE, version());
|
printf("%s (version %s)\n", CALC_TITLE, version());
|
||||||
printf("[%s]\n\n",
|
printf("[%s]\n\n",
|
||||||
"Type \"exit\" to exit, or \"help\" for help.");
|
"Type \"exit\" to exit, or \"help\" for help.");
|
||||||
switch (hist_init(calcbindings)) {
|
}
|
||||||
|
switch (hist_init(calcbindings)) {
|
||||||
case HIST_NOFILE:
|
case HIST_NOFILE:
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"%s: Cannot open bindings file \"%s\", "
|
"%s: Cannot open bindings file \"%s\", "
|
||||||
@@ -240,7 +237,6 @@ main(int argc, char **argv)
|
|||||||
"%s: Cannot set terminal modes, "
|
"%s: Cannot set terminal modes, "
|
||||||
"fancy editing disabled\n", program);
|
"fancy editing disabled\n", program);
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -252,53 +248,162 @@ main(int argc, char **argv)
|
|||||||
/*
|
/*
|
||||||
* reset/initialize the computing environment
|
* reset/initialize the computing environment
|
||||||
*/
|
*/
|
||||||
if (post_init) {
|
if (post_init)
|
||||||
initialize();
|
initialize();
|
||||||
} else {
|
post_init = TRUE;
|
||||||
/* initialize already done, jmpbuf is ready */
|
|
||||||
post_init = TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* if arg mode or non-tty mode, just do the work and be gone
|
|
||||||
*/
|
|
||||||
if (!interactive || !stdin_tty) {
|
|
||||||
if (q_flag == FALSE && allow_read) {
|
|
||||||
runrcfiles();
|
|
||||||
q_flag = TRUE;
|
|
||||||
}
|
|
||||||
if (interactive)
|
|
||||||
(void) openterminal();
|
|
||||||
else
|
|
||||||
(void) openstring(cmdbuf);
|
|
||||||
start_done = TRUE;
|
|
||||||
getcommands(FALSE);
|
|
||||||
libcalc_call_me_last();
|
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
/* if in arg mode, we should not get here */
|
|
||||||
if (!interactive) {
|
|
||||||
libcalc_call_me_last();
|
|
||||||
exit(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* process commands
|
* (re)establish the interrupt handler
|
||||||
*/
|
*/
|
||||||
if (!start_done) {
|
|
||||||
reinitialize();
|
|
||||||
}
|
|
||||||
(void) signal(SIGINT, intint);
|
(void) signal(SIGINT, intint);
|
||||||
start_done = TRUE;
|
|
||||||
getcommands(TRUE);
|
/*
|
||||||
|
* execute calc code based on the run state
|
||||||
|
*/
|
||||||
|
if (run_state == RUN_BEGIN) {
|
||||||
|
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;
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (run_state == RUN_RCFILES) {
|
||||||
|
fprintf(stderr, "Error in rcfiles\n");
|
||||||
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
|
getcommands(FALSE);
|
||||||
|
if (inputlevel() == 0) {
|
||||||
|
closeinput();
|
||||||
|
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;
|
||||||
|
} else {
|
||||||
|
closeinput();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
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;
|
||||||
|
} 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (run_state == RUN_PRE_CMD_ARGS) {
|
||||||
|
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;
|
||||||
|
(void) openstring(cmdbuf, (long) strlen(cmdbuf));
|
||||||
|
getcommands(FALSE);
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (run_state == RUN_CMD_ARGS) {
|
||||||
|
fprintf(stderr, "Error in commands\n");
|
||||||
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
|
getcommands(FALSE);
|
||||||
|
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;
|
||||||
|
closeinput();
|
||||||
|
} else {
|
||||||
|
closeinput();
|
||||||
|
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;
|
||||||
|
} 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (run_state == RUN_PRE_TOP_LEVEL) {
|
||||||
|
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;
|
||||||
|
} else {
|
||||||
|
if (stdin_tty) {
|
||||||
|
reinitialize();
|
||||||
|
} else {
|
||||||
|
resetinput();
|
||||||
|
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;
|
||||||
|
getcommands(TRUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while (run_state == RUN_TOP_LEVEL) {
|
||||||
|
if ((c_flag && !stoponerror) || stoponerror < 0) {
|
||||||
|
getcommands(TRUE);
|
||||||
|
if (!inputisterminal())
|
||||||
|
closeinput();
|
||||||
|
} else {
|
||||||
|
if (stdin_tty) {
|
||||||
|
reinitialize();
|
||||||
|
getcommands(TRUE);
|
||||||
|
} 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* all done
|
* all done
|
||||||
*/
|
*/
|
||||||
libcalc_call_me_last();
|
libcalc_call_me_last();
|
||||||
/* exit(0); */
|
return (run_state == RUN_EXIT_WITH_ERROR ||
|
||||||
return 0;
|
run_state == RUN_UNKNOWN) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
56
calc.h
56
calc.h
@@ -10,6 +10,7 @@
|
|||||||
#if !defined(__CALC_H__)
|
#if !defined(__CALC_H__)
|
||||||
#define __CALC_H__
|
#define __CALC_H__
|
||||||
|
|
||||||
|
#include <setjmp.h>
|
||||||
|
|
||||||
#include "value.h"
|
#include "value.h"
|
||||||
|
|
||||||
@@ -37,7 +38,6 @@
|
|||||||
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
#define SYMBOLSIZE 256 /* maximum symbol name size */
|
||||||
#define MAXINDICES 20 /* maximum number of indices for objects */
|
#define MAXINDICES 20 /* maximum number of indices for objects */
|
||||||
#define MAXLABELS 100 /* maximum number of user labels in function */
|
#define MAXLABELS 100 /* maximum number of user labels in function */
|
||||||
#define MAXOBJECTS 10 /* 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 */
|
||||||
@@ -58,6 +58,8 @@
|
|||||||
#define ABORT_MATH 3 /* abort on any math operation */
|
#define ABORT_MATH 3 /* abort on any math operation */
|
||||||
#define ABORT_NOW 4 /* abort right away */
|
#define ABORT_NOW 4 /* abort right away */
|
||||||
|
|
||||||
|
#define ERRMAX 20 /* default errmax value */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* File ids corresponding to standard in, out, error, and when not in use.
|
* File ids corresponding to standard in, out, error, and when not in use.
|
||||||
*/
|
*/
|
||||||
@@ -110,7 +112,7 @@ extern void trimconstants(void);
|
|||||||
/*
|
/*
|
||||||
* Input routines.
|
* Input routines.
|
||||||
*/
|
*/
|
||||||
extern int openstring(char *str);
|
extern int openstring(char *str, long num);
|
||||||
extern int openterminal(void);
|
extern int openterminal(void);
|
||||||
extern int opensearchfile(char *name, char *pathlist, char *exten, int reopen_ok);
|
extern int opensearchfile(char *name, char *pathlist, char *exten, int reopen_ok);
|
||||||
extern char *nextline(void);
|
extern char *nextline(void);
|
||||||
@@ -119,12 +121,13 @@ extern void reread(void);
|
|||||||
extern void resetinput(void);
|
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 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);
|
||||||
extern void closeinput(void);
|
extern void closeinput(void);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Other routines.
|
* Other routines.
|
||||||
*/
|
*/
|
||||||
@@ -138,21 +141,40 @@ 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);
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialization
|
* Initialization
|
||||||
*/
|
*/
|
||||||
extern void initialize(void);
|
extern void initialize(void);
|
||||||
extern void reinitialize(void);
|
extern void reinitialize(void);
|
||||||
|
extern int isatty(int tty); /* TRUE if fd is a tty */
|
||||||
|
extern char *version(void); /* return version string */
|
||||||
|
extern int post_init; /* TRUE => setjmp for math_error is ready */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Global data definitions.
|
* global flags and definitions
|
||||||
*/
|
*/
|
||||||
|
extern int abortlevel; /* current level of aborts */
|
||||||
|
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
|
extern jmp_buf jmpbuf; /* for errors */
|
||||||
|
|
||||||
|
extern int p_flag; /* TRUE => pipe mode */
|
||||||
|
extern int q_flag; /* TRUE => don't execute rc files */
|
||||||
|
extern int u_flag; /* TRUE => unbuffer stdin and stdout */
|
||||||
|
extern int d_flag; /* TRUE => disable heading, lib_debug == 0 */
|
||||||
|
extern int c_flag; /* TRUE => continue after error if permitted */
|
||||||
|
extern int i_flag; /* TRUE => try to go interactive after error */
|
||||||
|
extern int stoponerror; /* >0 => stop, <0 => continue, ==0 => use -c */
|
||||||
|
extern BOOL abort_now; /* TRUE => try to go interactive */
|
||||||
|
|
||||||
|
extern char *pager; /* $PAGER or default */
|
||||||
|
extern int stdin_tty; /* TRUE if stdin is a tty */
|
||||||
|
extern int havecommands; /* TRUE if have cmd args) */
|
||||||
|
extern char *program; /* our name */
|
||||||
|
extern char cmdbuf[]; /* command line expression */
|
||||||
|
|
||||||
extern int abortlevel; /* current level of aborts */
|
extern int abortlevel; /* current level of aborts */
|
||||||
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
extern BOOL inputwait; /* TRUE if in a terminal input wait */
|
||||||
extern VALUE *stack; /* execution stack */
|
extern VALUE *stack; /* execution stack */
|
||||||
extern int start_done; /* TRUE => start up processing finished */
|
|
||||||
extern int dumpnames; /* TRUE => dump names rather than indices */
|
extern int dumpnames; /* TRUE => dump names rather than indices */
|
||||||
|
|
||||||
extern char *calcpath; /* $CALCPATH or default */
|
extern char *calcpath; /* $CALCPATH or default */
|
||||||
@@ -163,15 +185,29 @@ extern char *shell; /* $SHELL or default */
|
|||||||
extern char *program; /* our name (argv[0]) */
|
extern char *program; /* our name (argv[0]) */
|
||||||
|
|
||||||
extern int no_env; /* TRUE (-e) => ignore env vars on startup */
|
extern int no_env; /* TRUE (-e) => ignore env vars on startup */
|
||||||
extern int ign_errmax; /* TRUE (-i) => ignore when errcount exceeds errmax */
|
extern int errmax; /* if >= 0, error when errcount exceeds errmax */
|
||||||
extern int new_std; /* TRUE (-n) => use newstd configuration */
|
extern int new_std; /* TRUE (-n) => use newstd configuration */
|
||||||
|
|
||||||
extern int allow_read; /* FALSE => may not open any files for reading */
|
extern int allow_read; /* FALSE => may not open any files for reading */
|
||||||
extern int allow_write; /* FALSE => may not open any files for writing */
|
extern int allow_write; /* FALSE => may not open any files for writing */
|
||||||
extern int allow_exec; /* FALSE => may not execute any commands */
|
extern int allow_exec; /* FALSE => may not execute any commands */
|
||||||
|
|
||||||
extern int post_init; /* TRUE => setjmp for math_error is ready */
|
/*
|
||||||
|
* calc startup and run state
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
RUN_UNKNOWN = -1, /* unknown or unset start state */
|
||||||
|
RUN_BEGIN = 0, /* calc execution starts */
|
||||||
|
RUN_RCFILES = 1, /* rc files being evaluated */
|
||||||
|
RUN_PRE_CMD_ARGS = 2, /* prepare to evaluate cmd args */
|
||||||
|
RUN_CMD_ARGS = 3, /* cmd args being evaluated */
|
||||||
|
RUN_PRE_TOP_LEVEL = 4, /* prepare to start top level activity */
|
||||||
|
RUN_TOP_LEVEL = 5, /* running at top level */
|
||||||
|
RUN_EXIT = 6, /* normal exit from calc */
|
||||||
|
RUN_EXIT_WITH_ERROR = 7 /* exit with error */
|
||||||
|
} run;
|
||||||
|
extern run run_state;
|
||||||
|
extern char *run_state_name(run state);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* calc version information
|
* calc version information
|
||||||
|
578
calc.man
578
calc.man
@@ -1,190 +1,396 @@
|
|||||||
.\"
|
.\"
|
||||||
.\" Copyright (c) 1994 David I. Bell and Landon Curt Noll
|
.\" Copyright (c) 1993 David I. Bell and Landon Curt Noll
|
||||||
|
.\" Original man page dated 15nov93
|
||||||
|
.\" Copyright (c) 1999 David I. Bell and Landon Curt Noll
|
||||||
.\" Permission is granted to use, distribute, or modify this source,
|
.\" Permission is granted to use, distribute, or modify this source,
|
||||||
.\" provided that this copyright notice remains intact.
|
.\" provided that this copyright notice remains intact.
|
||||||
.\"
|
.\"
|
||||||
.\" calculator by David I. Bell
|
.\" calculator by David I. Bell
|
||||||
.\" man page by Landon Noll
|
.\" man page by Landon Noll
|
||||||
.TH calc 1 "^..^" "15nov93"
|
.TH calc 1 "^..^" "15Oct1999"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
calc \- arbitrary precision calculator
|
calc \- arbitrary precision calculator
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
\fIcalc\fP
|
\fIcalc\fP
|
||||||
[\fI\-h\fP]
|
.RB [ \-c ]
|
||||||
[\fI\-m mode\fP]
|
.RB [ \-C ]
|
||||||
[\fI\-p\fP]
|
.RB [ \-d ]
|
||||||
[\fI\-q\fP]
|
.RB [ -D\ \&calc_debug[:lib_debug:[user_debug]] ]
|
||||||
[\fI\-u\fP]
|
.br
|
||||||
[\fI\-v\fP]
|
.in +5n
|
||||||
[\fIcalc_cmd \&.\|.\|.\fp]
|
.RB [ \-e ]
|
||||||
|
.RB [ \-h ]
|
||||||
|
.RB [ \-i ]
|
||||||
|
.RB [ \-m\ \&mode ]
|
||||||
|
.RB [ \-n ]
|
||||||
|
.RB [ \-p ]
|
||||||
|
.RB [ \-q ]
|
||||||
|
.RB [ \-u ]
|
||||||
|
.RB [ \-v ]
|
||||||
|
.br
|
||||||
|
.RB [ calc_cmd\ \&.\|.\|. ]
|
||||||
|
.in -5n
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
\&
|
\&
|
||||||
.br
|
.br
|
||||||
CALC COMMAND LINE
|
CALC COMMAND LINE
|
||||||
.PP
|
.PP
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI\-h\fP
|
.B \-c
|
||||||
Print a help message.
|
Continue reading command lines even after an execution
|
||||||
This option implies \fI \-q\fP.
|
error has caused the abandonment of a line.
|
||||||
This is equivalent to the calc command \fIhelp help\fP.
|
.sp 1
|
||||||
The help facility is disabled unless the \fImode\fP is 5 or 7.
|
For example:
|
||||||
See \fI\-m\fP below.
|
.sp 1
|
||||||
.sp
|
.in +5n
|
||||||
.TP
|
|
||||||
\fI\-m mode\fP
|
|
||||||
This flag sets the permission mode of calc.
|
|
||||||
It controls the ability for \fIcalc\fP to open files
|
|
||||||
and execute programs.
|
|
||||||
\fIMode\fP may be a number from 0 to 7.
|
|
||||||
.sp
|
|
||||||
The \fImode\fP value is interpreted in a way similar
|
|
||||||
to that of the \fRchmod(1)\fP octal mode:
|
|
||||||
.sp
|
|
||||||
.in +0.5i
|
|
||||||
.nf
|
.nf
|
||||||
0 do not open any file, do not execute progs
|
calc read many_errors.cal
|
||||||
1 do not open any file
|
|
||||||
2 do not open files for reading, do not execute progs
|
|
||||||
3 do not open files for reading
|
|
||||||
4 do not open files for writing, do not execute progs
|
|
||||||
5 do not open files for writing
|
|
||||||
6 do not execute any program
|
|
||||||
7 allow everything (default mode)
|
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
If one wished to run calc from a privledged user, one might
|
will cause
|
||||||
want to use \fI\-m 0\fP in an effort to make calc more secure.
|
.B calc
|
||||||
.sp
|
to abort on the first error, whereas:
|
||||||
\fIMode\fP bits for reading and writing apply only on an open.
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -c read many_errors.cal
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will
|
||||||
|
cause
|
||||||
|
.B calc
|
||||||
|
to try to process each line being read
|
||||||
|
despite the errors that it encounters.
|
||||||
|
.sp 1
|
||||||
|
By default, calc startup scripts ($CALCRC) are silently
|
||||||
|
ignored if not found.
|
||||||
|
This flag will report missing
|
||||||
|
startup scripts unless
|
||||||
|
.B \-d
|
||||||
|
is also given.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-C
|
||||||
|
Permit the execution of custom builtin functions. Without
|
||||||
|
this flag, calling the custom() builtin function will
|
||||||
|
simply generate an error.
|
||||||
|
.sp 1
|
||||||
|
Use if this flag may cause
|
||||||
|
.B calc
|
||||||
|
to execute functions that
|
||||||
|
are non-standard and that are not portable. Custom builtin
|
||||||
|
functions are disabled by default for this reason.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-d
|
||||||
|
Disable the printing of the opening title. The printing
|
||||||
|
of library debug and informational messages is also disabled
|
||||||
|
as if \fBconfig("lib_debug", 0)\fP had been executed.
|
||||||
|
.sp 1
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
calc 'read qtime; qtime(2)'
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will output something like:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
qtime(utc_hr_offset) defined
|
||||||
|
It's nearly ten past six.
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
whereas:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -d 'read qtime; qtime(2)'
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will just say:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
It's nearly ten past six.
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
This flag disables the reporting of missing calc
|
||||||
|
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
|
||||||
|
.B \-e
|
||||||
|
Ignore any environment variables on startup.
|
||||||
|
The getenv() builtin will still return values, however.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-h
|
||||||
|
Print a help message. This option implies
|
||||||
|
.BR \-q .
|
||||||
|
This
|
||||||
|
is equivalent to the
|
||||||
|
.B calc
|
||||||
|
command help help.
|
||||||
|
The help facility is disabled unless the mode is 5 or 7.
|
||||||
|
See
|
||||||
|
.BR \-m .
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-i
|
||||||
|
Become interactive if possible.
|
||||||
|
Be default, if
|
||||||
|
.I calc_cmd
|
||||||
|
args are given,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
This flag args are given,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
This flag will cause
|
||||||
|
.B calc
|
||||||
|
to drop into interactive mode after the
|
||||||
|
commands are executed.
|
||||||
|
.sp 1
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc 2+5
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will print the value 7 and exit whereas:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
calc -i 2+5
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
will print the value 7 and prompt the user for more
|
||||||
|
.B calc
|
||||||
|
commands.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.BR \-m " mode"
|
||||||
|
This flag sets the permission mode of
|
||||||
|
.BR calc .
|
||||||
|
It controls the ability for
|
||||||
|
.B calc
|
||||||
|
to open files and execute programs.
|
||||||
|
.I Mode
|
||||||
|
may be a number from 0 to 7.
|
||||||
|
.sp 1
|
||||||
|
The mode value is interpreted in a way similar to that
|
||||||
|
of the
|
||||||
|
.BR chmod (1)
|
||||||
|
octal mode:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
.nf
|
||||||
|
0 do not open any file, do not execute progs
|
||||||
|
1 do not open any file
|
||||||
|
2 do not open files for reading, do not execute progs
|
||||||
|
3 do not open files for reading
|
||||||
|
4 do not open files for writing, do not execute progs
|
||||||
|
5 do not open files for writing
|
||||||
|
6 do not execute any program
|
||||||
|
7 allow everything (default mode)
|
||||||
|
.fi
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
If one wished to run
|
||||||
|
.B calc
|
||||||
|
from a privileged user, one might want to use
|
||||||
|
.BR \-m " 0"
|
||||||
|
in an effort to make
|
||||||
|
.B calc
|
||||||
|
somewhat more secure.
|
||||||
|
.sp 1
|
||||||
|
Mode bits for reading and writing apply only on an
|
||||||
|
open.
|
||||||
Files already open are not effected.
|
Files already open are not effected.
|
||||||
Thus if one wanted to use the \fI\-m 0\fP in an effort to make
|
Thus if one wanted to use the
|
||||||
\fIcalc\fP more secure, but still wanted to read and write a specific
|
.BR \-m " 0"
|
||||||
file, one might want to do:
|
in an effort to make
|
||||||
.sp
|
.B calc
|
||||||
.in +0.5i
|
somewhat more secure, but still wanted to read and write a specific
|
||||||
|
file, one might want to do in
|
||||||
|
.BR sh (1),
|
||||||
|
.BR ksh (1),
|
||||||
|
.BR bash (1)-like
|
||||||
|
shells:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRcalc \-m 0 3<a.file\fP
|
calc -m 0 3<a.file
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
Files presented to \fIcalc\fP in this way are opened in an unknown mode.
|
Files presented to
|
||||||
\fICalc\fP will attempt to read or write them if directed.
|
.B calc
|
||||||
.sp
|
in this way are opened in an
|
||||||
If the \fImode\fP disables opening of files for reading, then
|
unknown mode.
|
||||||
the startup library scripts are disabled as of \fI\-q\fP was given.
|
.B Calc
|
||||||
The reading of key bindings is also disabled when the \fImode\fP
|
will attempt to read or write them if directed.
|
||||||
disables opening of files for reading.
|
.sp 1
|
||||||
|
If the mode disables opening of files for reading, then
|
||||||
|
the startup library scripts are disabled as of
|
||||||
|
.B \-q
|
||||||
|
was given.
|
||||||
|
The reading of key bindings is also disabled
|
||||||
|
when the mode disables opening of files for reading.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-p\fP
|
.B \-n
|
||||||
Pipe processing is enabled by use of \-p. For example:
|
Use the new configuration defaults instead of the old
|
||||||
.sp
|
default classic defaults.
|
||||||
.in +0.5i
|
This flag as the same effect
|
||||||
|
as executing \fBconfig("all", "newcfg")\fP at startup time.
|
||||||
|
|
||||||
|
.TP
|
||||||
|
.B \-p
|
||||||
|
Pipe processing is enabled by use of
|
||||||
|
.BR \-p .
|
||||||
|
For example:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRecho "print 2^21701\-1, 2^23209\-1" | calc \-p | fizzbin\fP
|
calc -p '2^21701-1' | fizzbin
|
||||||
.fi
|
.fi
|
||||||
.in -0.5i
|
.in -5n
|
||||||
.sp
|
.sp 1
|
||||||
In pipe mode, \fIcalc\fP does not prompt, does not print leading tabs
|
In pipe mode,
|
||||||
and does not print the initial header.
|
.B calc
|
||||||
|
does not prompt, does not print leading
|
||||||
|
tabs and does not print the initial header.
|
||||||
|
The
|
||||||
|
.B \-p
|
||||||
|
flag overrides
|
||||||
|
.BR \-i .
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-q\fP
|
.B \-q
|
||||||
Disable the use of the \fI$CALCRC\fP startup scripts.
|
Disable the use of the $CALCRC startup scripts.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-u\fP
|
.B \-u
|
||||||
Disable buffering of stdin and stdout.
|
Disable buffering of stdin and stdout.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fI \-v\fP
|
.B \-v
|
||||||
Print the version and exit.
|
Print the
|
||||||
|
.B calc
|
||||||
|
version number and exit.
|
||||||
.PP
|
.PP
|
||||||
Without \fIcalc_cmd\fPs, \fIcalc\fP operates interactively.
|
Without
|
||||||
If one or more \fIcalc_cmd\fPs are given on the command line,
|
.IR calc_cmd ,
|
||||||
\fIcalc\fP will execute them and exit.
|
.B calc
|
||||||
The printing of leading tabs on output is disabled
|
operates interactively.
|
||||||
as if \fIconfig("tab",0)\fP had been executed.
|
If one or more
|
||||||
|
.I calc_cmd
|
||||||
|
are given on the command line,
|
||||||
|
.B calc
|
||||||
|
will execute them and exit.
|
||||||
|
If
|
||||||
|
.B \-i
|
||||||
|
is given,
|
||||||
|
.B calc
|
||||||
|
will attempt to become interactive
|
||||||
|
even of one or more
|
||||||
|
.I calc_cmd
|
||||||
|
are given on the command line.
|
||||||
.PP
|
.PP
|
||||||
Normally on startup, \fIcalc\fP attempts to execute a collection
|
Normally on startup,
|
||||||
of library scripts.
|
.B calc
|
||||||
The environment variable \fI$CALCRC\fP (if non-existent then
|
attempts to execute a collection of
|
||||||
a compiled in value) contains a \fI:\fP separated list of
|
library scripts.
|
||||||
startup library scripts.
|
The environment variable $CALCRC (if non-existent
|
||||||
No error conditions are produced if these startup library scripts
|
then a compiled in value) contains a : separated list of startup
|
||||||
are not found.
|
library scripts.
|
||||||
|
No error conditions are produced if these startup
|
||||||
|
library scripts are not found.
|
||||||
.PP
|
.PP
|
||||||
If the \fImode\fP disables opening of files for reading, then
|
If the mode disables opening of files for reading, then the startup
|
||||||
the startup library scripts are disabled as of \fI\-q\fP was given
|
library scripts are disabled as of
|
||||||
and \fI$CALCRC\fP as well as the default compiled in value are ignored.
|
.B \-q
|
||||||
|
was given and $CALCRC as well
|
||||||
|
as the default compiled in value are ignored.
|
||||||
.PP
|
.PP
|
||||||
Filenames are subject to ``~'' expansion (see below).
|
Filenames are subject to ``~'' expansion (see below).
|
||||||
The environment variable \fI$CALCPATH\fP (if non-existent then
|
The
|
||||||
a compiled in value) contains a \fI:\fP separated list of search
|
environment variable $CALCPATH (if non-existent then a compiled in
|
||||||
directories.
|
value) contains a : separated list of search directories.
|
||||||
If a file does not begin with \fI/\fP, \fI~\fP or \fI./\fP,
|
If a
|
||||||
then it is searched for under each directory listed in the \fI$CALCPATH\fP.
|
file does not begin with /, ~ or ./, then it is searched for under
|
||||||
It is an error if no such readable file is found.
|
each directory listed in the $CALCPATH.
|
||||||
|
It is an error if no such
|
||||||
|
readable file is found.
|
||||||
.PP
|
.PP
|
||||||
Calc treats all open files, other than stdin, stdout and stderr
|
.B Calc
|
||||||
as files available for reading and writing.
|
treats all open files, other than stdin, stdout and
|
||||||
One may present calc with an already open file in the following way:
|
stderr as files available for reading and writing.
|
||||||
.sp
|
One may
|
||||||
.in +0.5i
|
present
|
||||||
|
.B calc
|
||||||
|
with an already open file using
|
||||||
|
.BR sh (1),
|
||||||
|
.BR ksh (1),
|
||||||
|
.BR bash (1)-like
|
||||||
|
shells is to:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
|
calc 3<open_file 4<open_file2
|
||||||
|
.in -5n
|
||||||
|
.sp 1
|
||||||
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
|
.sp 1
|
||||||
|
.in +5n
|
||||||
.nf
|
.nf
|
||||||
\fRcalc 3<open_file 4<open_file2\fP
|
|
||||||
.fi
|
|
||||||
.in -0.5i
|
|
||||||
.PP
|
|
||||||
For more information use the following calc commands:
|
|
||||||
.PP
|
|
||||||
.in 1.0i
|
|
||||||
help usage
|
|
||||||
.br
|
|
||||||
help help
|
help help
|
||||||
.br
|
help overview
|
||||||
|
help usage
|
||||||
help environment
|
help environment
|
||||||
.in -1.0i
|
help config
|
||||||
.PP
|
.fi
|
||||||
OVERVIEW
|
.in -5n
|
||||||
.PP
|
.sp 1
|
||||||
\fICalc\fP is arbitrary precision arithmetic system that uses
|
|
||||||
a C-like language.
|
|
||||||
\fICalc\fP is useful as a calculator, an algorithm prototyped
|
|
||||||
and as a mathematical research tool.
|
|
||||||
More importantly, \fIcalc\fP provides one with a machine
|
|
||||||
independent means of computation.
|
|
||||||
.PP
|
|
||||||
\fICalc\fP comes with a rich set of builtin mathematical
|
|
||||||
and programmatic functions.
|
|
||||||
.PP
|
|
||||||
\fICalc\fP is distributed with library of scripts.
|
|
||||||
Written in the same C-like language, library scripts may be
|
|
||||||
read in and executed during a \fIcalc\fP session.
|
|
||||||
These library scripts are also provided because they are
|
|
||||||
useful and to serve as examples of the \fIcalc\fP language.
|
|
||||||
One may further extend \fIcalc\fP thru the
|
|
||||||
use of user defined scripts.
|
|
||||||
.PP
|
|
||||||
Internally calc represents numeric values as fractions reduced to their
|
|
||||||
lowest terms.
|
|
||||||
The numerators and denominators of these factions may grow to
|
|
||||||
arbitrarily large values.
|
|
||||||
Numeric values read in are automatically converted into rationals.
|
|
||||||
The user need not be aware of this internal representation.
|
|
||||||
.PP
|
|
||||||
For more information use the following calc commands:
|
|
||||||
.PP
|
|
||||||
.in 1.0i
|
|
||||||
help intro
|
|
||||||
.br
|
|
||||||
help builtin
|
|
||||||
.br
|
|
||||||
help stdlib
|
|
||||||
.br
|
|
||||||
help define
|
|
||||||
.br
|
|
||||||
show builtins
|
|
||||||
.br
|
|
||||||
show functions
|
|
||||||
.in -1.0i
|
|
||||||
.PP
|
.PP
|
||||||
DATA TYPES
|
DATA TYPES
|
||||||
.PP
|
.PP
|
||||||
@@ -199,7 +405,9 @@ multiplication, division, negation, squaring, modulus,
|
|||||||
rounding, exponentiation, equality, comparison, printing
|
rounding, exponentiation, equality, comparison, printing
|
||||||
and so on.
|
and so on.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc commands:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help types
|
help types
|
||||||
@@ -220,7 +428,9 @@ procedure.
|
|||||||
Values may be grouped together in a matrix, or into a
|
Values may be grouped together in a matrix, or into a
|
||||||
a list that permits stack and queue style operations.
|
a list that permits stack and queue style operations.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc commands:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
commands:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help variable
|
help variable
|
||||||
@@ -256,7 +466,9 @@ For example:
|
|||||||
~chongo/lib/fft_multiply.cal
|
~chongo/lib/fft_multiply.cal
|
||||||
.in -1.0i
|
.in -1.0i
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc command:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
command:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help file
|
help file
|
||||||
@@ -275,7 +487,9 @@ These include commands such as function definition, help,
|
|||||||
reading in library scripts, dump files to a file, error notification,
|
reading in library scripts, dump files to a file, error notification,
|
||||||
configuration control and status.
|
configuration control and status.
|
||||||
.PP
|
.PP
|
||||||
For more information use the following calc command:
|
For more information use the following
|
||||||
|
.B calc
|
||||||
|
command:
|
||||||
.PP
|
.PP
|
||||||
.in 1.0i
|
.in 1.0i
|
||||||
help command
|
help command
|
||||||
@@ -295,7 +509,8 @@ help config
|
|||||||
.PD 0
|
.PD 0
|
||||||
.TP 20
|
.TP 20
|
||||||
${LIBDIR}/*.cal
|
${LIBDIR}/*.cal
|
||||||
library scripts shipped with calc
|
library scripts shipped with
|
||||||
|
.B calc
|
||||||
.br
|
.br
|
||||||
.sp
|
.sp
|
||||||
.TP 20
|
.TP 20
|
||||||
@@ -323,7 +538,9 @@ Default value: ${CALCPATH}
|
|||||||
.TP 5
|
.TP 5
|
||||||
CALCRC
|
CALCRC
|
||||||
On startup (unless \-h or \-q was given on the command
|
On startup (unless \-h or \-q was given on the command
|
||||||
line), calc searches for files along this :-separated
|
line),
|
||||||
|
.B calc
|
||||||
|
searches for files along this :-separated
|
||||||
environment variable.
|
environment variable.
|
||||||
.br
|
.br
|
||||||
.sp
|
.sp
|
||||||
@@ -333,19 +550,27 @@ Default value: ${CALCRC}
|
|||||||
.TP 5
|
.TP 5
|
||||||
CALCBINDINGS
|
CALCBINDINGS
|
||||||
On startup (unless \fI\-h\fP or \fI\-q\fP was given on the command
|
On startup (unless \fI\-h\fP or \fI\-q\fP was given on the command
|
||||||
line, or \fI\-m\fP disallows opening files for reading), calc reads
|
line, or \fI\-m\fP disallows opening files for reading),
|
||||||
|
.B calc
|
||||||
|
reads
|
||||||
key bindings from the filename specified
|
key bindings from the filename specified
|
||||||
by this environment variable.
|
by this environment variable.
|
||||||
.br
|
.br
|
||||||
.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
|
||||||
The majority of calc was written by David I. Bell.
|
The majority of
|
||||||
|
.B calc
|
||||||
|
was written by David I. Bell.
|
||||||
.sp
|
.sp
|
||||||
Calc archives and calc-tester mailing list maintained by Landon Curt Noll.
|
.B Calc
|
||||||
|
archives and calc-tester mailing list maintained by Landon Curt Noll.
|
||||||
.sp
|
.sp
|
||||||
Thanks for suggestions and encouragement from Peter Miller,
|
Thanks for suggestions and encouragement from Peter Miller,
|
||||||
Neil Justusson, and Landon Noll.
|
Neil Justusson, and Landon Noll.
|
||||||
@@ -378,30 +603,27 @@ Copyright (c) 19xx Ernest Bowen and Landon Curt Noll
|
|||||||
Permission is granted to use, distribute, or modify this source,
|
Permission is granted to use, distribute, or modify this source,
|
||||||
provided that this copyright notice remains intact.
|
provided that this copyright notice remains intact.
|
||||||
.sp
|
.sp
|
||||||
Send calc comments, suggestions, bug fixes, enhancements
|
Send comments, suggestions, bug fixes, enhancements
|
||||||
and interesting calc scripts that you would like you see included
|
and interesting
|
||||||
|
.B calc
|
||||||
|
scripts that you would like you see included
|
||||||
in future distributions to:
|
in future distributions to:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
dbell@auug.org.au
|
calc-tester@postofc.corp.sgi.com
|
||||||
.br
|
|
||||||
chongo@toad.com
|
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
Landon Noll maintains the official calc ftp archive at:
|
Landon Noll maintains the the
|
||||||
|
.B calc
|
||||||
|
web site is located at:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
ftp://ftp.uu.net/pub/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
.in -0.5i
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
Alpha test versions, complete with bugs, untested code and
|
One may join the
|
||||||
experimental features may be fetched (if you are brave) under:
|
.B calc
|
||||||
.sp
|
testing group by sending a request to:
|
||||||
.in +0.5i
|
|
||||||
http://reality.sgi.com/chongo/calc/
|
|
||||||
.in -0.5i
|
|
||||||
.sp
|
|
||||||
One may join the calc testing group by sending a request to:
|
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
@@ -410,14 +632,14 @@ calc-tester-request@postofc.corp.sgi.com
|
|||||||
Your message body (not the subject) should consist of:
|
Your message body (not the subject) should consist of:
|
||||||
.sp
|
.sp
|
||||||
.in +0.5i
|
.in +0.5i
|
||||||
|
.nf
|
||||||
subscribe calc-tester address
|
subscribe calc-tester address
|
||||||
.br
|
|
||||||
end
|
end
|
||||||
.br
|
|
||||||
name your_full_name
|
name your_full_name
|
||||||
|
.fi
|
||||||
|
.in -0.5i
|
||||||
.sp
|
.sp
|
||||||
where "address" is your EMail address and "your_full_name"
|
where "address" is your EMail address and "your_full_name"
|
||||||
is your full name.
|
is your full name.
|
||||||
.in -0.5i
|
|
||||||
.sp
|
.sp
|
||||||
Enjoy!
|
Share and Enjoy! :\-)
|
||||||
|
@@ -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);
|
||||||
|
202
codegen.c
202
codegen.c
@@ -31,9 +31,9 @@ static void getshowstatement(void);
|
|||||||
static void getfunction(void);
|
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, BOOL toplevel);
|
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);
|
||||||
@@ -86,6 +86,7 @@ getcommands(BOOL toplevel)
|
|||||||
/* firewall */
|
/* firewall */
|
||||||
name[0] = '\0';
|
name[0] = '\0';
|
||||||
name[MAXCMD+1] = '\0';
|
name[MAXCMD+1] = '\0';
|
||||||
|
abort_now = FALSE;
|
||||||
|
|
||||||
/* getcommands */
|
/* getcommands */
|
||||||
if (!toplevel)
|
if (!toplevel)
|
||||||
@@ -125,6 +126,7 @@ getcommands(BOOL toplevel)
|
|||||||
switch (opensearchfile(name,calcpath,CALCEXT,rdonce)) {
|
switch (opensearchfile(name,calcpath,CALCEXT,rdonce)) {
|
||||||
case 0:
|
case 0:
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
|
closeinput();
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
/* previously read and -once was given */
|
/* previously read and -once was given */
|
||||||
@@ -163,6 +165,13 @@ getcommands(BOOL toplevel)
|
|||||||
if (evaluate(FALSE))
|
if (evaluate(FALSE))
|
||||||
updateoldvalue(curfunc);
|
updateoldvalue(curfunc);
|
||||||
freefunc(curfunc);
|
freefunc(curfunc);
|
||||||
|
if (abort_now) {
|
||||||
|
if (!stdin_tty)
|
||||||
|
run_state = RUN_EXIT;
|
||||||
|
else if (run_state < RUN_PRE_TOP_LEVEL)
|
||||||
|
run_state = RUN_PRE_TOP_LEVEL;
|
||||||
|
longjmp(jmpbuf, 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -189,22 +198,26 @@ evaluate(BOOL nestflag)
|
|||||||
|
|
||||||
funcname = (nestflag ? "**" : "*");
|
funcname = (nestflag ? "**" : "*");
|
||||||
beginfunc(funcname, nestflag);
|
beginfunc(funcname, nestflag);
|
||||||
if (nestflag)
|
if (gettoken() == T_LEFTBRACE) {
|
||||||
(void) tokenmode(TM_DEFAULT);
|
getbody(NULL_LABEL, NULL_LABEL, NULL_LABEL, NULL_LABEL);
|
||||||
while (loop) {
|
} else {
|
||||||
switch (gettoken()) {
|
if (nestflag)
|
||||||
case T_SEMICOLON:
|
(void) tokenmode(TM_DEFAULT);
|
||||||
break;
|
rescantoken();
|
||||||
|
while (loop) {
|
||||||
|
switch (gettoken()) {
|
||||||
|
case T_SEMICOLON:
|
||||||
|
break;
|
||||||
|
case T_NEWLINE:
|
||||||
|
case T_EOF:
|
||||||
|
loop = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
case T_NEWLINE:
|
default:
|
||||||
case T_EOF:
|
rescantoken();
|
||||||
loop = 0;
|
getstatement(NULL_LABEL, NULL_LABEL,
|
||||||
break;
|
NULL_LABEL, NULL_LABEL);
|
||||||
|
}
|
||||||
default:
|
|
||||||
rescantoken();
|
|
||||||
getstatement(NULL_LABEL, NULL_LABEL,
|
|
||||||
NULL_LABEL, NULL_LABEL);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addop(OP_UNDEF);
|
addop(OP_UNDEF);
|
||||||
@@ -243,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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -261,6 +280,8 @@ getfunction(void)
|
|||||||
{
|
{
|
||||||
char *name; /* parameter name */
|
char *name; /* parameter name */
|
||||||
int type; /* type of token read */
|
int type; /* type of token read */
|
||||||
|
LABEL label;
|
||||||
|
long index;
|
||||||
|
|
||||||
(void) tokenmode(TM_DEFAULT);
|
(void) tokenmode(TM_DEFAULT);
|
||||||
if (gettoken() != T_SYMBOL) {
|
if (gettoken() != T_SYMBOL) {
|
||||||
@@ -276,9 +297,11 @@ getfunction(void)
|
|||||||
beginfunc(name, FALSE);
|
beginfunc(name, FALSE);
|
||||||
enterfuncscope();
|
enterfuncscope();
|
||||||
if (gettoken() != T_LEFTPAREN) {
|
if (gettoken() != T_LEFTPAREN) {
|
||||||
scanerror(T_SEMICOLON, "Left parenthesis expected for function");
|
scanerror(T_SEMICOLON,
|
||||||
|
"Left parenthesis expected for function");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
index = 0;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
type = gettoken();
|
type = gettoken();
|
||||||
if (type == T_RIGHTPAREN)
|
if (type == T_RIGHTPAREN)
|
||||||
@@ -292,12 +315,22 @@ getfunction(void)
|
|||||||
case SYM_UNDEFINED:
|
case SYM_UNDEFINED:
|
||||||
case SYM_GLOBAL:
|
case SYM_GLOBAL:
|
||||||
case SYM_STATIC:
|
case SYM_STATIC:
|
||||||
(void) addparam(name);
|
index = addparam(name);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
scanerror(T_NULL, "Parameter \"%s\" is already defined", name);
|
scanerror(T_NULL, "Parameter \"%s\" is already defined", name);
|
||||||
}
|
}
|
||||||
type = gettoken();
|
type = gettoken();
|
||||||
|
if (type == T_ASSIGN) {
|
||||||
|
clearlabel(&label);
|
||||||
|
addopone(OP_PARAMADDR, index);
|
||||||
|
addoplabel(OP_JUMPNN, &label);
|
||||||
|
getopassignment();
|
||||||
|
addop(OP_ASSIGNPOP);
|
||||||
|
setlabel(&label);
|
||||||
|
type = gettoken();
|
||||||
|
}
|
||||||
|
|
||||||
if (type == T_RIGHTPAREN)
|
if (type == T_RIGHTPAREN)
|
||||||
break;
|
break;
|
||||||
if (type != T_COMMA) {
|
if (type != T_COMMA) {
|
||||||
@@ -307,13 +340,11 @@ getfunction(void)
|
|||||||
}
|
}
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_ASSIGN:
|
case T_ASSIGN:
|
||||||
rescantoken();
|
|
||||||
getsimplebody();
|
getsimplebody();
|
||||||
break;
|
break;
|
||||||
case T_LEFTBRACE:
|
case T_LEFTBRACE:
|
||||||
rescantoken();
|
|
||||||
getbody(NULL_LABEL, NULL_LABEL, NULL_LABEL,
|
getbody(NULL_LABEL, NULL_LABEL, NULL_LABEL,
|
||||||
NULL_LABEL, TRUE);
|
NULL_LABEL);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
scanerror(T_NULL,
|
scanerror(T_NULL,
|
||||||
@@ -332,18 +363,9 @@ getfunction(void)
|
|||||||
static void
|
static void
|
||||||
getsimplebody(void)
|
getsimplebody(void)
|
||||||
{
|
{
|
||||||
if (gettoken() != T_ASSIGN) {
|
|
||||||
scanerror(T_SEMICOLON,
|
|
||||||
"Missing equals for simple function body");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
(void) tokenmode(TM_NEWLINES);
|
(void) tokenmode(TM_NEWLINES);
|
||||||
(void) getexprlist();
|
(void) getexprlist();
|
||||||
addop(OP_RETURN);
|
addop(OP_RETURN);
|
||||||
if (gettoken() != T_SEMICOLON)
|
|
||||||
rescantoken();
|
|
||||||
if (gettoken() != T_NEWLINE)
|
|
||||||
scanerror(T_NULL, "Illegal function definition");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -354,14 +376,10 @@ getsimplebody(void)
|
|||||||
*/
|
*/
|
||||||
/*ARGSUSED*/
|
/*ARGSUSED*/
|
||||||
static void
|
static void
|
||||||
getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaultlabel, BOOL toplevel)
|
getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaultlabel)
|
||||||
{
|
{
|
||||||
int oldmode;
|
int oldmode;
|
||||||
|
|
||||||
if (gettoken() != T_LEFTBRACE) {
|
|
||||||
scanerror(T_SEMICOLON, "Missing left brace for function body");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
oldmode = tokenmode(TM_DEFAULT);
|
oldmode = tokenmode(TM_DEFAULT);
|
||||||
while (TRUE) {
|
while (TRUE) {
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
@@ -369,6 +387,10 @@ getbody(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *defaul
|
|||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
case T_EOF:
|
||||||
|
scanerror(T_NULL, "End-of-file in function body");
|
||||||
|
return;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
rescantoken();
|
rescantoken();
|
||||||
getstatement(contlabel, breaklabel, nextcaselabel, defaultlabel);
|
getstatement(contlabel, breaklabel, nextcaselabel, defaultlabel);
|
||||||
@@ -382,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:
|
||||||
@@ -393,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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -427,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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -524,18 +554,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:
|
||||||
@@ -584,8 +616,7 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case T_LEFTBRACE:
|
case T_LEFTBRACE:
|
||||||
rescantoken();
|
getbody(contlabel, breaklabel, nextcaselabel, defaultlabel);
|
||||||
getbody(contlabel, breaklabel, nextcaselabel, defaultlabel, FALSE);
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case T_IF:
|
case T_IF:
|
||||||
@@ -598,25 +629,25 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
scanerror(T_SEMICOLON, "CONTINUE not within FOR, WHILE, or DO");
|
scanerror(T_SEMICOLON, "CONTINUE not within FOR, WHILE, or DO");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
addoplabel(OP_JUMPNE, contlabel);
|
addoplabel(OP_JUMPNZ, contlabel);
|
||||||
break;
|
break;
|
||||||
case T_BREAK:
|
case T_BREAK:
|
||||||
if (breaklabel == NULL_LABEL) {
|
if (breaklabel == NULL_LABEL) {
|
||||||
scanerror(T_SEMICOLON, "BREAK not within FOR, WHILE, or DO");
|
scanerror(T_SEMICOLON, "BREAK not within FOR, WHILE, or DO");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
addoplabel(OP_JUMPNE, breaklabel);
|
addoplabel(OP_JUMPNZ, breaklabel);
|
||||||
break;
|
break;
|
||||||
case T_GOTO:
|
case T_GOTO:
|
||||||
if (gettoken() != T_SYMBOL) {
|
if (gettoken() != T_SYMBOL) {
|
||||||
scanerror(T_SEMICOLON, "Missing label in goto");
|
scanerror(T_SEMICOLON, "Missing label in goto");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
addop(OP_JUMPNE);
|
addop(OP_JUMPNZ);
|
||||||
addlabel(tokensymbol());
|
addlabel(tokensymbol());
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
addoplabel(OP_JUMPEQ, &label1);
|
addoplabel(OP_JUMPZ, &label1);
|
||||||
rescantoken();
|
rescantoken();
|
||||||
getstatement(contlabel, breaklabel, NULL_LABEL, NULL_LABEL);
|
getstatement(contlabel, breaklabel, NULL_LABEL, NULL_LABEL);
|
||||||
if (gettoken() != T_ELSE) {
|
if (gettoken() != T_ELSE) {
|
||||||
@@ -667,7 +698,7 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
contlabel = &label1;
|
contlabel = &label1;
|
||||||
rescantoken();
|
rescantoken();
|
||||||
(void) getexprlist();
|
(void) getexprlist();
|
||||||
addoplabel(OP_JUMPNE, &label3);
|
addoplabel(OP_JUMPNZ, &label3);
|
||||||
addoplabel(OP_JUMP, breaklabel);
|
addoplabel(OP_JUMP, breaklabel);
|
||||||
if (gettoken() != T_SEMICOLON) {
|
if (gettoken() != T_SEMICOLON) {
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
@@ -708,7 +739,7 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
clearlabel(breaklabel);
|
clearlabel(breaklabel);
|
||||||
setlabel(contlabel);
|
setlabel(contlabel);
|
||||||
getcondition();
|
getcondition();
|
||||||
addoplabel(OP_JUMPEQ, breaklabel);
|
addoplabel(OP_JUMPZ, breaklabel);
|
||||||
getstatement(contlabel, breaklabel, NULL_LABEL, NULL_LABEL);
|
getstatement(contlabel, breaklabel, NULL_LABEL, NULL_LABEL);
|
||||||
addoplabel(OP_JUMP, contlabel);
|
addoplabel(OP_JUMP, contlabel);
|
||||||
setlabel(breaklabel);
|
setlabel(breaklabel);
|
||||||
@@ -731,7 +762,7 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
}
|
}
|
||||||
setlabel(contlabel);
|
setlabel(contlabel);
|
||||||
getcondition();
|
getcondition();
|
||||||
addoplabel(OP_JUMPNE, &label3);
|
addoplabel(OP_JUMPNZ, &label3);
|
||||||
setlabel(breaklabel);
|
setlabel(breaklabel);
|
||||||
(void) tokenmode(oldmode);
|
(void) tokenmode(oldmode);
|
||||||
return;
|
return;
|
||||||
@@ -815,6 +846,8 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
printeol = TRUE;
|
printeol = TRUE;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
|
case T_RIGHTPAREN:
|
||||||
|
case T_RIGHTBRACKET:
|
||||||
case T_RIGHTBRACE:
|
case T_RIGHTBRACE:
|
||||||
case T_NEWLINE:
|
case T_NEWLINE:
|
||||||
case T_EOF:
|
case T_EOF:
|
||||||
@@ -853,8 +886,19 @@ getstatement(LABEL *contlabel, LABEL *breaklabel, LABEL *nextcaselabel, LABEL *d
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case T_ABORT:
|
||||||
|
switch (gettoken()) {
|
||||||
|
case T_STRING:
|
||||||
|
addopone(OP_ABORT, tokenstring());
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
addopone(OP_ABORT, -1);
|
||||||
|
rescantoken();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case T_SYMBOL:
|
case T_SYMBOL:
|
||||||
if (nextchar() == ':') { /****HACK HACK ****/
|
if (nextchar() == ':') { /****HACK HACK****/
|
||||||
definelabel(tokensymbol());
|
definelabel(tokensymbol());
|
||||||
if (gettoken() == T_RIGHTBRACE) {
|
if (gettoken() == T_RIGHTBRACE) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
@@ -966,7 +1010,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:
|
||||||
@@ -988,8 +1036,7 @@ getoneobj(long index, int symtype)
|
|||||||
if (symtype == SYM_UNDEFINED) {
|
if (symtype == SYM_UNDEFINED) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
(void) getidexpr(TRUE, TRUE);
|
(void) getidexpr(TRUE, TRUE);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
symname = tokensymbol();
|
symname = tokensymbol();
|
||||||
definesymbol(symname, symtype);
|
definesymbol(symname, symtype);
|
||||||
usesymbol(symname, FALSE);
|
usesymbol(symname, FALSE);
|
||||||
@@ -1073,8 +1120,7 @@ getonematrix(int symtype)
|
|||||||
if (symtype == SYM_UNDEFINED) {
|
if (symtype == SYM_UNDEFINED) {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
(void) getidexpr(FALSE, TRUE);
|
(void) getidexpr(FALSE, TRUE);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
name = tokensymbol();
|
name = tokensymbol();
|
||||||
definesymbol(name, symtype);
|
definesymbol(name, symtype);
|
||||||
usesymbol(name, FALSE);
|
usesymbol(name, FALSE);
|
||||||
@@ -1159,9 +1205,9 @@ creatematrix(void)
|
|||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
case T_RIGHTBRACKET:
|
case T_RIGHTBRACKET:
|
||||||
addopone(OP_MATCREATE, dim);
|
addopone(OP_MATCREATE, dim);
|
||||||
if (gettoken() == T_LEFTBRACKET)
|
if (gettoken() == T_LEFTBRACKET) {
|
||||||
creatematrix();
|
creatematrix();
|
||||||
else {
|
} else {
|
||||||
rescantoken();
|
rescantoken();
|
||||||
addop(OP_ZERO);
|
addop(OP_ZERO);
|
||||||
}
|
}
|
||||||
@@ -1323,7 +1369,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);
|
||||||
}
|
}
|
||||||
@@ -1337,8 +1383,7 @@ getopassignment(void)
|
|||||||
while (gettoken() == T_ASSIGN)
|
while (gettoken() == T_ASSIGN)
|
||||||
getinitlist();
|
getinitlist();
|
||||||
rescantoken();
|
rescantoken();
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
rescantoken();
|
rescantoken();
|
||||||
(void) getassignment();
|
(void) getassignment();
|
||||||
}
|
}
|
||||||
@@ -1377,6 +1422,21 @@ getassignment (void)
|
|||||||
{
|
{
|
||||||
int type; /* type of expression */
|
int type; /* type of expression */
|
||||||
|
|
||||||
|
switch(gettoken()) {
|
||||||
|
case T_COMMA:
|
||||||
|
case T_SEMICOLON:
|
||||||
|
case T_NEWLINE:
|
||||||
|
case T_RIGHTPAREN:
|
||||||
|
case T_RIGHTBRACKET:
|
||||||
|
case T_RIGHTBRACE:
|
||||||
|
case T_EOF:
|
||||||
|
addop(OP_UNDEF);
|
||||||
|
rescantoken();
|
||||||
|
return EXPR_RVALUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
rescantoken();
|
||||||
|
|
||||||
type = getaltcond();
|
type = getaltcond();
|
||||||
|
|
||||||
switch (gettoken()) {
|
switch (gettoken()) {
|
||||||
@@ -1402,7 +1462,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);
|
||||||
}
|
}
|
||||||
@@ -1441,7 +1501,7 @@ getaltcond(void)
|
|||||||
}
|
}
|
||||||
clearlabel(&donelab);
|
clearlabel(&donelab);
|
||||||
clearlabel(&altlab);
|
clearlabel(&altlab);
|
||||||
addoplabel(OP_JUMPEQ, &altlab);
|
addoplabel(OP_JUMPZ, &altlab);
|
||||||
type = getaltcond();
|
type = getaltcond();
|
||||||
if (gettoken() != T_COLON) {
|
if (gettoken() != T_COLON) {
|
||||||
scanerror(T_SEMICOLON, "Missing colon for conditional expression");
|
scanerror(T_SEMICOLON, "Missing colon for conditional expression");
|
||||||
|
@@ -231,8 +231,7 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
s3 = zquo(tmp3, d, &tmp1, s2 < 0);
|
s3 = zquo(tmp3, d, &tmp1, s2 < 0);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
s2 = zquo(tmp1, d, &tmp3, s1 ? (s1 < 0) : 16);
|
s2 = zquo(tmp1, d, &tmp3, s1 ? (s1 < 0) : 16);
|
||||||
zfree(tmp1);
|
zfree(tmp1);
|
||||||
s3 = zsqrt(tmp3,&tmp1,(s1||s2) ? (s1<0 || s2<0) : 16);
|
s3 = zsqrt(tmp3,&tmp1,(s1||s2) ? (s1<0 || s2<0) : 16);
|
||||||
@@ -288,8 +287,7 @@ csqrt(COMPLEX *c, NUMBER *epsilon, long R)
|
|||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
s3 = zquo(tmp3, d, &mul1, 0);
|
s3 = zquo(tmp3, d, &mul1, 0);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
s2 = zquo(tmp1, d, &tmp3, 0);
|
s2 = zquo(tmp1, d, &tmp3, 0);
|
||||||
zfree(tmp1);
|
zfree(tmp1);
|
||||||
s3 = zsqrt(tmp3, &mul1, 0);
|
s3 = zsqrt(tmp3, &mul1, 0);
|
||||||
|
71
config.c
71
config.c
@@ -55,6 +55,7 @@ NAMETYPE configs[] = {
|
|||||||
{"lib_debug", CONFIG_LIB_DEBUG},
|
{"lib_debug", CONFIG_LIB_DEBUG},
|
||||||
{"calc_debug", CONFIG_CALC_DEBUG},
|
{"calc_debug", CONFIG_CALC_DEBUG},
|
||||||
{"user_debug", CONFIG_USER_DEBUG},
|
{"user_debug", CONFIG_USER_DEBUG},
|
||||||
|
{"verbose_quit",CONFIG_VERBOSE_QUIT},
|
||||||
{NULL, 0}
|
{NULL, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -93,9 +94,10 @@ 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 */
|
||||||
0, /* calc library debug level */
|
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
0 /* user defined debug level */
|
3, /* calc library debug level */
|
||||||
|
0, /* user defined debug level */
|
||||||
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
CONFIG newstd = { /* new non-backward compatible configuration */
|
CONFIG newstd = { /* new non-backward compatible configuration */
|
||||||
MODE_INITIAL, /* current output mode */
|
MODE_INITIAL, /* current output mode */
|
||||||
@@ -128,9 +130,10 @@ 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 */
|
||||||
0, /* calc library debug level */
|
|
||||||
0, /* internal calc debug level */
|
0, /* internal calc debug level */
|
||||||
0 /* user defined debug level */
|
3, /* calc library debug level */
|
||||||
|
0, /* user defined debug level */
|
||||||
|
TRUE /* print Quit or abort executed messages */
|
||||||
};
|
};
|
||||||
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
CONFIG *conf = NULL; /* loaded in at startup - current configuration */
|
||||||
|
|
||||||
@@ -806,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");
|
||||||
@@ -834,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");
|
||||||
@@ -848,6 +851,21 @@ setconfig(int type, VALUE *vp)
|
|||||||
conf->user_debug = temp;
|
conf->user_debug = temp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONFIG_VERBOSE_QUIT:
|
||||||
|
if (vp->v_type == V_NUM) {
|
||||||
|
q = vp->v_num;
|
||||||
|
conf->verbose_quit = !qiszero(q);
|
||||||
|
} else if (vp->v_type == V_STR) {
|
||||||
|
temp = truthtype(vp->v_str->s_str);
|
||||||
|
if (temp < 0) {
|
||||||
|
math_error("Illegal truth value"
|
||||||
|
"for verbose_quit");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
conf->verbose_quit = (int)temp;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Setting illegal config parameter");
|
math_error("Setting illegal config parameter");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -1107,18 +1125,22 @@ 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;
|
||||||
|
|
||||||
|
case CONFIG_VERBOSE_QUIT:
|
||||||
|
i = cfg->verbose_quit;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
math_error("Getting illegal CONFIG element");
|
math_error("Getting illegal CONFIG element");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -1192,7 +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->user_debug != cfg2->user_debug;
|
cfg1->lib_debug != cfg2->lib_debug ||
|
||||||
|
cfg1->user_debug != cfg2->user_debug ||
|
||||||
|
cfg1->verbose_quit != cfg2->verbose_quit;
|
||||||
}
|
}
|
||||||
|
53
config.h
53
config.h
@@ -28,12 +28,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@@ -82,10 +80,11 @@
|
|||||||
#define CONFIG_LIB_DEBUG 30
|
#define CONFIG_LIB_DEBUG 30
|
||||||
#define CONFIG_CALC_DEBUG 31
|
#define CONFIG_CALC_DEBUG 31
|
||||||
#define CONFIG_USER_DEBUG 32
|
#define CONFIG_USER_DEBUG 32
|
||||||
|
#define CONFIG_VERBOSE_QUIT 33
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* config defult symbols
|
* config default symbols
|
||||||
*/
|
*/
|
||||||
#define DISPLAY_DEFAULT 20 /* default digits for float display */
|
#define DISPLAY_DEFAULT 20 /* default digits for float display */
|
||||||
#define EPSILON_DEFAULT "1e-20" /* allowed error for float calculations */
|
#define EPSILON_DEFAULT "1e-20" /* allowed error for float calculations */
|
||||||
@@ -95,8 +94,6 @@
|
|||||||
#define MAXPRINT_DEFAULT 16 /* default number of elements printed */
|
#define MAXPRINT_DEFAULT 16 /* default number of elements printed */
|
||||||
#define MAXSCANCOUNT 20 /* default max scan errors before an abort */
|
#define MAXSCANCOUNT 20 /* default max scan errors before an abort */
|
||||||
|
|
||||||
#define ERRMAX 20 /* default errmax value */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* configuration object
|
* configuration object
|
||||||
@@ -118,8 +115,8 @@ struct config {
|
|||||||
LEN sq2; /* size of number to use square algorithm 2 */
|
LEN sq2; /* size of number to use square algorithm 2 */
|
||||||
LEN pow2; /* size of modulus to use REDC for powers */
|
LEN pow2; /* size of modulus to use REDC for powers */
|
||||||
LEN redc2; /* size of modulus to use REDC algorithm 2 */
|
LEN redc2; /* size of modulus to use REDC algorithm 2 */
|
||||||
int tilde_ok; /* ok to print a tilde on aproximations */
|
BOOL tilde_ok; /* ok to print a tilde on aproximations */
|
||||||
int tab_ok; /* ok to print tab before numeric values */
|
BOOL tab_ok; /* ok to print tab before numeric values */
|
||||||
long quomod; /* quomod() default rounding mode */
|
long quomod; /* quomod() default rounding mode */
|
||||||
long quo; /* quotent // default rounding mode */
|
long quo; /* quotent // default rounding mode */
|
||||||
long mod; /* mod % default rounding mode */
|
long mod; /* mod % default rounding mode */
|
||||||
@@ -129,28 +126,52 @@ struct config {
|
|||||||
long cfsim; /* cfsim() default rounding mode */
|
long cfsim; /* cfsim() default rounding mode */
|
||||||
long outround; /* output default rounding mode */
|
long outround; /* output default rounding mode */
|
||||||
long round; /* round()/bround() default rounding mode */
|
long round; /* round()/bround() default rounding mode */
|
||||||
int leadzero; /* ok to print leading 0 before decimal pt */
|
BOOL leadzero; /* ok to print leading 0 before decimal pt */
|
||||||
int fullzero; /* ok to print trailing 0's */
|
BOOL fullzero; /* ok to print trailing 0's */
|
||||||
long maxscancount; /* max scan errors before abort */
|
long maxscancount; /* max scan errors before abort */
|
||||||
char *prompt1; /* normal prompt */
|
char *prompt1; /* normal prompt */
|
||||||
char *prompt2; /* prompt when inside multi-line input */
|
char *prompt2; /* prompt when inside multi-line input */
|
||||||
int blkmaxprint; /* octets of a block to print, 0 => all */
|
int blkmaxprint; /* octets of a block to print, 0 => all */
|
||||||
int blkverbose; /* TRUE => print all lines if a block */
|
BOOL blkverbose; /* TRUE => print all lines if a block */
|
||||||
int blkbase; /* block output base */
|
int blkbase; /* block output base */
|
||||||
int blkfmt; /* block output style */
|
int blkfmt; /* block output style */
|
||||||
int lib_debug; /* library debug: <0 none, 0 default, >0 more */
|
long calc_debug; /* internal debug, see CALC_DEBUG_XXX below */
|
||||||
int calc_debug; /* internal debug: <0 none, 0 default,>0 more */
|
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 */
|
||||||
};
|
};
|
||||||
typedef struct config CONFIG;
|
typedef struct config CONFIG;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* lib_debug bit masks
|
||||||
|
*/
|
||||||
|
#define LIBDBG_STDIN_FUNC (0x00000001) /* interactive func define debug */
|
||||||
|
#define LIBDBG_FILE_FUNC (0x00000002) /* file read func define debug */
|
||||||
|
#define LIBDBG_MASK (0x00000003)
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* calc_debug bit masks
|
||||||
|
*/
|
||||||
|
#define CALCDBG_SYSTEM (0x00000001) /* print system cmd prior to exec */
|
||||||
|
#define CALCDBG_FUNC_QUIT (0x00000002) /* active functions when quit */
|
||||||
|
#define CALCDBG_HASH_STATE (0x00000004) /* hash state details */
|
||||||
|
#define CALCDBG_BLOCK (0x00000008) /* block debug */
|
||||||
|
#define CALCDBG_TTY (0x00000010) /* report TTY state changes */
|
||||||
|
#define CALCDBG_RUNSTATE (0x00000020) /* report run_state changes */
|
||||||
|
#define CALCDBG_MASK (0x0000003f)
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* global configuration states and aliases
|
* global configuration states and aliases
|
||||||
*/
|
*/
|
||||||
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") */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
8
custom.c
8
custom.c
@@ -24,12 +24,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* these include files are needed regardless of CUSTOM */
|
/* these include files are needed regardless of CUSTOM */
|
||||||
|
9
custom.h
9
custom.h
@@ -28,15 +28,12 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Be careful what you put in this file, upper .c files include
|
* Be careful what you put in this file, upper .c files include
|
||||||
* this file even when CUSTOM is not defined (ALLOW_CUSTOM is empty).
|
* this file even when CUSTOM is not defined (ALLOW_CUSTOM is empty).
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 1997 Landon Curt Noll
|
# Copyright (c) 1999 Landon Curt Noll
|
||||||
#
|
#
|
||||||
# Permission to use, copy, modify, and distribute this software and
|
# Permission to use, copy, modify, and distribute this software and
|
||||||
# its documentation for any purpose and without fee is hereby granted,
|
# its documentation for any purpose and without fee is hereby granted,
|
||||||
@@ -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 /\../\ chongo@toad.com
|
# 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
|
||||||
@@ -44,8 +44,19 @@ calc library standards and guidelines.
|
|||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
|
argv.cal
|
||||||
|
|
||||||
|
argv(var, ...)
|
||||||
|
|
||||||
|
print information about various args
|
||||||
|
|
||||||
halflen.cal
|
halflen.cal
|
||||||
|
|
||||||
halflen(num)
|
halflen(num)
|
||||||
|
|
||||||
Calculate the length of a numeric value in HALF's.
|
Calculate the length of a numeric value in HALF's.
|
||||||
|
|
||||||
|
pzasusb8.cal
|
||||||
|
|
||||||
|
Run custom("pzasusb8") on a standard set of data, print Endian
|
||||||
|
related information and print value size information.
|
||||||
|
@@ -38,17 +38,17 @@ Step 1: Do some background work
|
|||||||
you look at some examples of custom functions. Check out
|
you look at some examples of custom functions. Check out
|
||||||
the following source files:
|
the following source files:
|
||||||
|
|
||||||
../custom.c
|
custom.c
|
||||||
custom.h
|
custom/custom.h
|
||||||
custtbl.c
|
custom/custtbl.c
|
||||||
c_*.[ch]
|
custom/c_*.[ch]
|
||||||
../help/custom
|
help/custom (or run: calc help custom)
|
||||||
|
|
||||||
You would be well advised to look at a more recent calc source
|
You would be well advised to look at a more recent calc source
|
||||||
such as one available in from the calc alpha test archive.
|
such as one available in from the calc version archive.
|
||||||
See the following for more details:
|
See the following for more details:
|
||||||
|
|
||||||
../help/archive
|
help/archive (or run: calc help archive)
|
||||||
|
|
||||||
|
|
||||||
Step 2: Name your custom function
|
Step 2: Name your custom function
|
||||||
@@ -604,3 +604,16 @@ Step 11: Install
|
|||||||
|
|
||||||
Although calc does not run setuid, you may need to be root to install
|
Although calc does not run setuid, you may need to be root to install
|
||||||
the directories into which calc installs may be write protected.
|
the directories into which calc installs may be write protected.
|
||||||
|
|
||||||
|
|
||||||
|
Step 12: Contribute
|
||||||
|
|
||||||
|
Your custom function may be of interest to some people and/or
|
||||||
|
serve as an example of what one can do with custom functions.
|
||||||
|
|
||||||
|
Read the file:
|
||||||
|
|
||||||
|
help/contrib (or run: calc help contrib)
|
||||||
|
|
||||||
|
and consider submitting your custom function for possible
|
||||||
|
inclusion in later versions of calc.
|
||||||
|
@@ -26,12 +26,10 @@
|
|||||||
#
|
#
|
||||||
# Happy bit twiddling,
|
# Happy bit twiddling,
|
||||||
#
|
#
|
||||||
# Landon Curt Noll
|
# Landon Curt Noll
|
||||||
|
# http://reality.sgi.com/chongo/
|
||||||
#
|
#
|
||||||
# chongo@toad.com
|
# chongo <was here> /\../\
|
||||||
# ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
#
|
|
||||||
# chongo was here /\../\
|
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
#-=-=-=-=-=-=-=-=- You may want to change some values below -=-=-=-=-=-=-=-=-#
|
#-=-=-=-=-=-=-=-=- You may want to change some values below -=-=-=-=-=-=-=-=-#
|
||||||
@@ -41,13 +39,13 @@
|
|||||||
#
|
#
|
||||||
# Put your custom calc library files here.
|
# Put your custom calc library files here.
|
||||||
#
|
#
|
||||||
CUSTOM_CALC_FILES= argv.cal halflen.cal
|
CUSTOM_CALC_FILES= argv.cal halflen.cal pzasusb8.cal
|
||||||
|
|
||||||
# The custom help files to install
|
# The custom help files to install
|
||||||
#
|
#
|
||||||
# Put your custom help files here.
|
# Put your custom help files here.
|
||||||
#
|
#
|
||||||
CUSTOM_HELP= argv devnull help sysinfo
|
CUSTOM_HELP= argv devnull help sysinfo pzasusb8
|
||||||
|
|
||||||
# Any .h files that are needed by programs that use libcustcalc.a
|
# Any .h files that are needed by programs that use libcustcalc.a
|
||||||
#
|
#
|
||||||
@@ -63,7 +61,7 @@ CUSTOM_H_SRC=
|
|||||||
#
|
#
|
||||||
# Put your custom .c files here.
|
# Put your custom .c files here.
|
||||||
#
|
#
|
||||||
CUSTOM_SRC= c_argv.c c_devnull.c c_help.c c_sysinfo.c
|
CUSTOM_SRC= c_argv.c c_devnull.c c_help.c c_sysinfo.c c_pzasusb8.c
|
||||||
|
|
||||||
# Any .o files that are needed by program that use libcustcalc.a.
|
# Any .o files that are needed by program that use libcustcalc.a.
|
||||||
# Don't put ${REQUIRED_OBJ} files in this list.
|
# Don't put ${REQUIRED_OBJ} files in this list.
|
||||||
@@ -72,7 +70,7 @@ CUSTOM_SRC= c_argv.c c_devnull.c c_help.c c_sysinfo.c
|
|||||||
#
|
#
|
||||||
# Put your custom .o files here.
|
# Put your custom .o files here.
|
||||||
#
|
#
|
||||||
CUSTOM_OBJ= c_argv.o c_devnull.o c_help.o c_sysinfo.o
|
CUSTOM_OBJ= c_argv.o c_devnull.o c_help.o c_sysinfo.o c_pzasusb8.o
|
||||||
|
|
||||||
##############################################################################
|
##############################################################################
|
||||||
#-=-=-=-=-=-=- Defaults in case you want to build from this dir -=-=-=-=-=-=-#
|
#-=-=-=-=-=-=- Defaults in case you want to build from this dir -=-=-=-=-=-=-#
|
||||||
@@ -339,15 +337,11 @@ libcustcalc.a: ${CUSTCALC_OBJ} ${MAKE_FILE} ../Makefile
|
|||||||
|
|
||||||
distlist: ${DISTLIST}
|
distlist: ${DISTLIST}
|
||||||
${Q}for i in ${DISTLIST}; do \
|
${Q}for i in ${DISTLIST}; do \
|
||||||
echo calc/custom/$$i; \
|
echo custom/$$i; \
|
||||||
done
|
done
|
||||||
|
|
||||||
# The bsdi distribution has generated files as well as distributed files.
|
distdir:
|
||||||
#
|
${Q}echo custom
|
||||||
bsdilist: ${DISTLIST}
|
|
||||||
${Q}for i in ${DISTLIST}; do \
|
|
||||||
echo calc/custom/$$i; \
|
|
||||||
done
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
@@ -421,9 +415,13 @@ depend:
|
|||||||
else \
|
else \
|
||||||
rm -f Makefile.tmp; \
|
rm -f Makefile.tmp; \
|
||||||
mv Makefile Makefile.tmp; \
|
mv Makefile Makefile.tmp; \
|
||||||
sccs edit Makefile; \
|
if [ -d RCS ]; then \
|
||||||
|
co -l Makefile; \
|
||||||
|
fi ;\
|
||||||
mv Makefile.tmp Makefile; \
|
mv Makefile.tmp Makefile; \
|
||||||
echo new 'custom Makefile formed -- you need to check it in'; \
|
if [ -d RCS ]; then \
|
||||||
|
echo 'new custom Makefile formed -- you need to check it in'; \
|
||||||
|
fi; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
##
|
##
|
||||||
@@ -590,6 +588,31 @@ c_help.o: ../string.h
|
|||||||
c_help.o: ../value.h
|
c_help.o: ../value.h
|
||||||
c_help.o: ../zmath.h
|
c_help.o: ../zmath.h
|
||||||
c_help.o: c_help.c
|
c_help.o: c_help.c
|
||||||
|
c_pzasusb8.o: ../alloc.h
|
||||||
|
c_pzasusb8.o: ../block.h
|
||||||
|
c_pzasusb8.o: ../byteswap.h
|
||||||
|
c_pzasusb8.o: ../calcerr.h
|
||||||
|
c_pzasusb8.o: ../cmath.h
|
||||||
|
c_pzasusb8.o: ../config.h
|
||||||
|
c_pzasusb8.o: ../custom.h
|
||||||
|
c_pzasusb8.o: ../endian_calc.h
|
||||||
|
c_pzasusb8.o: ../hash.h
|
||||||
|
c_pzasusb8.o: ../have_const.h
|
||||||
|
c_pzasusb8.o: ../have_malloc.h
|
||||||
|
c_pzasusb8.o: ../have_memmv.h
|
||||||
|
c_pzasusb8.o: ../have_newstr.h
|
||||||
|
c_pzasusb8.o: ../have_stdlib.h
|
||||||
|
c_pzasusb8.o: ../have_string.h
|
||||||
|
c_pzasusb8.o: ../longbits.h
|
||||||
|
c_pzasusb8.o: ../md5.h
|
||||||
|
c_pzasusb8.o: ../nametype.h
|
||||||
|
c_pzasusb8.o: ../qmath.h
|
||||||
|
c_pzasusb8.o: ../shs.h
|
||||||
|
c_pzasusb8.o: ../shs1.h
|
||||||
|
c_pzasusb8.o: ../string.h
|
||||||
|
c_pzasusb8.o: ../value.h
|
||||||
|
c_pzasusb8.o: ../zmath.h
|
||||||
|
c_pzasusb8.o: c_pzasusb8.c
|
||||||
c_sysinfo.o: ../alloc.h
|
c_sysinfo.o: ../alloc.h
|
||||||
c_sysinfo.o: ../block.h
|
c_sysinfo.o: ../block.h
|
||||||
c_sysinfo.o: ../byteswap.h
|
c_sysinfo.o: ../byteswap.h
|
||||||
|
@@ -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 /\../\ chongo@toad.com
|
* chongo was here /\../\ http://reality.sgi.com/chongo/
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* argv - print information about various args
|
* argv - print information about various args
|
||||||
|
@@ -15,12 +15,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
|
@@ -15,12 +15,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
|
@@ -15,12 +15,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
|
70
custom/c_pzasusb8.c
Normal file
70
custom/c_pzasusb8.c
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
/*
|
||||||
|
* Permission to use, copy, modify, and distribute this software and
|
||||||
|
* its documentation for any purpose and without fee is hereby granted.
|
||||||
|
*
|
||||||
|
* Ernest Bowen, following Landon Curt Noll
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(CUSTOM)
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include "../have_const.h"
|
||||||
|
#include "../value.h"
|
||||||
|
#include "../custom.h"
|
||||||
|
#include "../zmath.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
* c_pzasusb8 - print numereator of real as if its array of HALFs were
|
||||||
|
* a string of USB8s
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* count = 1;
|
||||||
|
* vals[0] real number;
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* null
|
||||||
|
*/
|
||||||
|
/*ARGSUSED*/
|
||||||
|
VALUE
|
||||||
|
c_pzasusb8(char *name, int count, VALUE **vals)
|
||||||
|
{
|
||||||
|
VALUE result; /* what we will return */
|
||||||
|
ZVALUE z; /* numerator of the value */
|
||||||
|
long half_cnt; /* number of HALFs in the numerator */
|
||||||
|
USB8 *h; /* octet pointer */
|
||||||
|
long half_len; /* length of a half in octets */
|
||||||
|
long i;
|
||||||
|
long j;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* arg check
|
||||||
|
*/
|
||||||
|
result.v_type = V_NULL;
|
||||||
|
if (vals[0]->v_type != V_NUM) {
|
||||||
|
math_error("Non-real argument for pzasusb8");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* look at the numerator
|
||||||
|
*/
|
||||||
|
z = vals[0]->v_num->num;
|
||||||
|
half_len = sizeof(HALF);
|
||||||
|
half_cnt = z.len;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* print the octets
|
||||||
|
*/
|
||||||
|
h = (USB8 *) z.v;
|
||||||
|
for (i=0; i < half_cnt; ++i) {
|
||||||
|
printf("%ld:\t", i);
|
||||||
|
for (j=0; j < half_len; ++j) {
|
||||||
|
printf("%02x", (int)(*h++));
|
||||||
|
}
|
||||||
|
putchar('\n');
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif /* CUSTOM */
|
@@ -15,12 +15,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CUSTOM)
|
#if defined(CUSTOM)
|
||||||
@@ -110,7 +108,6 @@ static struct infoname sys_info[] = {
|
|||||||
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
{"MAXLABELS", "max number of user labels in function", NULL, (FULL)MAXLABELS},
|
||||||
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
{"MAXLEN", "longest storage size allowed", NULL, (FULL)MAXLEN},
|
||||||
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
{"MAXLONG", "largest long val", NULL, (FULL)MAXLONG},
|
||||||
{"MAXOBJECTS", "max number of object types", NULL, (FULL)MAXOBJECTS},
|
|
||||||
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
{"MAXPRINT_DEFAULT", "default number of elements printed", NULL, (FULL)MAXPRINT_DEFAULT},
|
||||||
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
{"MAXREDC", "number of entries in REDC cache", NULL, (FULL)MAXREDC},
|
||||||
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
{"MAXSCANCOUNT", "default max scan errors before an abort", NULL, (FULL)MAXSCANCOUNT},
|
||||||
|
@@ -24,12 +24,10 @@
|
|||||||
*
|
*
|
||||||
* Happy bit twiddling,
|
* Happy bit twiddling,
|
||||||
*
|
*
|
||||||
* Landon Curt Noll
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
*
|
*
|
||||||
* chongo@toad.com
|
* chongo <was here> /\../\
|
||||||
* ...!{pyramid,sun,uunet}!hoptoad!chongo
|
|
||||||
*
|
|
||||||
* chongo was here /\../\
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@@ -59,6 +57,7 @@ extern VALUE c_argv(char*, int, VALUE**);
|
|||||||
extern VALUE c_devnull(char*, int, VALUE**);
|
extern VALUE c_devnull(char*, int, VALUE**);
|
||||||
extern VALUE c_help(char*, int, VALUE**);
|
extern VALUE c_help(char*, int, VALUE**);
|
||||||
extern VALUE c_sysinfo(char*, int, VALUE**);
|
extern VALUE c_sysinfo(char*, int, VALUE**);
|
||||||
|
extern VALUE c_pzasusb8(char*, int, VALUE**);
|
||||||
|
|
||||||
|
|
||||||
#endif /* CUSTOM */
|
#endif /* CUSTOM */
|
||||||
@@ -108,6 +107,9 @@ CONST struct custom cust[] = {
|
|||||||
{ "sysinfo", "return a calc #define value",
|
{ "sysinfo", "return a calc #define value",
|
||||||
0, 1, c_sysinfo },
|
0, 1, c_sysinfo },
|
||||||
|
|
||||||
|
{ "pzasusb8", "print ZCALUE as USB8",
|
||||||
|
0, 1, c_pzasusb8 },
|
||||||
|
|
||||||
|
|
||||||
#endif /* CUSTOM */
|
#endif /* CUSTOM */
|
||||||
|
|
||||||
|
@@ -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 /\../\ chongo@toad.com
|
* 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
|
||||||
|
50
custom/pzasusb8
Normal file
50
custom/pzasusb8
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
NAME
|
||||||
|
pzasusb8 - print a number in hex octets
|
||||||
|
|
||||||
|
SYNOPSIS
|
||||||
|
custom("pzasusb8", arg)
|
||||||
|
|
||||||
|
TYPES
|
||||||
|
arg real
|
||||||
|
|
||||||
|
return null
|
||||||
|
|
||||||
|
DESCRIPTION
|
||||||
|
This custom function prints out the numerator of a real value
|
||||||
|
in octets. Each HALF value is printed in a separate line.
|
||||||
|
|
||||||
|
NOTE: The output will vary depending on the size of a HALF
|
||||||
|
and the byte order of the system. See:
|
||||||
|
|
||||||
|
custom("sysinfo", "BASEB")
|
||||||
|
custom("sysinfo", "CALC_BYTE_ORDER")
|
||||||
|
|
||||||
|
foe details.
|
||||||
|
|
||||||
|
This custom function is intented for testing of the general
|
||||||
|
custom interface.
|
||||||
|
|
||||||
|
EXAMPLE
|
||||||
|
> custom("pzasusb8", 0x01020304050607080910111213141516);
|
||||||
|
0: 13141516
|
||||||
|
1: 09101112
|
||||||
|
2: 05060708
|
||||||
|
3: 01020304
|
||||||
|
|
||||||
|
> custom("pzasusb8", 10^25)
|
||||||
|
0: 4a000000
|
||||||
|
1: 16140148
|
||||||
|
2: 00084595
|
||||||
|
|
||||||
|
> printf("%x\n", 10^25);
|
||||||
|
0x84595161401484a000000
|
||||||
|
|
||||||
|
LIMITS
|
||||||
|
calc must be built with ALLOW_CUSTOM= -DCUSTOM
|
||||||
|
calc must be executed with a -C arg.
|
||||||
|
|
||||||
|
LIBRARY
|
||||||
|
none
|
||||||
|
|
||||||
|
SEE ALSO
|
||||||
|
custom
|
31
custom/pzasusb8.cal
Normal file
31
custom/pzasusb8.cal
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Permission to use, copy, modify, and distribute this software and
|
||||||
|
* its documentation for any purpose and without fee is hereby granted.
|
||||||
|
*
|
||||||
|
* Ernest Bowen, following Landon Curt Noll
|
||||||
|
*/
|
||||||
|
|
||||||
|
print "p(n) prints array in which numerator of n is stored as a";
|
||||||
|
print "sequence of 2-hex-digits representing unsigned characters.";
|
||||||
|
print "h(n) printx n in hex notation. This should be the same as";
|
||||||
|
print "p(n) except for (1) its leading 0x, (2) possible trailing zeros";
|
||||||
|
print "in p(n), and (3) the order of the hex-digit pairs.";
|
||||||
|
print "The following example show results for n = isqrt(2e100).";
|
||||||
|
print "";
|
||||||
|
|
||||||
|
define p(n) {custom("pzasusb8", n); print;}
|
||||||
|
define h(n) = printf("%x\n", n);
|
||||||
|
|
||||||
|
n = isqrt(2e100);
|
||||||
|
print "";
|
||||||
|
p(n);
|
||||||
|
h(n);
|
||||||
|
print "";
|
||||||
|
print "BASEB: ", custom("sysinfo", "BASEB");
|
||||||
|
print "CALC_BYTE_ORDER: ", custom("sysinfo", "CALC_BYTE_ORDER");
|
||||||
|
print "BIG_ENDIAN: ", custom("sysinfo", "BIG_ENDIAN");
|
||||||
|
print "LITTLE_ENDIAN: ", custom("sysinfo", "LITTLE_ENDIAN");
|
||||||
|
print "LONG_BITS: ", custom("sysinfo", "LONG_BITS");
|
||||||
|
print "LONGLONG_BITS: ", custom("sysinfo", "LONGLONG_BITS");
|
||||||
|
print "Calc sizes:";
|
||||||
|
show sizes;
|
2
endian.c
2
endian.c
@@ -76,5 +76,5 @@ main(void)
|
|||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
19
file.c
19
file.c
@@ -115,15 +115,14 @@ file_init(void)
|
|||||||
*/
|
*/
|
||||||
if (fstat(i, &sbuf) >= 0) {
|
if (fstat(i, &sbuf) >= 0) {
|
||||||
fp = (FILE *) fdopen(i,"r+"); /*guess mode*/
|
fp = (FILE *) fdopen(i,"r+"); /*guess mode*/
|
||||||
if (fp)
|
if (fp) {
|
||||||
strcpy(files[idnum].mode, "r+");
|
strcpy(files[idnum].mode, "r+");
|
||||||
else {
|
} else {
|
||||||
fp = (FILE *) fdopen(i, "r");
|
fp = (FILE *) fdopen(i, "r");
|
||||||
if (fp) {
|
if (fp) {
|
||||||
strcpy(files[idnum].mode, "r");
|
strcpy(files[idnum].mode, "r");
|
||||||
files[idnum].writing = FALSE;
|
files[idnum].writing = FALSE;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
fp = (FILE *) fdopen(i, "w");
|
fp = (FILE *) fdopen(i, "w");
|
||||||
if (fp) {
|
if (fp) {
|
||||||
strcpy(files[idnum].mode, "w?");
|
strcpy(files[idnum].mode, "w?");
|
||||||
@@ -885,13 +884,14 @@ idprintf(FILEID id, char *fmt, int count, VALUE **vals)
|
|||||||
math_str((char *)
|
math_str((char *)
|
||||||
vp->v_nblock
|
vp->v_nblock
|
||||||
->blk->data);
|
->blk->data);
|
||||||
} else if (printchar) {
|
} else if (printchar) {
|
||||||
if (vp->v_nblock->blk->data !=
|
if (vp->v_nblock->blk->data !=
|
||||||
NULL)
|
NULL)
|
||||||
math_chr(*vp->v_nblock->
|
math_chr(*vp->v_nblock->
|
||||||
blk->data);
|
blk->data);
|
||||||
} else
|
} else {
|
||||||
printvalue(vp, PRINT_NORMAL);
|
printvalue(vp, PRINT_NORMAL);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
printvalue(vp, PRINT_NORMAL);
|
printvalue(vp, PRINT_NORMAL);
|
||||||
@@ -1770,8 +1770,7 @@ showfiles(void)
|
|||||||
if (fstat(fileno(fp), &sbuf) < 0) {
|
if (fstat(fileno(fp), &sbuf) < 0) {
|
||||||
printf("Bad fstat for file %d\n", (int) fiop->id);
|
printf("Bad fstat for file %d\n", (int) fiop->id);
|
||||||
sizes[i] = -1;
|
sizes[i] = -1;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
inodes[i] = sbuf.st_ino;
|
inodes[i] = sbuf.st_ino;
|
||||||
sizes[i] = (long) sbuf.st_size;
|
sizes[i] = (long) sbuf.st_size;
|
||||||
}
|
}
|
||||||
@@ -2471,9 +2470,9 @@ fsearch(FILEID id, char *str, ZVALUE start, ZVALUE end, ZVALUE *res)
|
|||||||
}
|
}
|
||||||
(void) f_seek_set(fiop->fp, &cur);
|
(void) f_seek_set(fiop->fp, &cur);
|
||||||
}
|
}
|
||||||
if (*tmp.v)
|
if (*tmp.v) {
|
||||||
(*tmp.v)--;
|
(*tmp.v)--;
|
||||||
else {
|
} else {
|
||||||
if (tmp.len == 1)
|
if (tmp.len == 1)
|
||||||
break;
|
break;
|
||||||
k = 0;
|
k = 0;
|
||||||
|
371
func.c
371
func.c
@@ -72,6 +72,7 @@ static int strscan(char *s, int count, VALUE **vals);
|
|||||||
static int filescan(FILEID id, int count, VALUE **vals);
|
static int filescan(FILEID id, int count, VALUE **vals);
|
||||||
static VALUE f_eval(VALUE *vp);
|
static VALUE f_eval(VALUE *vp);
|
||||||
static VALUE f_fsize(VALUE *vp);
|
static VALUE f_fsize(VALUE *vp);
|
||||||
|
static int malloced_putenv(char *str);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -84,6 +85,21 @@ extern void matrandperm(MATRIX *M);
|
|||||||
extern void listrandperm(LIST *lp);
|
extern void listrandperm(LIST *lp);
|
||||||
extern int idungetc(FILEID id, int ch);
|
extern int idungetc(FILEID id, int ch);
|
||||||
|
|
||||||
|
extern int stoponerror;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* malloced environment storage
|
||||||
|
*/
|
||||||
|
#define ENV_POOL_CHUNK 10 /* env_pool elements to allocate at a time */
|
||||||
|
struct env_pool {
|
||||||
|
char *getenv; /* what getenv() would return, NULL => unused */
|
||||||
|
char *putenv; /* pointer given to putenv() */
|
||||||
|
};
|
||||||
|
static int env_pool_cnt = 0; /* number of env_pool elements in use */
|
||||||
|
static int env_pool_max = 0; /* number of env_pool elements allocated */
|
||||||
|
static struct env_pool *e_pool = NULL; /* env_pool elements */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* if HZ & CLK_TCK are not defined, pick typical values, hope for the best
|
* if HZ & CLK_TCK are not defined, pick typical values, hope for the best
|
||||||
@@ -137,12 +153,15 @@ f_eval(VALUE *vp)
|
|||||||
FUNC *oldfunc;
|
FUNC *oldfunc;
|
||||||
FUNC *newfunc;
|
FUNC *newfunc;
|
||||||
VALUE result;
|
VALUE result;
|
||||||
char *cp;
|
char *str;
|
||||||
|
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);
|
||||||
cp = vp->v_str->s_str;
|
str = vp->v_str->s_str;
|
||||||
switch (openstring(cp)) {
|
num = vp->v_str->s_len;
|
||||||
|
switch (openstring(str, num)) {
|
||||||
case -2:
|
case -2:
|
||||||
return error_value(E_EVAL3);
|
return error_value(E_EVAL3);
|
||||||
case -1:
|
case -1:
|
||||||
@@ -150,7 +169,11 @@ f_eval(VALUE *vp)
|
|||||||
}
|
}
|
||||||
oldfunc = curfunc;
|
oldfunc = curfunc;
|
||||||
enterfilescope();
|
enterfilescope();
|
||||||
|
temp = stoponerror;
|
||||||
|
stoponerror = -1;
|
||||||
if (evaluate(TRUE)) {
|
if (evaluate(TRUE)) {
|
||||||
|
stoponerror = temp;
|
||||||
|
closeinput();
|
||||||
exitfilescope();
|
exitfilescope();
|
||||||
freevalue(stack--);
|
freevalue(stack--);
|
||||||
newfunc = curfunc;
|
newfunc = curfunc;
|
||||||
@@ -162,6 +185,8 @@ f_eval(VALUE *vp)
|
|||||||
free(newfunc);
|
free(newfunc);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
stoponerror = temp;
|
||||||
|
closeinput();
|
||||||
exitfilescope();
|
exitfilescope();
|
||||||
newfunc = curfunc;
|
newfunc = curfunc;
|
||||||
curfunc = oldfunc;
|
curfunc = oldfunc;
|
||||||
@@ -183,11 +208,11 @@ f_prompt(VALUE *vp)
|
|||||||
unsigned int len;
|
unsigned int len;
|
||||||
|
|
||||||
result.v_type = V_STR;
|
result.v_type = V_STR;
|
||||||
if (inputisterminal()) {
|
openterminal();
|
||||||
printvalue(vp, PRINT_SHORT);
|
printvalue(vp, PRINT_SHORT);
|
||||||
math_flush();
|
math_flush();
|
||||||
}
|
|
||||||
cp = nextline();
|
cp = nextline();
|
||||||
|
closeinput();
|
||||||
if (cp == NULL) {
|
if (cp == NULL) {
|
||||||
math_error("End of file while prompting");
|
math_error("End of file while prompting");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
@@ -209,6 +234,28 @@ f_prompt(VALUE *vp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
f_display(int count, VALUE **vals)
|
||||||
|
{
|
||||||
|
long oldvalue;
|
||||||
|
VALUE res;
|
||||||
|
|
||||||
|
oldvalue = conf->outdigits;
|
||||||
|
|
||||||
|
if (count > 0) {
|
||||||
|
if (vals[0]->v_type != V_NUM || qisfrac(vals[0]->v_num) ||
|
||||||
|
qisneg(vals[0]->v_num) || zge31b(vals[0]->v_num->num))
|
||||||
|
fprintf(stderr,
|
||||||
|
"Out-of-range arg for display ignored\n");
|
||||||
|
else
|
||||||
|
conf->outdigits = qtoi(vals[0]->v_num);
|
||||||
|
}
|
||||||
|
res.v_type = V_NUM;
|
||||||
|
res.v_num = itoq(oldvalue);
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*ARGSUSED*/
|
/*ARGSUSED*/
|
||||||
static VALUE
|
static VALUE
|
||||||
f_null(int count, VALUE **vals)
|
f_null(int count, VALUE **vals)
|
||||||
@@ -1482,16 +1529,12 @@ static VALUE
|
|||||||
f_hash(int count, VALUE **vals)
|
f_hash(int count, VALUE **vals)
|
||||||
{
|
{
|
||||||
QCKHASH hash;
|
QCKHASH hash;
|
||||||
long lhash;
|
|
||||||
VALUE result;
|
VALUE result;
|
||||||
|
|
||||||
hash = (QCKHASH)0;
|
hash = FNV1_32_BASIS;
|
||||||
while (count-- > 0)
|
while (count-- > 0)
|
||||||
hash = hashvalue(*vals++, hash);
|
hash = hashvalue(*vals++, hash);
|
||||||
lhash = (long) hash;
|
result.v_num = utoq((FULL) hash);
|
||||||
if (lhash < 0)
|
|
||||||
lhash = -lhash;
|
|
||||||
result.v_num = itoq(lhash);
|
|
||||||
result.v_type = V_NUM;
|
result.v_type = V_NUM;
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -1598,8 +1641,7 @@ f_avg(int count, VALUE **vals)
|
|||||||
if ((*vals)->v_type == V_LIST) {
|
if ((*vals)->v_type == V_LIST) {
|
||||||
addlistitems((*vals)->v_list, &sum);
|
addlistitems((*vals)->v_list, &sum);
|
||||||
n += countlistitems((*vals++)->v_list);
|
n += countlistitems((*vals++)->v_list);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
addvalue(&sum, *vals++, &tmp);
|
addvalue(&sum, *vals++, &tmp);
|
||||||
freevalue(&sum);
|
freevalue(&sum);
|
||||||
sum = tmp;
|
sum = tmp;
|
||||||
@@ -1648,8 +1690,7 @@ f_hmean(int count, VALUE **vals)
|
|||||||
if ((*vals)->v_type == V_LIST) {
|
if ((*vals)->v_type == V_LIST) {
|
||||||
addlistinv((*vals)->v_list, &sum);
|
addlistinv((*vals)->v_list, &sum);
|
||||||
n += countlistitems((*vals++)->v_list);
|
n += countlistitems((*vals++)->v_list);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
invertvalue(*vals++, &tmp1);
|
invertvalue(*vals++, &tmp1);
|
||||||
addvalue(&sum, &tmp1, &tmp2);
|
addvalue(&sum, &tmp1, &tmp2);
|
||||||
freevalue(&tmp1);
|
freevalue(&tmp1);
|
||||||
@@ -3800,9 +3841,9 @@ f_search(int count, VALUE **vals)
|
|||||||
start = qlink(start);
|
start = qlink(start);
|
||||||
}
|
}
|
||||||
if (end) {
|
if (end) {
|
||||||
if (!qispos(end))
|
if (!qispos(end)) {
|
||||||
end = qqadd(size, end);
|
end = qqadd(size, end);
|
||||||
else {
|
} else {
|
||||||
if (qrel(end, size) > 0)
|
if (qrel(end, size) > 0)
|
||||||
end = qlink(size);
|
end = qlink(size);
|
||||||
else
|
else
|
||||||
@@ -3824,8 +3865,7 @@ f_search(int count, VALUE **vals)
|
|||||||
if (count == 2 || (count == 4 && end != NULL)) {
|
if (count == 2 || (count == 4 && end != NULL)) {
|
||||||
start = qalloc();
|
start = qalloc();
|
||||||
start->num = pos;
|
start->num = pos;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
end = qalloc();
|
end = qalloc();
|
||||||
end->num = pos;
|
end->num = pos;
|
||||||
}
|
}
|
||||||
@@ -3963,9 +4003,9 @@ f_rsearch(int count, VALUE **vals)
|
|||||||
start = qlink(start);
|
start = qlink(start);
|
||||||
}
|
}
|
||||||
if (end) {
|
if (end) {
|
||||||
if (!qispos(end))
|
if (!qispos(end)) {
|
||||||
end = qqadd(size, end);
|
end = qqadd(size, end);
|
||||||
else {
|
} else {
|
||||||
if (qrel(end, size) > 0)
|
if (qrel(end, size) > 0)
|
||||||
end = qlink(size);
|
end = qlink(size);
|
||||||
else
|
else
|
||||||
@@ -3987,8 +4027,7 @@ f_rsearch(int count, VALUE **vals)
|
|||||||
if (count == 2 || (count == 4 && end != NULL)) {
|
if (count == 2 || (count == 4 && end != NULL)) {
|
||||||
start = qalloc();
|
start = qalloc();
|
||||||
start->num = pos;
|
start->num = pos;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
end = qalloc();
|
end = qalloc();
|
||||||
end->num = pos;
|
end->num = pos;
|
||||||
}
|
}
|
||||||
@@ -4000,8 +4039,7 @@ f_rsearch(int count, VALUE **vals)
|
|||||||
if (count < 4) {
|
if (count < 4) {
|
||||||
end = start;
|
end = start;
|
||||||
start = NULL;
|
start = NULL;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
qtmp = qsub(end, qlen);
|
qtmp = qsub(end, qlen);
|
||||||
qfree(end);
|
qfree(end);
|
||||||
end = qtmp;
|
end = qtmp;
|
||||||
@@ -4392,11 +4430,7 @@ f_errno(int count, VALUE **vals)
|
|||||||
math_error("errno argument out of range");
|
math_error("errno argument out of range");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
newerr = z1tol(vp->v_num->num);
|
newerr = (int) ztoi(vp->v_num->num);
|
||||||
if (newerr >= 32768) {
|
|
||||||
math_error("errno argument out of range");
|
|
||||||
/*NOTREACHED*/
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
olderr = set_errno(newerr);
|
olderr = set_errno(newerr);
|
||||||
|
|
||||||
@@ -4423,7 +4457,7 @@ f_errcount(int count, VALUE **vals)
|
|||||||
math_error("errcount argument out of range");
|
math_error("errcount argument out of range");
|
||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
newcount = z1tol(vp->v_num->num);
|
newcount = (int) ztoi(vp->v_num->num);
|
||||||
}
|
}
|
||||||
oldcount = set_errcount(newcount);
|
oldcount = set_errcount(newcount);
|
||||||
|
|
||||||
@@ -4436,23 +4470,21 @@ f_errcount(int count, VALUE **vals)
|
|||||||
static VALUE
|
static VALUE
|
||||||
f_errmax(int count, VALUE **vals)
|
f_errmax(int count, VALUE **vals)
|
||||||
{
|
{
|
||||||
int newmax, oldmax;
|
int oldmax;
|
||||||
VALUE *vp;
|
VALUE *vp;
|
||||||
VALUE result;
|
VALUE result;
|
||||||
|
|
||||||
newmax = -1;
|
oldmax = errmax;
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
vp = vals[0];
|
vp = vals[0];
|
||||||
|
|
||||||
/* arg must be an integer */
|
|
||||||
if (vp->v_type != V_NUM || qisfrac(vp->v_num) ||
|
if (vp->v_type != V_NUM || qisfrac(vp->v_num) ||
|
||||||
qisneg(vp->v_num) || zge31b(vp->v_num->num)) {
|
zge31b(vp->v_num->num))
|
||||||
math_error("errcount argument out of range");
|
fprintf(stderr,
|
||||||
/*NOTREACHED*/
|
"Out-of-range arg for errmax ignored\n");
|
||||||
}
|
else
|
||||||
newmax = z1tol(vp->v_num->num);
|
errmax = (int) ztoi(vp->v_num->num);
|
||||||
}
|
}
|
||||||
oldmax = set_errmax(newmax);
|
|
||||||
|
|
||||||
result.v_type = V_NUM;
|
result.v_type = V_NUM;
|
||||||
result.v_num = itoq((long) oldmax);
|
result.v_num = itoq((long) oldmax);
|
||||||
@@ -4460,6 +4492,30 @@ f_errmax(int count, VALUE **vals)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
f_stoponerror(int count, VALUE **vals)
|
||||||
|
{
|
||||||
|
int oldval;
|
||||||
|
VALUE *vp;
|
||||||
|
VALUE result;
|
||||||
|
|
||||||
|
oldval = stoponerror;
|
||||||
|
if (count > 0) {
|
||||||
|
vp = vals[0];
|
||||||
|
|
||||||
|
if (vp->v_type != V_NUM || qisfrac(vp->v_num) ||
|
||||||
|
zge31b(vp->v_num->num))
|
||||||
|
fprintf(stderr,
|
||||||
|
"Out-of-range arg for stoponerror ignored\n");
|
||||||
|
else
|
||||||
|
stoponerror = (int) ztoi(vp->v_num->num);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.v_type = V_NUM;
|
||||||
|
result.v_num = itoq((long) oldval);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
static VALUE
|
static VALUE
|
||||||
f_fclose(int count, VALUE **vals)
|
f_fclose(int count, VALUE **vals)
|
||||||
{
|
{
|
||||||
@@ -4574,9 +4630,9 @@ f_strerror(int count, VALUE **vals)
|
|||||||
|
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
vp = vals[0];
|
vp = vals[0];
|
||||||
if (vp->v_type < 0)
|
if (vp->v_type < 0) {
|
||||||
i = (long) -vp->v_type;
|
i = (long) -vp->v_type;
|
||||||
else {
|
} else {
|
||||||
if (vp->v_type != V_NUM || qisfrac(vp->v_num))
|
if (vp->v_type != V_NUM || qisfrac(vp->v_num))
|
||||||
return error_value(E_STRERROR1);
|
return error_value(E_STRERROR1);
|
||||||
i = qtoi(vp->v_num);
|
i = qtoi(vp->v_num);
|
||||||
@@ -4687,12 +4743,12 @@ f_error(int count, VALUE **vals)
|
|||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
vp = vals[0];
|
vp = vals[0];
|
||||||
|
|
||||||
if (vp->v_type <= 0)
|
if (vp->v_type <= 0) {
|
||||||
r = (long) -vp->v_type;
|
r = (long) -vp->v_type;
|
||||||
else {
|
} else {
|
||||||
if (vp->v_type != V_NUM || qisfrac(vp->v_num))
|
if (vp->v_type != V_NUM || qisfrac(vp->v_num)) {
|
||||||
r = E_ERROR1;
|
r = E_ERROR1;
|
||||||
else {
|
} else {
|
||||||
r = qtoi(vp->v_num);
|
r = qtoi(vp->v_num);
|
||||||
if (r < 0 || r >= 32768)
|
if (r < 0 || r >= 32768)
|
||||||
r = E_ERROR2;
|
r = E_ERROR2;
|
||||||
@@ -5482,28 +5538,26 @@ f_tail(VALUE *v1, VALUE *v2)
|
|||||||
res.v_type = v1->v_type;
|
res.v_type = v1->v_type;
|
||||||
switch (v1->v_type) {
|
switch (v1->v_type) {
|
||||||
case V_LIST:
|
case V_LIST:
|
||||||
if (n == 0)
|
if (n == 0) {
|
||||||
res.v_list = listalloc();
|
res.v_list = listalloc();
|
||||||
else if (n > 0) {
|
} else if (n > 0) {
|
||||||
res.v_list = listsegment(v1->v_list,
|
res.v_list = listsegment(v1->v_list,
|
||||||
v1->v_list->l_count - n,
|
v1->v_list->l_count - n,
|
||||||
v1->v_list->l_count - 1);
|
v1->v_list->l_count - 1);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
res.v_list = listsegment(v1->v_list,
|
res.v_list = listsegment(v1->v_list,
|
||||||
v1->v_list->l_count - 1,
|
v1->v_list->l_count - 1,
|
||||||
v1->v_list->l_count + n);
|
v1->v_list->l_count + n);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
case V_STR:
|
case V_STR:
|
||||||
if (n == 0)
|
if (n == 0) {
|
||||||
res.v_str = slink(&_nullstring_);
|
res.v_str = slink(&_nullstring_);
|
||||||
else if (n > 0) {
|
} else if (n > 0) {
|
||||||
res.v_str = stringsegment(v1->v_str,
|
res.v_str = stringsegment(v1->v_str,
|
||||||
v1->v_str->s_len - n,
|
v1->v_str->s_len - n,
|
||||||
v1->v_str->s_len - 1);
|
v1->v_str->s_len - 1);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
res.v_str = stringsegment(v1->v_str,
|
res.v_str = stringsegment(v1->v_str,
|
||||||
v1->v_str->s_len - 1,
|
v1->v_str->s_len - 1,
|
||||||
v1->v_str->s_len + n);
|
v1->v_str->s_len + n);
|
||||||
@@ -5833,6 +5887,28 @@ f_isatty(VALUE *vp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static VALUE
|
||||||
|
f_inputlevel (void)
|
||||||
|
{
|
||||||
|
VALUE result;
|
||||||
|
|
||||||
|
result.v_type = V_NUM;
|
||||||
|
result.v_num = itoq((long) inputlevel());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
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)
|
||||||
{
|
{
|
||||||
@@ -5935,8 +6011,7 @@ f_putenv(int count, VALUE **vals)
|
|||||||
|
|
||||||
/* return putenv result */
|
/* return putenv result */
|
||||||
result.v_type = V_NUM;
|
result.v_type = V_NUM;
|
||||||
result.v_num = itoq((long) putenv(putenv_str));
|
result.v_num = itoq((long) malloced_putenv(putenv_str));
|
||||||
free(putenv_str);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -5978,6 +6053,9 @@ f_system(VALUE *vp)
|
|||||||
/*NOTREACHED*/
|
/*NOTREACHED*/
|
||||||
}
|
}
|
||||||
result.v_type = V_NUM;
|
result.v_type = V_NUM;
|
||||||
|
if (conf->calc_debug & CALCDBG_SYSTEM) {
|
||||||
|
printf("%s\n", vp->v_str->s_str);
|
||||||
|
}
|
||||||
result.v_num = itoq((long) system(vp->v_str->s_str));
|
result.v_num = itoq((long) system(vp->v_str->s_str));
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -6756,6 +6834,8 @@ static CONST struct builtin builtins[] = {
|
|||||||
"round value a to b number of binary places"},
|
"round value a to b number of binary places"},
|
||||||
{"btrunc", 1, 2, 0, OP_NOP, f_btrunc, 0,
|
{"btrunc", 1, 2, 0, OP_NOP, f_btrunc, 0,
|
||||||
"truncate a to b number of binary places"},
|
"truncate a to b number of binary places"},
|
||||||
|
{"calclevel", 0, 0, 0, OP_NOP, 0, f_calclevel,
|
||||||
|
"current calculation level"},
|
||||||
{"ceil", 1, 1, 0, OP_NOP, 0, f_ceil,
|
{"ceil", 1, 1, 0, OP_NOP, 0, f_ceil,
|
||||||
"smallest integer greater than or equal to number"},
|
"smallest integer greater than or equal to number"},
|
||||||
{"cfappr", 1, 3, 0, OP_NOP, f_cfappr, 0,
|
{"cfappr", 1, 3, 0, OP_NOP, f_cfappr, 0,
|
||||||
@@ -6806,6 +6886,8 @@ static CONST struct builtin builtins[] = {
|
|||||||
"digit at specified decimal place of number"},
|
"digit at specified decimal place of number"},
|
||||||
{"digits", 1, 1, 0, OP_NOP, f_digits, 0,
|
{"digits", 1, 1, 0, OP_NOP, f_digits, 0,
|
||||||
"number of digits in number"},
|
"number of digits in number"},
|
||||||
|
{"display", 0, 1, 0, OP_NOP, 0, f_display,
|
||||||
|
"number of decimal digits for displaying numbers"},
|
||||||
{"dp", 2, 2, 0, OP_NOP, 0, f_dp,
|
{"dp", 2, 2, 0, OP_NOP, 0, f_dp,
|
||||||
"dot product of two vectors"},
|
"dot product of two vectors"},
|
||||||
{"epsilon", 0, 1, 0, OP_SETEPSILON, 0, 0,
|
{"epsilon", 0, 1, 0, OP_SETEPSILON, 0, 0,
|
||||||
@@ -6916,6 +6998,8 @@ static CONST struct builtin builtins[] = {
|
|||||||
"integral log of a number base 2"},
|
"integral log of a number base 2"},
|
||||||
{"im", 1, 1, 0, OP_IM, 0, 0,
|
{"im", 1, 1, 0, OP_IM, 0, 0,
|
||||||
"imaginary part of complex number"},
|
"imaginary part of complex number"},
|
||||||
|
{"inputlevel", 0, 0, 0, OP_NOP, 0, f_inputlevel,
|
||||||
|
"current input depth"},
|
||||||
{"insert", 2, IN, FA, OP_NOP, 0, f_listinsert,
|
{"insert", 2, IN, FA, OP_NOP, 0, f_listinsert,
|
||||||
"insert values c ... into list a at position b"},
|
"insert values c ... into list a at position b"},
|
||||||
{"int", 1, 1, 0, OP_INT, qint, 0,
|
{"int", 1, 1, 0, OP_INT, qint, 0,
|
||||||
@@ -7188,6 +7272,8 @@ static CONST struct builtin builtins[] = {
|
|||||||
"seed the random() function"},
|
"seed the random() function"},
|
||||||
{"ssq", 1, IN, 0, OP_NOP, 0, f_ssq,
|
{"ssq", 1, IN, 0, OP_NOP, 0, f_ssq,
|
||||||
"sum of squares of values"},
|
"sum of squares of values"},
|
||||||
|
{"stoponerror", 0, 1, 0, OP_NOP, 0, f_stoponerror,
|
||||||
|
"assign value to stoponerror flag"},
|
||||||
{"str", 1, 1, 0, OP_NOP, 0, f_str,
|
{"str", 1, 1, 0, OP_NOP, 0, f_str,
|
||||||
"simple value converted to string"},
|
"simple value converted to string"},
|
||||||
{"strcat", 1,IN, 0, OP_NOP, 0, f_strcat,
|
{"strcat", 1,IN, 0, OP_NOP, 0, f_strcat,
|
||||||
@@ -7248,12 +7334,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 */
|
||||||
@@ -7271,6 +7378,7 @@ showbuiltins(void)
|
|||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
#endif /* FUNCLIST */
|
||||||
|
|
||||||
|
|
||||||
#if !defined(FUNCLIST)
|
#if !defined(FUNCLIST)
|
||||||
@@ -7476,4 +7584,145 @@ showerrors(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* malloced_putenv - Keep track of malloced environment variable storage
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* str a malloced string which will be given to putenv
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* putenv() return value
|
||||||
|
*
|
||||||
|
* NOTE: The caller MUST pass a string that the caller has previously malloced.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
malloced_putenv(char *str)
|
||||||
|
{
|
||||||
|
char *value; /* location of the value part of the str argument */
|
||||||
|
char *old_val; /* previously stored (or inherited) env value */
|
||||||
|
int found_cnt; /* number of active env_pool entries found */
|
||||||
|
struct env_pool *new; /* new e_pool */
|
||||||
|
int i;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* firewall
|
||||||
|
*/
|
||||||
|
if (str == NULL) {
|
||||||
|
math_error("malloced_putenv given a NULL pointer!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
if (str[0] == '=') {
|
||||||
|
math_error("malloced_putenv = is first character in string!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* determine the place where getenv would return
|
||||||
|
*/
|
||||||
|
value = strchr(str, '=');
|
||||||
|
if (value == NULL) {
|
||||||
|
math_error("malloced_putenv = not found in string!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
++value;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* lookup for an existing environment value
|
||||||
|
*/
|
||||||
|
*(value-1) = '\0';
|
||||||
|
old_val = getenv(str);
|
||||||
|
*(value-1) = '=';
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we have the value in our environment, look for a
|
||||||
|
* previously malloced string and free it
|
||||||
|
*/
|
||||||
|
if (old_val != NULL && env_pool_cnt > 0) {
|
||||||
|
for (i=0, found_cnt=0;
|
||||||
|
i < env_pool_max && found_cnt < env_pool_cnt;
|
||||||
|
++i) {
|
||||||
|
|
||||||
|
/* skip an unused entry */
|
||||||
|
if (e_pool[i].getenv == NULL) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
++found_cnt;
|
||||||
|
|
||||||
|
/* look for the 1st match */
|
||||||
|
if (e_pool[i].getenv == value) {
|
||||||
|
|
||||||
|
/* found match, free the storage */
|
||||||
|
if (e_pool[i].putenv != NULL) {
|
||||||
|
free(e_pool[i].putenv);
|
||||||
|
}
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
--env_pool_cnt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ensure that we have room in the e_pool
|
||||||
|
*/
|
||||||
|
if (env_pool_max == 0) {
|
||||||
|
|
||||||
|
/* allocate an initial pool (with one extra guard value) */
|
||||||
|
new = (struct env_pool *)malloc((ENV_POOL_CHUNK+1) *
|
||||||
|
sizeof(struct env_pool));
|
||||||
|
if (new == NULL) {
|
||||||
|
math_error("malloced_putenv malloc failed");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
e_pool = new;
|
||||||
|
env_pool_max = ENV_POOL_CHUNK;
|
||||||
|
for (i=0; i <= ENV_POOL_CHUNK; ++i) {
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if (env_pool_cnt >= env_pool_max) {
|
||||||
|
|
||||||
|
/* expand the current pool (with one extra guard value) */
|
||||||
|
new = (struct env_pool *)realloc(e_pool,
|
||||||
|
(env_pool_max+ENV_POOL_CHUNK+1) *
|
||||||
|
sizeof(struct env_pool));
|
||||||
|
if (new == NULL) {
|
||||||
|
math_error("malloced_putenv realloc failed");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
e_pool = new;
|
||||||
|
for (i=env_pool_max; i <= env_pool_max + ENV_POOL_CHUNK; ++i) {
|
||||||
|
e_pool[i].getenv = NULL;
|
||||||
|
}
|
||||||
|
env_pool_max += ENV_POOL_CHUNK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* store our data into the first e_pool entry
|
||||||
|
*/
|
||||||
|
for (i=0; i < env_pool_max; ++i) {
|
||||||
|
|
||||||
|
/* skip used entries */
|
||||||
|
if (e_pool[i].getenv != NULL) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* store in this free entry and stop looping */
|
||||||
|
e_pool[i].getenv = value;
|
||||||
|
e_pool[i].putenv = str;
|
||||||
|
++env_pool_cnt;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (i >= env_pool_max) {
|
||||||
|
math_error("malloced_putenv missed unused entry!!");
|
||||||
|
/*NOTREACHED*/
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* finally, do the putenv action
|
||||||
|
*/
|
||||||
|
return putenv(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif /* FUNCLIST */
|
#endif /* FUNCLIST */
|
||||||
|
49
hash.c
49
hash.c
@@ -391,8 +391,8 @@ hash_zvalue(int type, ZVALUE zval, HASH *state)
|
|||||||
*/
|
*/
|
||||||
if (zval.len > full_lim) {
|
if (zval.len > full_lim) {
|
||||||
for (j=0; j < zval.len-full_lim-1; j += 2) {
|
for (j=0; j < zval.len-full_lim-1; j += 2) {
|
||||||
half[j] = zval.v[full_lim+i+1];
|
half[j] = zval.v[full_lim+j+1];
|
||||||
half[j+1] = zval.v[full_lim+i];
|
half[j+1] = zval.v[full_lim+j];
|
||||||
}
|
}
|
||||||
if (j < zval.len-full_lim) {
|
if (j < zval.len-full_lim) {
|
||||||
half[j] = (HALF)0;
|
half[j] = (HALF)0;
|
||||||
@@ -562,7 +562,7 @@ hash_complex(int type, void *c, HASH *state)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash_str - hash a string
|
* hash_str - hash a null-terminated string
|
||||||
*
|
*
|
||||||
* given:
|
* given:
|
||||||
* type - hash type (see hash.h)
|
* type - hash type (see hash.h)
|
||||||
@@ -606,6 +606,47 @@ hash_str(int type, char *str, HASH *state)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* hash_STR - hash a STRING
|
||||||
|
*
|
||||||
|
* given:
|
||||||
|
* type - hash type (see hash.h)
|
||||||
|
* str - the STRING
|
||||||
|
* state - the state to hash or NULL
|
||||||
|
*
|
||||||
|
* returns:
|
||||||
|
* the new state
|
||||||
|
*/
|
||||||
|
HASH *
|
||||||
|
hash_STR(int type, STRING *str, HASH *state)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* initialize if state is NULL
|
||||||
|
*/
|
||||||
|
if (state == NULL) {
|
||||||
|
state = hash_init(type, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* setup for the string hash
|
||||||
|
*/
|
||||||
|
if (!state->bytes) {
|
||||||
|
(state->chkpt)(state);
|
||||||
|
state->bytes = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* hash the string
|
||||||
|
*/
|
||||||
|
(state->update)(state, (USB8*) str->s_str, (USB32) str->s_len);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* all done
|
||||||
|
*/
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* hash_usb8 - hash an array of USB8s
|
* hash_usb8 - hash an array of USB8s
|
||||||
*
|
*
|
||||||
@@ -720,7 +761,7 @@ hash_value(int type, void *v, HASH *state)
|
|||||||
/* strings have no setup */
|
/* strings have no setup */
|
||||||
|
|
||||||
/* hash this type */
|
/* hash this type */
|
||||||
state = hash_str(type, value->v_str->s_str, state);
|
state = hash_STR(type, value->v_str, state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case V_MAT:
|
case V_MAT:
|
||||||
|
@@ -46,16 +46,21 @@ int
|
|||||||
main(void)
|
main(void)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_NO_CONST)
|
#if defined(HAVE_NO_CONST)
|
||||||
|
|
||||||
printf("#undef HAVE_CONST /* no */\n");
|
printf("#undef HAVE_CONST /* no */\n");
|
||||||
printf("#undef CONST\n");
|
printf("#undef CONST\n");
|
||||||
printf("#define CONST /* no */\n");
|
printf("#define CONST /* no */\n");
|
||||||
|
|
||||||
#else /* HAVE_NO_CONST */
|
#else /* HAVE_NO_CONST */
|
||||||
|
|
||||||
const char * const str = "const";
|
const char * const str = "const";
|
||||||
|
|
||||||
printf("#define HAVE_CONST /* yes */\n");
|
printf("#define HAVE_CONST /* yes */\n");
|
||||||
printf("#undef CONST\n");
|
printf("#undef CONST\n");
|
||||||
printf("#define CONST %s /* yes */\n", str);
|
printf("#define CONST %s /* yes */\n", str);
|
||||||
|
|
||||||
#endif /* HAVE_NO_CONST */
|
#endif /* HAVE_NO_CONST */
|
||||||
|
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
60
have_getpgid.c
Normal file
60
have_getpgid.c
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* have_getpgid - Determine if we getpgid()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_getpgid
|
||||||
|
*
|
||||||
|
* Not all systems have the getpgid() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_GETPGID
|
||||||
|
* defined ==> use getpgid()
|
||||||
|
* undefined ==> do not or cannot call getpgid()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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/types.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_GETPGID)
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETPGID /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_GETPGID */
|
||||||
|
|
||||||
|
(void) getpgid((pid_t)0);
|
||||||
|
|
||||||
|
printf("#define HAVE_GETPGID /* yes */\n");
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_GETPGID */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
59
have_getprid.c
Normal file
59
have_getprid.c
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* have_getprid - Determine if we getprid()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_getprid
|
||||||
|
*
|
||||||
|
* Not all systems have the getprid() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_GETPRID
|
||||||
|
* defined ==> use getprid()
|
||||||
|
* undefined ==> do not or cannot call getprid()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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/types.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_GETPRID)
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETPRID /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_GETPRID */
|
||||||
|
|
||||||
|
(void) getprid();
|
||||||
|
printf("#define HAVE_GETPRID /* yes */\n");
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_GETPRID */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
59
have_getsid.c
Normal file
59
have_getsid.c
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* have_getsid - Determine if we getsid()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_getsid
|
||||||
|
*
|
||||||
|
* Not all systems have the getsid() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_GETSID
|
||||||
|
* defined ==> use getsid()
|
||||||
|
* undefined ==> do not call or cannot call getsid()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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/types.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_GETSID)
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETSID /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_GETSID */
|
||||||
|
|
||||||
|
(void) getsid((pid_t)0);
|
||||||
|
|
||||||
|
printf("#define HAVE_GETSID /* yes */\n");
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_GETSID */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
74
have_gettime.c
Normal file
74
have_gettime.c
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
/*
|
||||||
|
* have_gettime - Determine if we clock_gettime()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_gettime
|
||||||
|
*
|
||||||
|
* Not all systems have the clock_gettime() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_GETTIME
|
||||||
|
* defined ==> use clock_gettime() for either CLOCK_SGI_CYCLE
|
||||||
|
* and/or CLOCK_REALTIME
|
||||||
|
* undefined ==> clock_gettime() is not available for both
|
||||||
|
* CLOCK_SGI_CYCLE and CLOCK_REALTIME
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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 <time.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_GETTIME)
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETTIME /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_GETTIME */
|
||||||
|
|
||||||
|
# if defined(CLOCK_SGI_CYCLE)
|
||||||
|
|
||||||
|
struct timespec sgi_cycle; /* SGI hardware clock */
|
||||||
|
(void) clock_gettime(CLOCK_SGI_CYCLE, &sgi_cycle);
|
||||||
|
printf("#define HAVE_GETTIME /* yes - w/CLOCK_SGI_CYCLE */\n");
|
||||||
|
|
||||||
|
# elif defined(CLOCK_REALTIME)
|
||||||
|
|
||||||
|
struct timespec realtime; /* POSIX realtime clock */
|
||||||
|
(void) clock_gettime(CLOCK_REALTIME, &realtime);
|
||||||
|
printf("#define HAVE_GETTIME /* yes - CLOCK_REALTIME only */\n");
|
||||||
|
|
||||||
|
# else
|
||||||
|
|
||||||
|
printf("#undef HAVE_GETTIME /* no - no SGI_CYCLE and no REALTIME */\n");
|
||||||
|
|
||||||
|
# endif /* CLOCK_REALTIME */
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_GETTIME */
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -2,7 +2,7 @@
|
|||||||
* have_memmv - Determine if we memmove()
|
* have_memmv - Determine if we memmove()
|
||||||
*
|
*
|
||||||
* usage:
|
* usage:
|
||||||
* have_newstr
|
* have_memmv
|
||||||
*
|
*
|
||||||
* Not all systems with memcpy() have memmove() functions, so this may not
|
* Not all systems with memcpy() have memmove() functions, so this may not
|
||||||
* compile on your system.
|
* compile on your system.
|
||||||
@@ -48,12 +48,17 @@ int
|
|||||||
main(void)
|
main(void)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_NO_MEMMOVE)
|
#if defined(HAVE_NO_MEMMOVE)
|
||||||
|
|
||||||
printf("#undef HAVE_MEMMOVE /* no */\n");
|
printf("#undef HAVE_MEMMOVE /* no */\n");
|
||||||
|
|
||||||
#else /* HAVE_NO_MEMMOVE */
|
#else /* HAVE_NO_MEMMOVE */
|
||||||
|
|
||||||
(void) memmove(dest, src, MOVELEN);
|
(void) memmove(dest, src, MOVELEN);
|
||||||
|
|
||||||
printf("#define HAVE_MEMMOVE /* yes */\n");
|
printf("#define HAVE_MEMMOVE /* yes */\n");
|
||||||
|
|
||||||
#endif /* HAVE_NO_MEMMOVE */
|
#endif /* HAVE_NO_MEMMOVE */
|
||||||
|
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@@ -50,14 +50,19 @@ int
|
|||||||
main(void)
|
main(void)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_NO_NEWSTR)
|
#if defined(HAVE_NO_NEWSTR)
|
||||||
|
|
||||||
printf("#undef HAVE_NEWSTR /* no */\n");
|
printf("#undef HAVE_NEWSTR /* no */\n");
|
||||||
|
|
||||||
#else /* HAVE_NO_NEWSTR */
|
#else /* HAVE_NO_NEWSTR */
|
||||||
|
|
||||||
(void) memcpy(dest, src, MOVELEN);
|
(void) memcpy(dest, src, MOVELEN);
|
||||||
(void) memset(dest, 0, MOVELEN);
|
(void) memset(dest, 0, MOVELEN);
|
||||||
(void) strchr(src, 'e');
|
(void) strchr(src, 'e');
|
||||||
|
|
||||||
printf("#define HAVE_NEWSTR /* yes */\n");
|
printf("#define HAVE_NEWSTR /* yes */\n");
|
||||||
|
|
||||||
#endif /* HAVE_NO_NEWSTR */
|
#endif /* HAVE_NO_NEWSTR */
|
||||||
|
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
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;
|
||||||
|
}
|
@@ -51,15 +51,20 @@ int
|
|||||||
main(void)
|
main(void)
|
||||||
{
|
{
|
||||||
#if defined(HAVE_NO_UID_T)
|
#if defined(HAVE_NO_UID_T)
|
||||||
|
|
||||||
printf("#undef HAVE_UID_T /* no */\n");
|
printf("#undef HAVE_UID_T /* no */\n");
|
||||||
|
|
||||||
#else /* HAVE_NO_UID_T */
|
#else /* HAVE_NO_UID_T */
|
||||||
|
|
||||||
uid_t curds;
|
uid_t curds;
|
||||||
extern uid_t geteuid();
|
extern uid_t geteuid();
|
||||||
|
|
||||||
curds = geteuid();
|
curds = geteuid();
|
||||||
|
|
||||||
printf("#define HAVE_UID_T /* yes */\n");
|
printf("#define HAVE_UID_T /* yes */\n");
|
||||||
|
|
||||||
#endif /* HAVE_NO_UID_T */
|
#endif /* HAVE_NO_UID_T */
|
||||||
|
|
||||||
/* exit(0); */
|
/* exit(0); */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
65
have_ustat.c
Normal file
65
have_ustat.c
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
/*
|
||||||
|
* have_ustat - Determine if we ustat()
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* have_ustat
|
||||||
|
*
|
||||||
|
* Not all systems have the ustat() function, so this may not
|
||||||
|
* compile on your system.
|
||||||
|
*
|
||||||
|
* This prog outputs several defines:
|
||||||
|
*
|
||||||
|
* HAVE_USTAT
|
||||||
|
* defined ==> use ustat()
|
||||||
|
* undefined ==> do not call or cannot call ustat()
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* 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/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <ustat.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
#if defined(HAVE_NO_USTAT)
|
||||||
|
|
||||||
|
printf("#undef HAVE_USTAT /* no */\n");
|
||||||
|
|
||||||
|
#else /* HAVE_NO_USTAT */
|
||||||
|
|
||||||
|
struct stat stat_dot; /* stat of "." */
|
||||||
|
struct ustat ustat_dot; /* usage stat of "." */
|
||||||
|
|
||||||
|
(void) stat(".", &stat_dot);
|
||||||
|
(void) ustat(stat_dot.st_dev, &ustat_dot);
|
||||||
|
|
||||||
|
printf("#define HAVE_USTAT /* yes */\n");
|
||||||
|
|
||||||
|
#endif /* HAVE_NO_USTAT */
|
||||||
|
|
||||||
|
/* exit(0); */
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -57,11 +57,13 @@ try_this(char *fmt, ...)
|
|||||||
va_list ap;
|
va_list ap;
|
||||||
|
|
||||||
va_start(ap);
|
va_start(ap);
|
||||||
|
|
||||||
#if !defined(DONT_HAVE_VSPRINTF)
|
#if !defined(DONT_HAVE_VSPRINTF)
|
||||||
vsprintf(buf, fmt, ap);
|
vsprintf(buf, fmt, ap);
|
||||||
#else
|
#else
|
||||||
sprintf(buf, fmt, ap);
|
sprintf(buf, fmt, ap);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
va_end(ap);
|
va_end(ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
3
help.c
3
help.c
@@ -121,9 +121,8 @@ givehelp(char *type)
|
|||||||
"else %s no such help, try: help help;fi",
|
"else %s no such help, try: help help;fi",
|
||||||
HELPDIR, type, pager, HELPDIR, type,
|
HELPDIR, type, pager, HELPDIR, type,
|
||||||
CUSTOMHELPDIR, type, pager, CUSTOMHELPDIR, type, ECHO);
|
CUSTOMHELPDIR, type, pager, CUSTOMHELPDIR, type, ECHO);
|
||||||
if (conf->calc_debug > 0) {
|
if (conf->calc_debug & CALCDBG_SYSTEM) {
|
||||||
printf("%s\n", helpcmd);
|
printf("%s\n", helpcmd);
|
||||||
sleep(3);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* execute the help command */
|
/* execute the help command */
|
||||||
|
@@ -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
|
||||||
#
|
#
|
||||||
@@ -74,7 +73,7 @@ STD_HELP_FILES_12= archive
|
|||||||
|
|
||||||
BLT_HELP_FILES_13= bugs changes
|
BLT_HELP_FILES_13= bugs changes
|
||||||
|
|
||||||
STD_HELP_FILES_14= contrib credit todo
|
STD_HELP_FILES_14= contrib credit wishlist todo
|
||||||
|
|
||||||
# These files are used in the following order to construct full
|
# These files are used in the following order to construct full
|
||||||
#
|
#
|
||||||
@@ -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 \
|
||||||
@@ -258,7 +258,7 @@ calc: usage
|
|||||||
|
|
||||||
custom_cal: ../custom/CUSTOM_CAL
|
custom_cal: ../custom/CUSTOM_CAL
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp ../custom/CUSTOM_CAL $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -270,7 +270,7 @@ custom_cal: ../custom/CUSTOM_CAL
|
|||||||
|
|
||||||
new_custom: ../custom/HOW_TO_ADD
|
new_custom: ../custom/HOW_TO_ADD
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp ../custom/HOW_TO_ADD $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -282,7 +282,7 @@ new_custom: ../custom/HOW_TO_ADD
|
|||||||
|
|
||||||
copy: blkcpy
|
copy: blkcpy
|
||||||
rm -f $@
|
rm -f $@
|
||||||
cp usage $@
|
cp blkcpy $@
|
||||||
chmod 0444 $@
|
chmod 0444 $@
|
||||||
-@if [ -z "${Q}" ]; then \
|
-@if [ -z "${Q}" ]; then \
|
||||||
echo ''; \
|
echo ''; \
|
||||||
@@ -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; \
|
||||||
|
31
help/archive
31
help/archive
@@ -1,31 +1,16 @@
|
|||||||
Where to get the the latest versions of calc
|
Where to get the the latest versions of calc
|
||||||
|
|
||||||
Landon Noll maintains the official calc ftp archive at:
|
Landon Noll maintains the official calc home page at:
|
||||||
|
|
||||||
ftp://ftp.uu.net/pub/calc
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
|
|
||||||
Alpha test versions, complete with bugs, untested code and
|
|
||||||
experimental features may be fetched (if you are brave) under:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc/
|
|
||||||
|
|
||||||
One may join the calc testing group by sending a request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
|
||||||
|
|
||||||
subscribe calc-tester address
|
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
|
||||||
is your full name.
|
|
||||||
|
|
||||||
See:
|
See:
|
||||||
|
|
||||||
http://prime.corp.sgi.com/csp/ioccc/noll/noll.html#calc
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
for details.
|
for information on how to obtain up a recent version of calc.
|
||||||
|
|
||||||
Landon Curt Noll <chongo@toad.com> /\oo/\
|
Landon Curt Noll
|
||||||
|
http://reality.sgi.com/chongo/
|
||||||
|
|
||||||
|
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
|
263
help/command
263
help/command
@@ -14,12 +14,10 @@ Command sequence
|
|||||||
described in the next section.
|
described in the next section.
|
||||||
|
|
||||||
|
|
||||||
NOTE: Calc commands are in lower case. UPPER case is used below
|
define a function
|
||||||
for emphasis only, and should be considered in lower case.
|
-----------------
|
||||||
|
define function(params) { body }
|
||||||
|
define function(params) = expression
|
||||||
DEFINE function(params) { body }
|
|
||||||
DEFINE function(params) = expression
|
|
||||||
This first form defines a full function which can consist
|
This first form defines a full function which can consist
|
||||||
of declarations followed by many statements which implement
|
of declarations followed by many statements which implement
|
||||||
the function.
|
the function.
|
||||||
@@ -30,13 +28,22 @@ Command sequence
|
|||||||
and question mark operators can be useful. Examples of
|
and question mark operators can be useful. Examples of
|
||||||
simple functions are:
|
simple functions are:
|
||||||
|
|
||||||
define sumcubes(a, b) = a^3 + b^3;
|
define sumcubes(a, b) = a^3 + b^3
|
||||||
define pimod(a) = a % pi();
|
define pimod(a) = a % pi()
|
||||||
|
define printnum(a, n, p)
|
||||||
|
{
|
||||||
|
if (p == 0) {
|
||||||
|
print a: "^": n, "=", a^n;
|
||||||
|
} else {
|
||||||
|
print a: "^": n, "mod", p, "=", pmod(a,n,p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
HELP
|
|
||||||
This displays a general help message.
|
|
||||||
|
|
||||||
READ filename
|
read calc commands
|
||||||
|
------------------
|
||||||
|
read filename
|
||||||
|
read -once filename
|
||||||
This reads definitions from the specified filename.
|
This reads definitions from the specified filename.
|
||||||
The name can be quoted if desired. The calculator
|
The name can be quoted if desired. The calculator
|
||||||
uses the CALCPATH environment variable to search
|
uses the CALCPATH environment variable to search
|
||||||
@@ -52,14 +59,11 @@ Command sequence
|
|||||||
evaluate or functions to define, just like at the top
|
evaluate or functions to define, just like at the top
|
||||||
level command level.
|
level command level.
|
||||||
|
|
||||||
If the -m mode disallows opening of files for reading,
|
When -once is given, the read command acts like the regular
|
||||||
this command will be disabled.
|
read expect that it will ignore filename if is has been
|
||||||
|
previously read.
|
||||||
|
|
||||||
READ -once filename
|
The read -once form is particularly useful in a library that
|
||||||
This command acts like the regular READ expect that it
|
|
||||||
will ignore filename if is has been previously read.
|
|
||||||
|
|
||||||
This command is particularly useful in a library that
|
|
||||||
needs to read a 2nd library. By using the READ -once
|
needs to read a 2nd library. By using the READ -once
|
||||||
command, one will not reread that 2nd library, nor will
|
command, one will not reread that 2nd library, nor will
|
||||||
once risk entering into a infinite READ loop (where
|
once risk entering into a infinite READ loop (where
|
||||||
@@ -69,7 +73,10 @@ Command sequence
|
|||||||
If the -m mode disallows opening of files for reading,
|
If the -m mode disallows opening of files for reading,
|
||||||
this command will be disabled.
|
this command will be disabled.
|
||||||
|
|
||||||
WRITE filename
|
|
||||||
|
write calc commands
|
||||||
|
-------------------
|
||||||
|
write filename
|
||||||
This writes the values of all global variables to the
|
This writes the values of all global variables to the
|
||||||
specified filename, in such a way that the file can be
|
specified filename, in such a way that the file can be
|
||||||
later read in order to recreate the variable values.
|
later read in order to recreate the variable values.
|
||||||
@@ -81,19 +88,221 @@ Command sequence
|
|||||||
If the -m mode disallows opening of files for writing,
|
If the -m mode disallows opening of files for writing,
|
||||||
this command will be disabled.
|
this command will be disabled.
|
||||||
|
|
||||||
QUIT
|
|
||||||
This leaves the calculator, when given as a top-level
|
|
||||||
command.
|
|
||||||
|
|
||||||
CD
|
quit or exit
|
||||||
Change the current directory to the home directory, if $HOME
|
------------
|
||||||
|
quit
|
||||||
|
quit string
|
||||||
|
exit
|
||||||
|
exit string
|
||||||
|
The action of these commands depends on where they are used.
|
||||||
|
At the interactive level, they will cause calc it edit.
|
||||||
|
This is the normal way to leave the calculator. In any
|
||||||
|
other use, they will stop the current calculation as if
|
||||||
|
an error had occurred.
|
||||||
|
|
||||||
|
If a string is given, then the string is printed as the reason
|
||||||
|
for quitting, otherwise a general quit message is printed.
|
||||||
|
The routine name and line number which executed the quit is
|
||||||
|
also printed in either case.
|
||||||
|
|
||||||
|
Exit is an alias for quit.
|
||||||
|
|
||||||
|
Quit is useful when a routine detects invalid arguments,
|
||||||
|
in order to stop a calculation cleanly. For example,
|
||||||
|
for a square root routine, an error can be given if the
|
||||||
|
supplied parameter was a negative number, as in:
|
||||||
|
|
||||||
|
define mysqrt(n)
|
||||||
|
{
|
||||||
|
if (! isnum(n))
|
||||||
|
quit "non-numeric argument";
|
||||||
|
if (n < 0)
|
||||||
|
quit "Negative argument";
|
||||||
|
return sqrt(n);
|
||||||
|
}
|
||||||
|
|
||||||
|
See 'more information about abort and quit' below for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
abort
|
||||||
|
-----
|
||||||
|
abort
|
||||||
|
abort string
|
||||||
|
This command behaves like QUIT except that it will attempt
|
||||||
|
to return to the interactive level if permitted, otherwise
|
||||||
|
calc exit.
|
||||||
|
|
||||||
|
See 'more information about abort and quit' below for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
|
||||||
|
change current directory
|
||||||
|
------------------------
|
||||||
|
cd
|
||||||
|
cd dir
|
||||||
|
Change the current directory to 'dir'. If 'dir' is ommitted,
|
||||||
|
change the current directory to the home directory, if $HOME
|
||||||
is set in the environment.
|
is set in the environment.
|
||||||
|
|
||||||
CD dir
|
|
||||||
Change the current directory to dir.
|
show information
|
||||||
|
----------------
|
||||||
|
show item
|
||||||
|
This command displays some information where 'item' is
|
||||||
|
one of the following:
|
||||||
|
|
||||||
|
blocks unfreed named blocks
|
||||||
|
builtin built in functions
|
||||||
|
config config parameters and values
|
||||||
|
constants cache of numeric constants
|
||||||
|
custom custom functions if calc -C was used
|
||||||
|
errors new error-values created
|
||||||
|
files open files, file position and sizes
|
||||||
|
function user-defined functions
|
||||||
|
globaltypes global variables
|
||||||
|
objfunctions possible object functions
|
||||||
|
objtypes defined objects
|
||||||
|
opcodes func internal opcodes for function `func'
|
||||||
|
sizes size in octets of calc value types
|
||||||
|
realglobals numeric global variables
|
||||||
|
statics unscoped static variables
|
||||||
|
numbers calc number cache
|
||||||
|
redcdata REDC data defined
|
||||||
|
strings calc string cache
|
||||||
|
literals calc literal cache
|
||||||
|
|
||||||
|
Only the first 4 characters of item are examined, so:
|
||||||
|
|
||||||
|
show globals
|
||||||
|
show global
|
||||||
|
show glob
|
||||||
|
|
||||||
|
do the same thing.
|
||||||
|
|
||||||
|
|
||||||
|
calc help
|
||||||
|
---------
|
||||||
|
help
|
||||||
|
help name
|
||||||
|
This displays a help related to 'name' or general
|
||||||
|
help of none is given.
|
||||||
|
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
|
||||||
|
more information about abort and quit
|
||||||
|
=====================================
|
||||||
|
|
||||||
|
Consider the following calc file called myfile.cal:
|
||||||
|
|
||||||
|
print "start of myfile.cal";
|
||||||
|
define q() {quit "quit from q()"; print "end of q()"}
|
||||||
|
define a() {abort "abort from a()"}
|
||||||
|
x = 3;
|
||||||
|
{print "start #1"; if (x > 1) q()} print "after #1";
|
||||||
|
{print "start #2"; if (x > 1) a()} print "after #2";
|
||||||
|
{print "start #3"; if (x > 1) quit "quit from 3rd statement"}
|
||||||
|
print "end of myfile.cal";
|
||||||
|
|
||||||
|
The command:
|
||||||
|
|
||||||
|
calc read myfile
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
|
||||||
|
The QUIT within the q() function prevented the ``end of q()''
|
||||||
|
statement from being evaluated. This QUIT command caused
|
||||||
|
control to be returned to just after the place where q()
|
||||||
|
was called.
|
||||||
|
|
||||||
|
Notice that unlike QUIT, the ABORT inside function a() halts
|
||||||
|
the processing of statements from the input source (myfile.cal).
|
||||||
|
Because calc was not interactive, ABORT causes calc to exit.
|
||||||
|
|
||||||
|
The command:
|
||||||
|
|
||||||
|
calc -i read myfile
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
> <==== calc interactive prompt
|
||||||
|
|
||||||
|
because the '-i' calc causes ABORT to drop into an
|
||||||
|
interactive prompt. However typing a QUIT or ABORT
|
||||||
|
at the interactive prompt level will always calc to exit,
|
||||||
|
even when calc is invoked with '-i'.
|
||||||
|
|
||||||
|
Also observe that both of these commands:
|
||||||
|
|
||||||
|
cat myfile.cal | calc
|
||||||
|
cat myfile.cal | calc -i
|
||||||
|
|
||||||
|
will produce:
|
||||||
|
|
||||||
|
q() defined
|
||||||
|
a() defined
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
|
||||||
|
The ABORT inside function a() halts the processing of statements
|
||||||
|
from the input source (standard input). Because standard input
|
||||||
|
is not a terminal, using '-i' does not force it to drop into
|
||||||
|
an interactive prompt.
|
||||||
|
|
||||||
|
If one were to type in the contents of myfile.cal interactively,
|
||||||
|
calc will produce:
|
||||||
|
|
||||||
|
> print "start of myfile.cal";
|
||||||
|
start of myfile.cal
|
||||||
|
> define q() {quit "quit from q()"; print "end of q()"}
|
||||||
|
q() defined
|
||||||
|
> define a() {abort "abort from a()"}
|
||||||
|
a() defined
|
||||||
|
> x = 3;
|
||||||
|
> {print "start #1"; if (x > 1) q()} print "after #1";
|
||||||
|
start statment #1
|
||||||
|
quit from q()
|
||||||
|
after statment #1
|
||||||
|
> {print "start #2"; if (x > 1) a()} print "after #2";
|
||||||
|
start statment #2
|
||||||
|
abort from a()
|
||||||
|
> {print "start #3"; if (x > 1) quit "quit from 3rd statement"}
|
||||||
|
start #3
|
||||||
|
quit from 3rd statement
|
||||||
|
|
||||||
|
The ABORT from within the a() function returned control to
|
||||||
|
the interactive level.
|
||||||
|
|
||||||
|
The QUIT (after the if (x > 1) ...) will cause calc to exit
|
||||||
|
because it was given at the interactive prompt level.
|
||||||
|
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
|
||||||
Also see the help topic:
|
Also see the help topic:
|
||||||
|
|
||||||
statement flow control and declaration statements
|
statement flow control and declaration statements
|
||||||
usage for -m modes
|
usage how to invoke the calc command and calc -options
|
||||||
|
134
help/config
134
help/config
@@ -40,9 +40,10 @@ Configuration parameters
|
|||||||
"blkverbose" TRUE=>print all lines, FALSE=>skip duplicates
|
"blkverbose" TRUE=>print all lines, FALSE=>skip duplicates
|
||||||
"blkbase" block output base
|
"blkbase" block output base
|
||||||
"blkfmt" block output format
|
"blkfmt" block output format
|
||||||
"lib_debug" calc library script debug level
|
"calc_debug" controls internal calc debug information
|
||||||
"calc_debug" internal calc debug level
|
"lib_debug" controls library script debug information
|
||||||
"user_debug" user defined debug level
|
"user_debug" for user defined debug information
|
||||||
|
"verbose_quit" TRUE=>print message on empty quit or abort
|
||||||
|
|
||||||
|
|
||||||
The "all" config value allows one to save/restore the configuration
|
The "all" config value allows one to save/restore the configuration
|
||||||
@@ -78,7 +79,8 @@ Configuration parameters
|
|||||||
The "newstd" is not backward compatible with the historic
|
The "newstd" is not backward compatible with the historic
|
||||||
configuration. Even so, some people prefer this configuration
|
configuration. Even so, some people prefer this configuration
|
||||||
and place the config("all", "newstd") command in their CALCRC
|
and place the config("all", "newstd") command in their CALCRC
|
||||||
startup files.
|
startup files; newstd may also be established by invoking calc
|
||||||
|
with the flag -n.
|
||||||
|
|
||||||
When nonzero, the "trace" parameter activates one or more features
|
When nonzero, the "trace" parameter activates one or more features
|
||||||
that may be useful for debugging. These features correspond to
|
that may be useful for debugging. These features correspond to
|
||||||
@@ -103,9 +105,12 @@ Configuration parameters
|
|||||||
the decimal point to be printed in real or exponential mode in
|
the decimal point to be printed in real or exponential mode in
|
||||||
normal unformatted printing (print, strprint, fprint) or in
|
normal unformatted printing (print, strprint, fprint) or in
|
||||||
formatted printing (printf, strprintf, fprintf) when precision is not
|
formatted printing (printf, strprintf, fprintf) when precision is not
|
||||||
specified. The initial value is 20. This parameter does not change
|
specified. The initial value for oldstd is 20, for newstd 10.
|
||||||
the stored value of a number. Where rounding is necessary, the type
|
The parameter may be changed to the value d by either
|
||||||
of rounding to be used is controlled by "outround".
|
config("display", d) or by display (d). This parameter does not change
|
||||||
|
the stored value of a number. Where rounding is necessary to
|
||||||
|
display up to d decimal places, the type of rounding to be used is
|
||||||
|
controlled by config("outround").
|
||||||
|
|
||||||
The "epsilon" parameter specifies the default accuracy for the
|
The "epsilon" parameter specifies the default accuracy for the
|
||||||
calculation of functions for which exact values are not possible or
|
calculation of functions for which exact values are not possible or
|
||||||
@@ -118,9 +123,10 @@ Configuration parameters
|
|||||||
absolute value of the remainder usually does not exceed epsilon/2.
|
absolute value of the remainder usually does not exceed epsilon/2.
|
||||||
Functions which require an epsilon value accept an
|
Functions which require an epsilon value accept an
|
||||||
optional argument which overrides this default epsilon value for
|
optional argument which overrides this default epsilon value for
|
||||||
that single call. (The value v can be assigned to the "epsilon"
|
that single call. The value v can be assigned to the "epsilon"
|
||||||
parameter by epsilon(v) as well as by config("epsilon", v), and the
|
parameter by either config("epsilon", v) or epsilon(v); each of
|
||||||
current value obtained by epsilon() as well as by config("epsilon").)
|
these functions return the current epsilon value; config("epsilon")
|
||||||
|
or epsilon() returns but does not change the epsilon value.
|
||||||
For the transcendental functions and the functions sqrt() and
|
For the transcendental functions and the functions sqrt() and
|
||||||
appr(), the calculated value is always a multiple of epsilon.
|
appr(), the calculated value is always a multiple of epsilon.
|
||||||
|
|
||||||
@@ -311,67 +317,87 @@ Configuration parameters
|
|||||||
|
|
||||||
The default "blkfmt" is "hd".
|
The default "blkfmt" is "hd".
|
||||||
|
|
||||||
With regards to "lib_debug", "calc_debug" and "user_debug":
|
The "calc_debug" is intended for controlling internal calc routines
|
||||||
higher absolute values result in more detailed debugging and
|
that test its operation, or collect or display information that
|
||||||
more verbose debug messages. The default value is 0 in which
|
might be useful for debug purposes. Much of the output from these
|
||||||
a very amount of debugging will be performed with nil messages.
|
will make sense only to calc wizards. Zero value (the default for
|
||||||
The -1 value is reserved for no debugging or messages. Any
|
both oldstd and newstd) of config("lib_calc") corresponds to switching
|
||||||
value <-1 will perform debugging silently (presumably collecting
|
off all these routines. For nonzero value, particular bits
|
||||||
data to be displayed at a later time). Values >0 result in a
|
currently have the following meanings:
|
||||||
greater degree of debugging and more verbose messages.
|
|
||||||
|
|
||||||
The "lib_debug" is reserved by convention for calc library scripts.
|
n Meaning of bit n of config("calc_debug")
|
||||||
This config parameter takes the place of the lib_debug global variable.
|
|
||||||
By convention, "lib_debug" has the following meanings:
|
|
||||||
|
|
||||||
<-1 no debug messages are printed though some internal
|
0 outputs shell commands prior to execution
|
||||||
debug actions and information may be collected
|
|
||||||
|
|
||||||
-1 no debug messages are printed, no debug actions will be taken
|
1 outputs currently active functions when a quit instruction
|
||||||
|
is executed
|
||||||
|
|
||||||
0 only usage message regarding each important object are
|
2 some details of shs, shs1 and md5 hash states are included
|
||||||
printed at the time of the read (default)
|
in the output when these are printed
|
||||||
|
|
||||||
>0 messages regarding each important object are
|
3 when a function constructs a block value, tests are
|
||||||
printed at the time of the read in addition
|
made that the result has the properties required for use of
|
||||||
to other debug messages
|
that block, e.g. that the pointer to the start of the
|
||||||
|
block is not NULL, and that its "length" is not negative.
|
||||||
|
A failure will result in a runtime error.
|
||||||
|
|
||||||
The "calc_debug" is reserved by convention for internal calc routines.
|
4 Report on changes to the state of stdin as well as changes
|
||||||
The output of "calc_debug" will change from release to release.
|
to internal variables that control the setting and restoring
|
||||||
Generally this value is used by calc wizards and by the regress.cal
|
of stdin.
|
||||||
routine (make check). By convention, "calc_debug" has the following
|
|
||||||
meanings:
|
|
||||||
|
|
||||||
<-1 reserved for future use
|
5 Report on changes to the run state of calc.
|
||||||
|
|
||||||
-1 no debug messages are printed, no debug actions will be taken
|
Bits >= 6 are reserved for future use and should not be used at this time.
|
||||||
|
|
||||||
0 very little, if any debugging is performed (and then mostly
|
By default, "calc_debug" is 0. The initial value may be overridden
|
||||||
in alpha test code). The only output is as a result of
|
by the -D command line option.
|
||||||
internal fatal errors (typically either math_error() or
|
|
||||||
exit() will be called). (default)
|
|
||||||
|
|
||||||
>0 a greater degree of debugging is performed and more
|
The "lib_debug" parameter is intended for controlling the possible
|
||||||
verbose messages are printed (regress.cal uses 1).
|
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").
|
||||||
No calc code or shipped library will change this value other than
|
No calc code or shipped library should change this value. Users
|
||||||
during startup or during a config("all", xyz) call.
|
should feel free to use it in any way. In particular they may
|
||||||
|
use particular bits for special purposes as with "calc_debug", or
|
||||||
|
they may use it to indicate a debug level with larger values
|
||||||
|
indicating more stringent and more informative tests with presumably
|
||||||
|
slower operation or more memory usage, and a particular value (like
|
||||||
|
-1 or 0) corresponding to "no tests".
|
||||||
|
|
||||||
The following is suggested as a convention for use of "user_debug".
|
By default, "user_debug" is 0. The initial value may be overridden
|
||||||
These are only suggestions: feel free to use it as you like:
|
by the -D command line option.
|
||||||
|
|
||||||
<-1 no debug messages are printed though some internal
|
The "verbose_quit" controls the print of the message:
|
||||||
debug actions and information may be collected
|
|
||||||
|
|
||||||
-1 no debug messages are printed, no debug actions will be taken
|
Quit or abort executed
|
||||||
|
|
||||||
0 very little, if any debugging is performed. The only output
|
when a non-interactive quit or abort without an argument is encounted.
|
||||||
are from fatal errors. (default)
|
A quit of abort without an argument does not display a message when
|
||||||
|
invoked at the interactive level.
|
||||||
>0 a greater degree of debugging is performed and more
|
|
||||||
verbose messages are printed
|
|
||||||
|
|
||||||
The following are synonyms for true:
|
The following are synonyms for true:
|
||||||
|
|
||||||
|
47
help/contrib
47
help/contrib
@@ -5,30 +5,27 @@ We welcome and encourage you to send us:
|
|||||||
* custom functions that you have modified or written
|
* custom functions that you have modified or written
|
||||||
* any other source code modifications
|
* any other source code modifications
|
||||||
|
|
||||||
Prior to doing so, you should consider trying your changes on the most
|
Prior to doing so, you should consider applying your changes to the most
|
||||||
recent alpha test code. To obtain the most recent code, look under
|
recent version of calc.
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc/
|
Landon Noll maintains the official calc home page at:
|
||||||
|
|
||||||
You should also consider joining the calc testing group by sending a
|
http://reality.sgi.com/chongo/tech/comp/calc/
|
||||||
request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
See:
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
http://reality.sgi.com/chongo/tech/comp/calc/calc-download.html
|
||||||
|
|
||||||
subscribe calc-tester address
|
for information on how to obtain up a recent version of calc.
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
=-=
|
||||||
is your full name.
|
|
||||||
|
|
||||||
In order to consider integrating your code, we need:
|
In order to consider integrating your code, we need:
|
||||||
|
|
||||||
* help files (documentation)
|
* the calc version you are working with (use the latest calc, see above)
|
||||||
* CHANGES text (brief description of what it does)
|
* new help files or help file patches, if applicable (documentation)
|
||||||
* regress.cal test (to test non-custom code)
|
* proposed text for the CHANGES file (brief description of what it does)
|
||||||
|
* regress.cal test patch, if applicable
|
||||||
* your source code and/or source code changes (:-))
|
* your source code and/or source code changes (:-))
|
||||||
|
|
||||||
The best way to send us new code, if your changes are small, is
|
The best way to send us new code, if your changes are small, is
|
||||||
@@ -45,4 +42,22 @@ Thanks for considering submitting code to calc. Calc is a collective
|
|||||||
work by a number of people. It would not be what it is today without
|
work by a number of people. It would not be what it is today without
|
||||||
your efforts and submissions!
|
your efforts and submissions!
|
||||||
|
|
||||||
Landon Curt Noll <chongo@toad.com> /\oo/\
|
=-=
|
||||||
|
|
||||||
|
One may join the calc testing group by sending a request to:
|
||||||
|
|
||||||
|
calc-tester-request@postofc.corp.sgi.com
|
||||||
|
|
||||||
|
Your message body (not the subject) should consist of:
|
||||||
|
|
||||||
|
subscribe calc-tester address
|
||||||
|
end
|
||||||
|
name your_full_name
|
||||||
|
|
||||||
|
where "address" is your EMail address and "your_full_name"
|
||||||
|
is your full name.
|
||||||
|
|
||||||
|
Landon Curt Noll
|
||||||
|
http://reality.sgi.com/chongo/
|
||||||
|
|
||||||
|
chongo <was here> /\../\
|
||||||
|
39
help/credit
39
help/credit
@@ -22,41 +22,10 @@ Credits
|
|||||||
|
|
||||||
Most of this source and binary has one of the following copyrights:
|
Most of this source and binary has one of the following copyrights:
|
||||||
|
|
||||||
Copyright (c) 19xx David I. Bell
|
Copyright (c) year David I. Bell
|
||||||
Copyright (c) 19xx David I. Bell and Landon Curt Noll
|
Copyright (c) year David I. Bell and Landon Curt Noll
|
||||||
Copyright (c) 19xx Landon Curt Noll
|
Copyright (c) year Landon Curt Noll
|
||||||
Copyright (c) 19xx Ernest Bowen and Landon Curt Noll
|
Copyright (c) year Ernest Bowen and Landon Curt Noll
|
||||||
|
|
||||||
Permission is granted to use, distribute, or modify this source,
|
Permission is granted to use, distribute, or modify this source,
|
||||||
provided that this copyright notice remains intact.
|
provided that this copyright notice remains intact.
|
||||||
|
|
||||||
Send calc comments, suggestions, bug fixes, enhancements and
|
|
||||||
interesting calc scripts that you would like you see included in
|
|
||||||
future distributions to:
|
|
||||||
|
|
||||||
dbell@auug.org.au
|
|
||||||
chongo@toad.com
|
|
||||||
|
|
||||||
Landon Noll maintains the official calc ftp archive at:
|
|
||||||
|
|
||||||
ftp://ftp.uu.net/pub/calc
|
|
||||||
|
|
||||||
Alpha test versions, complete with bugs, untested code and
|
|
||||||
experimental features may be fetched (if you are brave) under:
|
|
||||||
|
|
||||||
http://reality.sgi.com/chongo/calc/
|
|
||||||
|
|
||||||
One may join the calc testing group by sending a request to:
|
|
||||||
|
|
||||||
calc-tester-request@postofc.corp.sgi.com
|
|
||||||
|
|
||||||
Your message body (not the subject) should consist of:
|
|
||||||
|
|
||||||
subscribe calc-tester address
|
|
||||||
end
|
|
||||||
name your_full_name
|
|
||||||
|
|
||||||
where "address" is your EMail address and "your_full_name"
|
|
||||||
is your full name.
|
|
||||||
|
|
||||||
Enjoy!
|
|
||||||
|
@@ -8,7 +8,7 @@ Environment variables
|
|||||||
If this variable does not exist, a compiled value
|
If this variable does not exist, a compiled value
|
||||||
is used. Typically compiled in value is:
|
is used. Typically compiled in value is:
|
||||||
|
|
||||||
.:./lib:~/lib:${LIBDIR}/calc
|
.:./lib:~/lib:${LIBDIR}/calc:${LIBDIR}/custom
|
||||||
|
|
||||||
where ${LIBDIR} is usually:
|
where ${LIBDIR} is usually:
|
||||||
|
|
||||||
@@ -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,6 @@ 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/showbuiltins/main/
|
||||||
s/[ ][ ]*$//
|
s/[ ][ ]*$//
|
||||||
p
|
p
|
||||||
|
27
help/hash
27
help/hash
@@ -1,5 +1,5 @@
|
|||||||
NAME
|
NAME
|
||||||
hash - hash value
|
hash - FNV-1 hash value
|
||||||
|
|
||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
hash(x_1 [, x_2, x_3, ...])
|
hash(x_1 [, x_2, x_3, ...])
|
||||||
@@ -12,10 +12,32 @@ TYPES
|
|||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
Returns a hash value for one or more values of arbitrary types.
|
Returns a hash value for one or more values of arbitrary types.
|
||||||
|
|
||||||
|
The basis of this hash algorithm was taken from an idea sent
|
||||||
|
as reviewer comments to the IEEE POSIX P1003.2 committee by:
|
||||||
|
|
||||||
|
Phong Vo (http://www.research.att.com/info/kpv/)
|
||||||
|
Glenn Fowler (http://www.research.att.com/~gsf/)
|
||||||
|
|
||||||
|
In a subsequent ballot round:
|
||||||
|
|
||||||
|
Landon Curt Noll (http://reality.sgi.com/chongo/)
|
||||||
|
|
||||||
|
improved on their algorithm. Some people tried this hash
|
||||||
|
and found that it worked rather well. In an EMail message
|
||||||
|
to Landon, they named it ``Fowler/Noll/Vo'' or the FNV hash.
|
||||||
|
|
||||||
|
FNV hashes are architected to be fast while maintaining a low
|
||||||
|
collision rate. The FNV speed allows one to quickly hash lots
|
||||||
|
of data while maintaining a reasonable collision rate. See:
|
||||||
|
|
||||||
|
http://reality.sgi.com/chongo/tech/comp/fnv/
|
||||||
|
|
||||||
|
for more details as well as other forms of the FNV hash.
|
||||||
|
|
||||||
EXAMPLE
|
EXAMPLE
|
||||||
> a = isqrt(2e1000); s = "xyz";
|
> a = isqrt(2e1000); s = "xyz";
|
||||||
> hash(a,s)
|
> hash(a,s)
|
||||||
870000771
|
2378490456
|
||||||
|
|
||||||
LIMITS
|
LIMITS
|
||||||
The number of arguments is not to exceed 100.
|
The number of arguments is not to exceed 100.
|
||||||
@@ -24,3 +46,4 @@ LIBRARY
|
|||||||
none
|
none
|
||||||
|
|
||||||
SEE ALSO
|
SEE ALSO
|
||||||
|
sha, sha1, md5
|
||||||
|
@@ -42,7 +42,8 @@ following topics:
|
|||||||
changes recent changes to calc
|
changes recent changes to calc
|
||||||
contrib how to contribute scripts, code or custom functions
|
contrib how to contribute scripts, code or custom functions
|
||||||
credit who wrote calc and who helped
|
credit who wrote calc and who helped
|
||||||
todo needed enhancements and wish list
|
todo list of priority action items for calc
|
||||||
|
wishlist wish list of future enhancements of calc
|
||||||
|
|
||||||
full all of the above (in the above order)
|
full all of the above (in the above order)
|
||||||
|
|
||||||
|
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
|
@@ -44,7 +44,7 @@
|
|||||||
|
|
||||||
for and overview of the help system. The command:
|
for and overview of the help system. The command:
|
||||||
|
|
||||||
help builtins
|
help builtin
|
||||||
|
|
||||||
provides information on built-in mathematical functions, whereas:
|
provides information on built-in mathematical functions, whereas:
|
||||||
|
|
||||||
@@ -67,6 +67,14 @@
|
|||||||
It contains information about differences between C and calc
|
It contains information about differences between C and calc
|
||||||
that may surprize you.
|
that may surprize you.
|
||||||
|
|
||||||
|
To learn about calc library files that are shipped with calc, try:
|
||||||
|
|
||||||
|
help stdlib
|
||||||
|
|
||||||
|
To learn how to invoke the calc command and about calc -flags, try:
|
||||||
|
|
||||||
|
help usage
|
||||||
|
|
||||||
A full and extensive overview of calc may be obtained by:
|
A full and extensive overview of calc may be obtained by:
|
||||||
|
|
||||||
help full
|
help full
|
||||||
@@ -156,5 +164,3 @@
|
|||||||
These can contain both functions to be defined, and expressions
|
These can contain both functions to be defined, and expressions
|
||||||
to be calculated. Global variables which are numbers can be
|
to be calculated. Global variables which are numbers can be
|
||||||
saved to a file by using the 'write filename' command.
|
saved to a file by using the 'write filename' command.
|
||||||
|
|
||||||
XXX - update this file and add in new major features
|
|
||||||
|
@@ -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
|
||||||
|
117
help/statement
117
help/statement
@@ -10,28 +10,38 @@ Statements
|
|||||||
expressions are optional and may be omitted (as in RETURN).
|
expressions are optional and may be omitted (as in RETURN).
|
||||||
|
|
||||||
|
|
||||||
NOTE: Calc commands are in lower case. UPPER case is used below
|
C-like statements
|
||||||
for emphasis only, and should be considered in lower case.
|
-----------------
|
||||||
|
{ statement }
|
||||||
|
{ statement; ... statement }
|
||||||
IF (expr) statement
|
if (expr) statement
|
||||||
IF (expr) statement ELSE statement
|
if (expr) statement ELSE statement
|
||||||
FOR (optionalexpr ; optionalexpr ; optionalexpr) statement
|
for (optionalexpr ; optionalexpr ; optionalexpr) statement
|
||||||
WHILE (expr) statement
|
while (expr) statement
|
||||||
DO statement WHILE (expr)
|
do statement while (expr)
|
||||||
CONTINUE
|
continue
|
||||||
BREAK
|
break
|
||||||
GOTO label
|
goto label
|
||||||
These all work like in normal C.
|
These all work like in normal C.
|
||||||
|
|
||||||
RETURN optionalexpr
|
See 'help expression' for details on expressions.
|
||||||
|
See 'help builtin' for details on calc builtin functions.
|
||||||
|
|
||||||
|
|
||||||
|
return
|
||||||
|
------
|
||||||
|
return optionalexpr
|
||||||
|
return ( optionalexpr )
|
||||||
This returns a value from a function. Functions always
|
This returns a value from a function. Functions always
|
||||||
have a return value, even if this statement is not used.
|
have a return value, even if this statement is not used.
|
||||||
If no return statement is executed, or if no expression
|
If no return statement is executed, or if no expression
|
||||||
is specified in the return statement, then the return
|
is specified in the return statement, then the return
|
||||||
value from the function is the null type.
|
value from the function is the null type.
|
||||||
|
|
||||||
SWITCH (expr) { caseclauses }
|
|
||||||
|
switch
|
||||||
|
------
|
||||||
|
switch (expr) { caseclauses }
|
||||||
Switch statements work similarly to C, except for the
|
Switch statements work similarly to C, except for the
|
||||||
following. A switch can be done on any type of value,
|
following. A switch can be done on any type of value,
|
||||||
and the case statements can be of any type of values.
|
and the case statements can be of any type of values.
|
||||||
@@ -42,17 +52,12 @@ Statements
|
|||||||
is the exception, and only matches once all other cases
|
is the exception, and only matches once all other cases
|
||||||
have been tested.
|
have been tested.
|
||||||
|
|
||||||
{ statements }
|
|
||||||
This is a normal list of statements, each one ended by
|
|
||||||
a semicolon. Unlike the C language, no declarations are
|
|
||||||
permitted within an inner-level compound statement.
|
|
||||||
Declarations are only permitted at the beginning of a
|
|
||||||
function definition, or at the beginning of an expression
|
|
||||||
sequence.
|
|
||||||
|
|
||||||
MAT variable [dimension] [dimension] ...
|
matrix
|
||||||
MAT variable [dimension, dimension, ...]
|
------
|
||||||
MAT variable [] = { value, ... }
|
mat variable [dimension] [dimension] ...
|
||||||
|
mat variable [dimension, dimension, ...]
|
||||||
|
mat variable [] = { value, ... }
|
||||||
This creates a matrix variable with the specified dimensions.
|
This creates a matrix variable with the specified dimensions.
|
||||||
Matrices can have from 1 to 4 dimensions. When specifying
|
Matrices can have from 1 to 4 dimensions. When specifying
|
||||||
multiple dimensions, you can use either the standard C syntax,
|
multiple dimensions, you can use either the standard C syntax,
|
||||||
@@ -119,8 +124,11 @@ Statements
|
|||||||
local mat temp[5];
|
local mat temp[5];
|
||||||
static mat strtable[] = {"hi", "there", "folks");
|
static mat strtable[] = {"hi", "there", "folks");
|
||||||
|
|
||||||
OBJ type { elementnames } optionalvariables
|
|
||||||
OBJ type variable
|
object
|
||||||
|
------
|
||||||
|
obj type { elementnames } optionalvariables
|
||||||
|
obj type variable
|
||||||
These create a new object type, or create one or more
|
These create a new object type, or create one or more
|
||||||
variables of the specified type. For this calculator,
|
variables of the specified type. For this calculator,
|
||||||
an object is just a structure which is implicitly acted
|
an object is just a structure which is implicitly acted
|
||||||
@@ -183,33 +191,12 @@ Statements
|
|||||||
static obj point temp2 = {4, 3};
|
static obj point temp2 = {4, 3};
|
||||||
global obj point p1, p2, p3;
|
global obj point p1, p2, p3;
|
||||||
|
|
||||||
EXIT string
|
|
||||||
QUIT string
|
|
||||||
This command is used in two cases. At the top command
|
|
||||||
line level, quit will exit from the calculator. This
|
|
||||||
is the normal way to leave the calculator. In any other
|
|
||||||
use, quit will abort the current calculation as if an
|
|
||||||
error had occurred. If a string is given, then the string
|
|
||||||
is printed as the reason for quitting, otherwise a general
|
|
||||||
quit message is printed. The routine name and line number
|
|
||||||
which executed the quit is also printed in either case.
|
|
||||||
|
|
||||||
Quit is useful when a routine detects invalid arguments,
|
print expressions
|
||||||
in order to stop a calculation cleanly. For example,
|
-----------------
|
||||||
for a square root routine, an error can be given if the
|
print expr
|
||||||
supplied parameter was a negative number, as in:
|
print expr, ... expr
|
||||||
|
print expr: ... expr
|
||||||
define mysqrt(n)
|
|
||||||
{
|
|
||||||
if (n < 0)
|
|
||||||
quit "Negative argument";
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
Exit is an alias for quit.
|
|
||||||
|
|
||||||
|
|
||||||
PRINT exprs
|
|
||||||
For interactive expression evaluation, the values of all
|
For interactive expression evaluation, the values of all
|
||||||
typed-in expressions are automatically displayed to the
|
typed-in expressions are automatically displayed to the
|
||||||
user. However, within a function or loop, the printing of
|
user. However, within a function or loop, the printing of
|
||||||
@@ -228,8 +215,8 @@ Statements
|
|||||||
expression unless the statement ends with a colon. As
|
expression unless the statement ends with a colon. As
|
||||||
examples:
|
examples:
|
||||||
|
|
||||||
print 3, 4; prints "3 4" and newline.
|
print 3, 4; prints "3 4" and newline.
|
||||||
print 5:; prints "5" with no newline.
|
print 5:; prints "5" with no newline.
|
||||||
print 'a' : 'b' , 'c'; prints "ab c" and newline.
|
print 'a' : 'b' , 'c'; prints "ab c" and newline.
|
||||||
print; prints a newline.
|
print; prints a newline.
|
||||||
|
|
||||||
@@ -247,25 +234,9 @@ Statements
|
|||||||
prints the name of the file that was opened.
|
prints the name of the file that was opened.
|
||||||
|
|
||||||
|
|
||||||
SHOW item
|
|
||||||
This command displays some information.
|
|
||||||
|
|
||||||
builtin built in functions
|
|
||||||
global global variables
|
|
||||||
function user-defined functions
|
|
||||||
objfunc possible object functions
|
|
||||||
config config parameters and values
|
|
||||||
objtype defined objects
|
|
||||||
|
|
||||||
Only the first 4 characters of item are examined, so:
|
|
||||||
|
|
||||||
show globals
|
|
||||||
show global
|
|
||||||
show glob
|
|
||||||
|
|
||||||
do the same thing.
|
|
||||||
|
|
||||||
|
|
||||||
Also see the help topic:
|
Also see the help topic:
|
||||||
|
|
||||||
command top level commands
|
command top level commands
|
||||||
|
expression calc expression syntax
|
||||||
|
builtin calc builtin functions
|
||||||
|
usage how to invoke the calc command and calc -options
|
||||||
|
260
help/todo
260
help/todo
@@ -1,183 +1,96 @@
|
|||||||
Needed enhancements
|
Calc Todo Items:
|
||||||
|
|
||||||
Send calc comments, suggestions, bug fixes, enhancements and
|
The following items should be addressed sometime in the short to
|
||||||
interesting calc scripts that you would like you see included in
|
medium term future, if not before the next release.
|
||||||
future distributions to:
|
|
||||||
|
|
||||||
dbell@auug.org.au
|
Code contributions are welcome. Send patches to:
|
||||||
chongo@toad.com
|
|
||||||
|
|
||||||
The following items are in the calc wish list. Programs like this
|
calc-tester@postofc.corp.sgi.com
|
||||||
can be extended and improved forever.
|
|
||||||
|
|
||||||
* In general use faster algorithms for large numbers when they
|
See also the 'wishlist' help files for the calc enhancement wish list.
|
||||||
become known. In particular, look at better algorithms for
|
|
||||||
very large numbers -- multiply, square and mod in particular.
|
|
||||||
|
|
||||||
* Implement an autoload feature. Associate a calc library filename
|
=-=
|
||||||
with a function or global variable. On the first reference of
|
|
||||||
such item, perform an automatic load of that file.
|
|
||||||
|
|
||||||
* Add error handling statements, so that QUITs, errors from the
|
Very High priority items:
|
||||||
'eval' function, division by zeroes, and so on can be caught.
|
|
||||||
This should be done using syntax similar to:
|
|
||||||
|
|
||||||
ONERROR statement DO statement;
|
* Write the help file for the display() builtin function.
|
||||||
|
|
||||||
Something like signal isn't versatile enough.
|
* Write the help file for the stoponerror() builtin function.
|
||||||
|
|
||||||
* Add a debugging capability so that functions can be single stepped,
|
* Update the errmax about the meaning of errmax(-1).
|
||||||
breakpoints inserted, variables displayed, and so on.
|
|
||||||
|
|
||||||
* Figure out how to write all variables out to a file, including
|
* Review and if needed, correct/update the help topics:
|
||||||
deeply nested arrays, lists, and objects.
|
|
||||||
|
|
||||||
Add the ability to read and write a value in some binary form.
|
topic description
|
||||||
Clearly this is easy for non-neg integers. The question of
|
----- -----------
|
||||||
everything else is worth pondering.
|
intro introduction to calc
|
||||||
|
overview overview of calc
|
||||||
|
assoc using associations
|
||||||
|
command top level commands
|
||||||
|
config configuration parameters
|
||||||
|
define how to define functions
|
||||||
|
environment how environment variables effect calc
|
||||||
|
errorcodes calc generated error codes
|
||||||
|
expression expression sequences
|
||||||
|
file using files
|
||||||
|
history command history
|
||||||
|
interrupt how interrupts are handled
|
||||||
|
list using lists
|
||||||
|
mat using matrices
|
||||||
|
obj user defined data types
|
||||||
|
operator math, relational, logic and variable access ...
|
||||||
|
statement flow control and declaration statements
|
||||||
|
types builtin data types
|
||||||
|
unexpected unexpected syntax/usage surprises for C ...
|
||||||
|
variable variables and variable declarations
|
||||||
|
libcalc using the arbitrary precision routines in ...
|
||||||
|
bugs known bugs and mis-features
|
||||||
|
wishlist wish list of future enhancements of calc
|
||||||
|
|
||||||
* Eliminate the need for the define keyword by doing smarter parsing.
|
* Fix any 'Known bugs' as noted in the BUGS file or as
|
||||||
|
displayed by 'calc help bugs'.
|
||||||
|
|
||||||
* Allow results of a command (or all commands) to be re-directed to a
|
=-=
|
||||||
file or piped into a command.
|
|
||||||
|
|
||||||
* Add some kind of #include and #define facility. Perhaps use
|
High priority items:
|
||||||
the C pre-processor itself?
|
|
||||||
|
|
||||||
* Support a more general input and output base mode other than
|
* Verify, complete or fix the 'SEE ALSO' help file sections.
|
||||||
just dec, hex or octal.
|
|
||||||
|
|
||||||
* Implement a form of symbolic algebra. Work on this has already
|
* Verify, complete or fix the 'LIBRARY' help file sections.
|
||||||
begun. This will use backquotes to define expressions, and new
|
|
||||||
functions will be able to act on expressions. For example:
|
|
||||||
|
|
||||||
x = `hello * strlen(mom)`;
|
* Verify, complete or fix the 'LIMITS' help file sections.
|
||||||
x = sub(x, `hello`, `hello + 1`);
|
|
||||||
x = sub(x, `hello`, 10, `mom`, "curds");
|
|
||||||
eval(x);
|
|
||||||
|
|
||||||
prints 55.
|
* Verify, complete or fix the 'SYNOPSIS' and 'TYPES' help file sections.
|
||||||
|
|
||||||
* Place the results of previous commands into a parallel history list.
|
* Where reasonable, be sure that regress.cal tests builtin functions.
|
||||||
Add a binding that returns the saved result of the command so
|
|
||||||
that one does not need to re-execute a previous command simply
|
|
||||||
to obtain its value.
|
|
||||||
|
|
||||||
If you have a command that takes a very long time to execute,
|
* Perform a code coverage analysis of the 'make check' action
|
||||||
it would be nice if you could get at its result without having
|
and improve the coverage (within reason) of the regress.cal suite.
|
||||||
to spend the time to reexecute it.
|
|
||||||
|
|
||||||
* Add a binding to delete a value from the history list.
|
* Create a Linux rpm (Red Hat Package Manager) package for calc.
|
||||||
|
|
||||||
One may need to remove a large value from the history list if
|
* Address, if possible and reasonable, any Calc Mis-features
|
||||||
it is very large. Deleting the value would replace the history
|
as noted in the BUGS file or as displayed by 'calc help bugs'.
|
||||||
entry with a null value.
|
|
||||||
|
|
||||||
* Add a binding to delete a command from the history list.
|
* The shell script that is currently constructed to display a help
|
||||||
|
file (in help.c) is a gross hack. That code should be replaced
|
||||||
|
with code that looks for the help file in the pre-defined help
|
||||||
|
directories. When the specific help file is found and opened,
|
||||||
|
then a $PAGER should be forked and execed after doing things such
|
||||||
|
as closing open file descriptors that the $PAGER does not need.
|
||||||
|
|
||||||
Since you can delete values, you might as well be able to
|
* Inspect changes made since the last major calc release (the
|
||||||
delete commands.
|
initial x.y.z version ... prior to any t sub-version) to help
|
||||||
|
ensure that they have not introduced new or re-introduced old bugs
|
||||||
|
into calc.
|
||||||
|
|
||||||
* All one to alter the size of the history list thru config().
|
* Consider using configure to build the calc Makefile.
|
||||||
|
|
||||||
In some cases, 256 values is too small, in others it is too large.
|
=-=
|
||||||
|
|
||||||
* Add a builtin that returns a value from the history list.
|
Medium priority items:
|
||||||
As an example:
|
|
||||||
|
|
||||||
histval(-10)
|
* Complete the use of CONST where appropriate:
|
||||||
|
|
||||||
returns the 10th value on the history value list, if such
|
|
||||||
a value is in the history list (null otherwise). And:
|
|
||||||
|
|
||||||
histval(23)
|
|
||||||
|
|
||||||
return the value of the 23rd command given to calc, if
|
|
||||||
such a value is in the history list (null otherwise).
|
|
||||||
|
|
||||||
It would be very helpful to use the history values in
|
|
||||||
subsequent equations.
|
|
||||||
|
|
||||||
* Add a builtin that returns command as a string from the
|
|
||||||
history list. As an example:
|
|
||||||
|
|
||||||
history(-10)
|
|
||||||
|
|
||||||
returns a string containing the 10th command on the
|
|
||||||
history list, if a such a value is in the history list
|
|
||||||
(empty string otherwise). And:
|
|
||||||
|
|
||||||
history(23)
|
|
||||||
|
|
||||||
return the string containing the 23rd command given to calc, if
|
|
||||||
such a value is in the history list (empty string otherwise).
|
|
||||||
|
|
||||||
One could use the eval() function to re-evaluate the command.
|
|
||||||
|
|
||||||
* Allow one to optionally restore the command number to calc
|
|
||||||
prompts. When going back in the history list, indicate the
|
|
||||||
command number that is being examined.
|
|
||||||
|
|
||||||
The command number was a useful item. When one is scanning the
|
|
||||||
history list, knowing where you are is hard without it. It can
|
|
||||||
get confusing when the history list wraps or when you use
|
|
||||||
search bindings. Command numbers would be useful in
|
|
||||||
conjunction with positive args for the history() and histval()
|
|
||||||
functions as suggested above.
|
|
||||||
|
|
||||||
* Add a builtin that returns the current command number.
|
|
||||||
For example:
|
|
||||||
|
|
||||||
cmdnum()
|
|
||||||
|
|
||||||
returns the current command number.
|
|
||||||
|
|
||||||
This would allow one to tag a value in the history list. One
|
|
||||||
could save the result of cmdnum() in a variable and later use
|
|
||||||
it as an arg to the histval() or history() functions.
|
|
||||||
|
|
||||||
* Add a factoring builtin functions. Provide functions that perform
|
|
||||||
multiple polynomial quadratic sieves, elliptic curve, difference
|
|
||||||
of two squares, N-1 factoring as so on. Provide a easy general
|
|
||||||
factoring builtin (say factor(foo)) that would attempt to apply
|
|
||||||
whatever process was needed based on the value.
|
|
||||||
|
|
||||||
Factoring builtins would return a matrix of factors.
|
|
||||||
|
|
||||||
It would be handy to configure, via config(), the maximum time
|
|
||||||
that one should try to factor a number. By default the time
|
|
||||||
should be infinite. If one set the time limit to a finite
|
|
||||||
value and the time limit was exceeded, the factoring builtin
|
|
||||||
would return whatever if had found thus far, even if no new
|
|
||||||
factors had been found.
|
|
||||||
|
|
||||||
Another factoring configuration interface, via config(), that
|
|
||||||
is needed would be to direct the factoring builtins to return
|
|
||||||
as soon as a factor was found.
|
|
||||||
|
|
||||||
* Allow one to config calc break up long output lines.
|
|
||||||
|
|
||||||
The command: calc '2^100000' will produce one very long
|
|
||||||
line. Many times this is reasonable. Long output lines
|
|
||||||
are a problem for some utilities. It would be nice if one
|
|
||||||
could configure, via config(), calc to fold long lines.
|
|
||||||
|
|
||||||
By default, calc should continue to produce long lines.
|
|
||||||
|
|
||||||
One option to config should be to specify the length to
|
|
||||||
fold output. Another option should be to append a trailing
|
|
||||||
\ on folded lines (as some symbolic packages use).
|
|
||||||
|
|
||||||
* Allow one to use the READ and WRITE commands inside a function.
|
|
||||||
|
|
||||||
* Remove or increase limits on factor(), lfactor(), isprime(),
|
|
||||||
nextprime(), and prevprime(). Currently these functions cannot
|
|
||||||
search for factors > 2^32.
|
|
||||||
|
|
||||||
* Add read -once -try "filename" which would do nothing
|
|
||||||
if "filename" was not a readable file.
|
|
||||||
|
|
||||||
* Complete the use of CONST where appropirate:
|
|
||||||
|
|
||||||
CONST is beginning to be used with read-only tables and some
|
CONST is beginning to be used with read-only tables and some
|
||||||
function arguments. This allows certain compilers to better
|
function arguments. This allows certain compilers to better
|
||||||
@@ -196,48 +109,13 @@ Needed enhancements
|
|||||||
at by 'fizbin' and the HALF array pointer at by 'data' should be
|
at by 'fizbin' and the HALF array pointer at by 'data' should be
|
||||||
treated as read-only.
|
treated as read-only.
|
||||||
|
|
||||||
* Blocks should have the following features:
|
|
||||||
|
|
||||||
+ read/write to/from files (ala fread/fwrite)
|
|
||||||
|
|
||||||
+ misc memory functions (ala memcpy, memcmp, memset,
|
|
||||||
memchr, etc.)
|
|
||||||
|
|
||||||
+ scatter and gather functions (to send every n-th octet
|
|
||||||
to another block and to copy from n blocks, the 1st
|
|
||||||
then 2nd then 3rd ... octets)
|
|
||||||
|
|
||||||
* Printing of blocks should be under the control of the
|
|
||||||
config() interface. This should allow one to select
|
|
||||||
from any of the following formats:
|
|
||||||
|
|
||||||
+ as one long string
|
|
||||||
|
|
||||||
+ as a series of lines (< 80 chars wide)
|
|
||||||
|
|
||||||
+ in od command style (offset: value value value ...)
|
|
||||||
|
|
||||||
+ in hex dump style (offset: val val val val ... 3hf.Uas.c)
|
|
||||||
|
|
||||||
* In addition one should be able to control the following
|
|
||||||
aspects of printing blocks via the config() interface:
|
|
||||||
|
|
||||||
+ base (hex, octal, char, base 2)
|
|
||||||
|
|
||||||
+ amount of data (the first n octets or the entire block)
|
|
||||||
|
|
||||||
+ skipping printing of duplicate print lines (ala od)
|
|
||||||
|
|
||||||
+ have the ability to print the block as raw data
|
|
||||||
|
|
||||||
* It is overkill to have nearly everything wind up in libcalc.a.
|
* It is overkill to have nearly everything wind up in libcalc.a.
|
||||||
|
|
||||||
One should make available a the fundimental math operations
|
One should make available a the fundamental math operations
|
||||||
on ZVALUE, NUMBER and perhaps COMPLEX (without all of the
|
on ZVALUE, NUMBER and perhaps COMPLEX (without all of the
|
||||||
other stuff) in a separate library.
|
other stuff) in a separate library.
|
||||||
|
|
||||||
* improve the coverage in the 'SEE ALSO' help file lists
|
* Clean the source code and document it better.
|
||||||
|
|
||||||
* where reasonable, be sure that regress.cal tests builtin functions
|
* Add a builtin function to access the 64 bit FNV hash which
|
||||||
|
is currently being used internally in seed.c.
|
||||||
* clean the source code and document it better
|
|
||||||
|
99
help/usage
99
help/usage
@@ -2,7 +2,26 @@ Calc command line
|
|||||||
|
|
||||||
Calc has the following command line:
|
Calc has the following command line:
|
||||||
|
|
||||||
calc [-C] [-e] [-h] [-i] [-m mode] [-n] [-p] [-q] [-u] [calc_cmd ...]
|
calc [-c] [-C] [-d] [-D calc_debug[:lib_debug:[user_debug]]]
|
||||||
|
[-e] [-h] [-i] [-m mode] [-n] [-p] [-q] [-u] [-v] [calc_cmd ...]
|
||||||
|
|
||||||
|
-c Continue reading command lines even after an execution
|
||||||
|
error has caused the abandonment of a line.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc read many_errors.cal
|
||||||
|
|
||||||
|
will cause calc to abort on the first error, whereas:
|
||||||
|
|
||||||
|
calc -c read many_errors.cal
|
||||||
|
|
||||||
|
will cause calc to try to process each line being read
|
||||||
|
despite the errors that it encounters.
|
||||||
|
|
||||||
|
By default, calc startup scripts ($CALCRC) are silently
|
||||||
|
ignored if not found. This flag will report missing
|
||||||
|
startup scripts unless -d is also given.
|
||||||
|
|
||||||
-C Permit the execution of custom builtin functions. Without
|
-C Permit the execution of custom builtin functions. Without
|
||||||
this flag, calling the custom() builtin function will
|
this flag, calling the custom() builtin function will
|
||||||
@@ -12,6 +31,46 @@ Calc command line
|
|||||||
are non-standard and that are not portable. Custom builtin
|
are non-standard and that are not portable. Custom builtin
|
||||||
functions are disabled by default for this reason.
|
functions are disabled by default for this reason.
|
||||||
|
|
||||||
|
-d Disable the printing of the opening title. The printing
|
||||||
|
of library debug and informational messages is also disabled
|
||||||
|
as if config("lib_debug",0) had been executed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will output something like:
|
||||||
|
|
||||||
|
qtime(utc_hr_offset) defined
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
whereas:
|
||||||
|
|
||||||
|
calc -d 'read qtime; qtime(2)'
|
||||||
|
|
||||||
|
will just say:
|
||||||
|
|
||||||
|
It's nearly ten past six.
|
||||||
|
|
||||||
|
This flag disables the reporting of missing calc
|
||||||
|
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.
|
||||||
|
|
||||||
@@ -19,7 +78,21 @@ Calc command line
|
|||||||
is equivalent to the calc command help help. The help
|
is equivalent to the calc command help help. The help
|
||||||
facility is disabled unless the mode is 5 or 7. See -m.
|
facility is disabled unless the mode is 5 or 7. See -m.
|
||||||
|
|
||||||
-i Do not about if the error count exceeds maxerr().
|
-i Become interactive if possible. Be default, if calc_cmd
|
||||||
|
args are given, calc will execute them and exit. This flag
|
||||||
|
will cause calc to drop into interactive mode after the
|
||||||
|
commands are executed.
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
calc 2+5
|
||||||
|
|
||||||
|
will print the value 7 and exit whereas:
|
||||||
|
|
||||||
|
calc -i 2+5
|
||||||
|
|
||||||
|
will print the value 7 and prompt the user for more
|
||||||
|
calc commands.
|
||||||
|
|
||||||
-m mode
|
-m mode
|
||||||
This flag sets the permission mode of calc. It
|
This flag sets the permission mode of calc. It
|
||||||
@@ -38,7 +111,7 @@ Calc command line
|
|||||||
6 do not execute any program
|
6 do not execute any program
|
||||||
7 allow everything (default mode)
|
7 allow everything (default mode)
|
||||||
|
|
||||||
If one wished to run calc from a privledged user, one
|
If one wished to run calc from a privileged user, one
|
||||||
might want to use -m 0 in an effort to make calc more
|
might want to use -m 0 in an effort to make calc more
|
||||||
secure.
|
secure.
|
||||||
|
|
||||||
@@ -46,7 +119,7 @@ Calc command line
|
|||||||
open. Files already open are not effected. Thus if one
|
open. Files already open are not effected. Thus if one
|
||||||
wanted to use the -m 0 in an effort to make calc more
|
wanted to use the -m 0 in an effort to make calc more
|
||||||
secure, but still wanted to read and write a specific
|
secure, but still wanted to read and write a specific
|
||||||
file, one might want to do:
|
file, one might want to do in sh, ksh, bash-like shells:
|
||||||
|
|
||||||
calc -m 0 3<a.file
|
calc -m 0 3<a.file
|
||||||
|
|
||||||
@@ -59,25 +132,28 @@ Calc command line
|
|||||||
given. The reading of key bindings is also disabled
|
given. The reading of key bindings is also disabled
|
||||||
when the mode disables opening of files for reading.
|
when the mode disables opening of files for reading.
|
||||||
|
|
||||||
-n Use the new configutation defaults instead of the old
|
-n Use the new configuration defaults instead of the old
|
||||||
default classic defaults. This flag as the same effect
|
default classic defaults. This flag as the same effect
|
||||||
as executing config("all", "newcfg") at startup time.
|
as executing config("all", "newcfg") at startup time.
|
||||||
|
|
||||||
-p Pipe processing is enabled by use of -p. For example:
|
-p Pipe processing is enabled by use of -p. For example:
|
||||||
|
|
||||||
echo "print 2^21701-1, 2^23209-1" | calc -p | fizzbin
|
calc -p '2^21701-1' | fizzbin
|
||||||
|
|
||||||
In pipe mode, calc does not prompt, does not print
|
In pipe mode, calc does not prompt, does not print leading
|
||||||
leading tabs and does not print the initial header.
|
tabs and does not print the initial header. The -p flag
|
||||||
|
overrides -i.
|
||||||
|
|
||||||
-q Disable the use of the $CALCRC startup scripts.
|
-q Disable the use of the $CALCRC startup scripts.
|
||||||
|
|
||||||
-u Disable buffering of stdin and stdout.
|
-u Disable buffering of stdin and stdout.
|
||||||
|
|
||||||
|
-v Print calc version number and exit.
|
||||||
|
|
||||||
Without `calc_cmd', calc operates interactively. If one or more
|
Without `calc_cmd', calc operates interactively. If one or more
|
||||||
`calc_cmd' are given on the command line, calc will execute them and
|
`calc_cmd' are given on the command line, calc will execute them and
|
||||||
exit. The printing of leading tabs on output is disabled as if
|
exit. If -i is given, calc will attempt to become interactive
|
||||||
config("tab",0) had been executed.
|
even of one or more `calc_cmd' are given on the command line.
|
||||||
|
|
||||||
Normally on startup, calc attempts to execute a collection of
|
Normally on startup, calc attempts to execute a collection of
|
||||||
library scripts. The environment variable $CALCRC (if non-existent
|
library scripts. The environment variable $CALCRC (if non-existent
|
||||||
@@ -98,7 +174,8 @@ Calc command line
|
|||||||
|
|
||||||
Calc treats all open files, other than stdin, stdout and
|
Calc treats all open files, other than stdin, stdout and
|
||||||
stderr as files available for reading and writing. One may
|
stderr as files available for reading and writing. One may
|
||||||
present calc with an already open file in the following way:
|
present calc with an already open file using sh, ksh or bash-like
|
||||||
|
shells is to:
|
||||||
|
|
||||||
calc 3<open_file 4<open_file2
|
calc 3<open_file 4<open_file2
|
||||||
|
|
||||||
|
181
help/wishlist
Normal file
181
help/wishlist
Normal file
@@ -0,0 +1,181 @@
|
|||||||
|
Calc Enhancement Wish List:
|
||||||
|
|
||||||
|
Send calc comments, suggestions, bug fixes, enhancements and
|
||||||
|
interesting calc scripts that you would like you see included in
|
||||||
|
future distributions to:
|
||||||
|
|
||||||
|
calc-tester@postofc.corp.sgi.com
|
||||||
|
|
||||||
|
The following items are in the calc wish list. Programs like this
|
||||||
|
can be extended and improved forever.
|
||||||
|
|
||||||
|
See the 'todo' help file for higher priority todo items.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
* In general use faster algorithms for large numbers when they
|
||||||
|
become known. In particular, look at better algorithms for
|
||||||
|
very large numbers -- multiply, square and mod in particular.
|
||||||
|
|
||||||
|
* Implement an autoload feature. Associate a calc library filename
|
||||||
|
with a function or global variable. On the first reference of
|
||||||
|
such item, perform an automatic load of that file.
|
||||||
|
|
||||||
|
* Add error handling statements, so that QUITs, errors from the
|
||||||
|
'eval' function, division by zeroes, and so on can be caught.
|
||||||
|
This should be done using syntax similar to:
|
||||||
|
|
||||||
|
ONERROR statement DO statement;
|
||||||
|
|
||||||
|
Something like signal isn't versatile enough.
|
||||||
|
|
||||||
|
* Add a debugging capability so that functions can be single stepped,
|
||||||
|
breakpoints inserted, variables displayed, and so on.
|
||||||
|
|
||||||
|
* Figure out how to write all variables out to a file, including
|
||||||
|
deeply nested arrays, lists, and objects.
|
||||||
|
|
||||||
|
Add the ability to read and write a value in some binary form.
|
||||||
|
Clearly this is easy for non-neg integers. The question of
|
||||||
|
everything else is worth pondering.
|
||||||
|
|
||||||
|
* Eliminate the need for the define keyword by doing smarter parsing.
|
||||||
|
|
||||||
|
* Allow results of a command (or all commands) to be re-directed to a
|
||||||
|
file or piped into a command.
|
||||||
|
|
||||||
|
* Add some kind of #include and #define facility. Perhaps use
|
||||||
|
the C pre-processor itself?
|
||||||
|
|
||||||
|
* Support a more general input and output base mode other than
|
||||||
|
just dec, hex or octal.
|
||||||
|
|
||||||
|
* Implement a form of symbolic algebra. Work on this has already
|
||||||
|
begun. This will use backquotes to define expressions, and new
|
||||||
|
functions will be able to act on expressions. For example:
|
||||||
|
|
||||||
|
x = `hello * strlen(mom)`;
|
||||||
|
x = sub(x, `hello`, `hello + 1`);
|
||||||
|
x = sub(x, `hello`, 10, `mom`, "curds");
|
||||||
|
eval(x);
|
||||||
|
|
||||||
|
prints 55.
|
||||||
|
|
||||||
|
* Place the results of previous commands into a parallel history list.
|
||||||
|
Add a binding that returns the saved result of the command so
|
||||||
|
that one does not need to re-execute a previous command simply
|
||||||
|
to obtain its value.
|
||||||
|
|
||||||
|
If you have a command that takes a very long time to execute,
|
||||||
|
it would be nice if you could get at its result without having
|
||||||
|
to spend the time to reexecute it.
|
||||||
|
|
||||||
|
* Add a binding to delete a value from the history list.
|
||||||
|
|
||||||
|
One may need to remove a large value from the history list if
|
||||||
|
it is very large. Deleting the value would replace the history
|
||||||
|
entry with a null value.
|
||||||
|
|
||||||
|
* Add a binding to delete a command from the history list.
|
||||||
|
|
||||||
|
Since you can delete values, you might as well be able to
|
||||||
|
delete commands.
|
||||||
|
|
||||||
|
* All one to alter the size of the history list thru config().
|
||||||
|
|
||||||
|
In some cases, 256 values is too small, in others it is too large.
|
||||||
|
|
||||||
|
* Add a builtin that returns a value from the history list.
|
||||||
|
As an example:
|
||||||
|
|
||||||
|
histval(-10)
|
||||||
|
|
||||||
|
returns the 10th value on the history value list, if such
|
||||||
|
a value is in the history list (null otherwise). And:
|
||||||
|
|
||||||
|
histval(23)
|
||||||
|
|
||||||
|
return the value of the 23rd command given to calc, if
|
||||||
|
such a value is in the history list (null otherwise).
|
||||||
|
|
||||||
|
It would be very helpful to use the history values in
|
||||||
|
subsequent equations.
|
||||||
|
|
||||||
|
* Add a builtin that returns command as a string from the
|
||||||
|
history list. As an example:
|
||||||
|
|
||||||
|
history(-10)
|
||||||
|
|
||||||
|
returns a string containing the 10th command on the
|
||||||
|
history list, if a such a value is in the history list
|
||||||
|
(empty string otherwise). And:
|
||||||
|
|
||||||
|
history(23)
|
||||||
|
|
||||||
|
return the string containing the 23rd command given to calc, if
|
||||||
|
such a value is in the history list (empty string otherwise).
|
||||||
|
|
||||||
|
One could use the eval() function to re-evaluate the command.
|
||||||
|
|
||||||
|
* Allow one to optionally restore the command number to calc
|
||||||
|
prompts. When going back in the history list, indicate the
|
||||||
|
command number that is being examined.
|
||||||
|
|
||||||
|
The command number was a useful item. When one is scanning the
|
||||||
|
history list, knowing where you are is hard without it. It can
|
||||||
|
get confusing when the history list wraps or when you use
|
||||||
|
search bindings. Command numbers would be useful in
|
||||||
|
conjunction with positive args for the history() and histval()
|
||||||
|
functions as suggested above.
|
||||||
|
|
||||||
|
* Add a builtin that returns the current command number.
|
||||||
|
For example:
|
||||||
|
|
||||||
|
cmdnum()
|
||||||
|
|
||||||
|
returns the current command number.
|
||||||
|
|
||||||
|
This would allow one to tag a value in the history list. One
|
||||||
|
could save the result of cmdnum() in a variable and later use
|
||||||
|
it as an arg to the histval() or history() functions.
|
||||||
|
|
||||||
|
* Add a factoring builtin functions. Provide functions that perform
|
||||||
|
multiple polynomial quadratic sieves, elliptic curve, difference
|
||||||
|
of two squares, N-1 factoring as so on. Provide a easy general
|
||||||
|
factoring builtin (say factor(foo)) that would attempt to apply
|
||||||
|
whatever process was needed based on the value.
|
||||||
|
|
||||||
|
Factoring builtins would return a matrix of factors.
|
||||||
|
|
||||||
|
It would be handy to configure, via config(), the maximum time
|
||||||
|
that one should try to factor a number. By default the time
|
||||||
|
should be infinite. If one set the time limit to a finite
|
||||||
|
value and the time limit was exceeded, the factoring builtin
|
||||||
|
would return whatever if had found thus far, even if no new
|
||||||
|
factors had been found.
|
||||||
|
|
||||||
|
Another factoring configuration interface, via config(), that
|
||||||
|
is needed would be to direct the factoring builtins to return
|
||||||
|
as soon as a factor was found.
|
||||||
|
|
||||||
|
* Allow one to config calc break up long output lines.
|
||||||
|
|
||||||
|
The command: calc '2^100000' will produce one very long
|
||||||
|
line. Many times this is reasonable. Long output lines
|
||||||
|
are a problem for some utilities. It would be nice if one
|
||||||
|
could configure, via config(), calc to fold long lines.
|
||||||
|
|
||||||
|
By default, calc should continue to produce long lines.
|
||||||
|
|
||||||
|
One option to config should be to specify the length to
|
||||||
|
fold output. Another option should be to append a trailing
|
||||||
|
\ on folded lines (as some symbolic packages use).
|
||||||
|
|
||||||
|
* Allow one to use the READ and WRITE commands inside a function.
|
||||||
|
|
||||||
|
* Remove or increase limits on factor(), lfactor(), isprime(),
|
||||||
|
nextprime(), and prevprime(). Currently these functions cannot
|
||||||
|
search for factors > 2^32.
|
||||||
|
|
||||||
|
* Add read -once -try "filename" which would do nothing
|
||||||
|
if "filename" was not a readable file.
|
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.
|
||||||
@@ -48,6 +50,8 @@
|
|||||||
# include <string.h>
|
# include <string.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(USE_READLINE)
|
||||||
|
|
||||||
extern FILE *curstream(void);
|
extern FILE *curstream(void);
|
||||||
|
|
||||||
#define STDIN 0
|
#define STDIN 0
|
||||||
@@ -242,7 +246,7 @@ int
|
|||||||
hist_getline(char *prompt, char *buf, int len)
|
hist_getline(char *prompt, char *buf, int len)
|
||||||
{
|
{
|
||||||
if (!inited)
|
if (!inited)
|
||||||
(void) hist_init((char *) NULL);
|
(void) hist_init(calcbindings);
|
||||||
|
|
||||||
HS.prompt = prompt;
|
HS.prompt = prompt;
|
||||||
HS.bufsize = len - 2;
|
HS.bufsize = len - 2;
|
||||||
@@ -283,11 +287,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 +318,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 +351,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 +375,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 +400,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
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -455,8 +508,9 @@ do_bind_line(KEY_MAP *map, char *line)
|
|||||||
if (*cp == '?') {
|
if (*cp == '?') {
|
||||||
key = 0177;
|
key = 0177;
|
||||||
cp++;
|
cp++;
|
||||||
} else
|
} else {
|
||||||
key = CONTROL(*cp++);
|
key = CONTROL(*cp++);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (key == '\\')
|
else if (key == '\\')
|
||||||
key = *cp++;
|
key = *cp++;
|
||||||
@@ -1383,8 +1437,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.
|
||||||
@@ -1425,6 +1583,5 @@ main(int argc, char **argv)
|
|||||||
hist_term();
|
hist_term();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
/* END CODE */
|
#endif /* HIST_TEST */
|
||||||
|
82
input.c
82
input.c
@@ -12,6 +12,12 @@
|
|||||||
#include <pwd.h>
|
#include <pwd.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
#include "have_unistd.h"
|
||||||
|
#if defined(HAVE_UNISTD_H)
|
||||||
|
#include <unistd.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "calc.h"
|
#include "calc.h"
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
#include "hist.h"
|
#include "hist.h"
|
||||||
@@ -33,8 +39,9 @@ typedef struct {
|
|||||||
int i_state; /* state (read, reread) */
|
int i_state; /* state (read, reread) */
|
||||||
int i_char; /* currently read char */
|
int i_char; /* currently read char */
|
||||||
long i_line; /* line number */
|
long i_line; /* line number */
|
||||||
char *i_str; /* current string for input (if not NULL) */
|
char *i_cp; /* pointer to string character to be read */
|
||||||
char *i_origstr; /* original string so it can be freed */
|
char *i_str; /* start of string copy to be read, or NULL */
|
||||||
|
long i_num; /* number of string characters remaining */
|
||||||
char *i_ttystr; /* current character of tty line (or NULL) */
|
char *i_ttystr; /* current character of tty line (or NULL) */
|
||||||
FILE *i_fp; /* current file for input (if not NULL) */
|
FILE *i_fp; /* current file for input (if not NULL) */
|
||||||
char *i_name; /* file name if known */
|
char *i_name; /* file name if known */
|
||||||
@@ -311,7 +318,7 @@ f_open(char *name, char *mode)
|
|||||||
*/
|
*/
|
||||||
if (!allow_read && !allow_write) {
|
if (!allow_read && !allow_write) {
|
||||||
/* no reads and no writes means no opens! */
|
/* no reads and no writes means no opens! */
|
||||||
if (start_done) {
|
if (run_state > RUN_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for read or write disallowed by -m\n");
|
"open for read or write disallowed by -m\n");
|
||||||
@@ -319,7 +326,7 @@ f_open(char *name, char *mode)
|
|||||||
return NULL;
|
return NULL;
|
||||||
} else if (!allow_read && strchr(mode, 'r') != NULL) {
|
} else if (!allow_read && strchr(mode, 'r') != NULL) {
|
||||||
/* reading new files disallowed */
|
/* reading new files disallowed */
|
||||||
if (start_done) {
|
if (run_state > RUN_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for read disallowed by -m\n");
|
"open for read disallowed by -m\n");
|
||||||
@@ -330,7 +337,7 @@ f_open(char *name, char *mode)
|
|||||||
strchr(mode, 'a') != NULL ||
|
strchr(mode, 'a') != NULL ||
|
||||||
strchr(mode, '+') != NULL)) {
|
strchr(mode, '+') != NULL)) {
|
||||||
/* writing new files disallowed */
|
/* writing new files disallowed */
|
||||||
if (start_done) {
|
if (run_state > RUN_BEGIN) {
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"open of %s mode %s - %s\n", name, mode,
|
"open of %s mode %s - %s\n", name, mode,
|
||||||
"open for write disallowed by -m\n");
|
"open for write disallowed by -m\n");
|
||||||
@@ -375,7 +382,6 @@ openfile(char *name)
|
|||||||
cip->i_state = IS_READ;
|
cip->i_state = IS_READ;
|
||||||
cip->i_char = '\0';
|
cip->i_char = '\0';
|
||||||
cip->i_str = NULL;
|
cip->i_str = NULL;
|
||||||
cip->i_origstr = NULL;
|
|
||||||
cip->i_ttystr = NULL;
|
cip->i_ttystr = NULL;
|
||||||
cip->i_fp = fp;
|
cip->i_fp = fp;
|
||||||
cip->i_line = 1;
|
cip->i_line = 1;
|
||||||
@@ -401,7 +407,7 @@ curstream(void)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Open a string for scanning. String is ended by a null character.
|
* Open a string for scanning, num characters to be read.
|
||||||
* String is copied into local memory so it can be trashed afterwards.
|
* String is copied into local memory so it can be trashed afterwards.
|
||||||
* Returns -1 if cannot open string.
|
* Returns -1 if cannot open string.
|
||||||
*
|
*
|
||||||
@@ -409,21 +415,22 @@ curstream(void)
|
|||||||
* str string to be opened
|
* str string to be opened
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
openstring(char *str)
|
openstring(char *str, long num)
|
||||||
{
|
{
|
||||||
char *cp; /* copied string */
|
char *cp; /* copied string */
|
||||||
|
|
||||||
if ((depth >= MAXDEPTH) || (str == NULL))
|
if ((depth >= MAXDEPTH) || (str == NULL))
|
||||||
return -2;
|
return -2;
|
||||||
cp = (char *)malloc(strlen(str) + 1);
|
cp = (char *) malloc(num + 1);
|
||||||
if (cp == NULL)
|
if (cp == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
strcpy(cp, str);
|
strcpy(cp, str);
|
||||||
cip = inputs + depth++;
|
cip = inputs + depth++;
|
||||||
cip->i_state = IS_READ;
|
cip->i_state = IS_READ;
|
||||||
cip->i_char = '\0';
|
cip->i_char = '\0';
|
||||||
|
cip->i_cp = cp;
|
||||||
cip->i_str = cp;
|
cip->i_str = cp;
|
||||||
cip->i_origstr = cp;
|
cip->i_num = num;
|
||||||
cip->i_fp = NULL;
|
cip->i_fp = NULL;
|
||||||
cip->i_name = NULL;
|
cip->i_name = NULL;
|
||||||
cip->i_ttystr = NULL;
|
cip->i_ttystr = NULL;
|
||||||
@@ -445,7 +452,6 @@ openterminal(void)
|
|||||||
cip->i_state = IS_READ;
|
cip->i_state = IS_READ;
|
||||||
cip->i_char = '\0';
|
cip->i_char = '\0';
|
||||||
cip->i_str = NULL;
|
cip->i_str = NULL;
|
||||||
cip->i_origstr = NULL;
|
|
||||||
cip->i_ttystr = NULL;
|
cip->i_ttystr = NULL;
|
||||||
cip->i_fp = NULL;
|
cip->i_fp = NULL;
|
||||||
cip->i_name = NULL;
|
cip->i_name = NULL;
|
||||||
@@ -462,8 +468,8 @@ closeinput(void)
|
|||||||
{
|
{
|
||||||
if (depth <= 0)
|
if (depth <= 0)
|
||||||
return;
|
return;
|
||||||
if (cip->i_origstr)
|
if (cip->i_str)
|
||||||
free(cip->i_origstr);
|
free(cip->i_str);
|
||||||
if (cip->i_fp)
|
if (cip->i_fp)
|
||||||
fclose(cip->i_fp);
|
fclose(cip->i_fp);
|
||||||
if (cip->i_name)
|
if (cip->i_name)
|
||||||
@@ -515,8 +521,11 @@ nextchar(void)
|
|||||||
return ch;
|
return ch;
|
||||||
}
|
}
|
||||||
if (cip->i_str) { /* from string */
|
if (cip->i_str) { /* from string */
|
||||||
ch = chartoint(*cip->i_str++);
|
if (cip->i_num) {
|
||||||
if (ch == '\0')
|
ch = chartoint(*cip->i_cp++);
|
||||||
|
cip->i_num--;
|
||||||
|
}
|
||||||
|
else
|
||||||
ch = EOF;
|
ch = EOF;
|
||||||
} else if (cip->i_fp) { /* from file */
|
} else if (cip->i_fp) { /* from file */
|
||||||
ch = fgetc(cip->i_fp);
|
ch = fgetc(cip->i_fp);
|
||||||
@@ -525,10 +534,6 @@ nextchar(void)
|
|||||||
} else { /* from terminal */
|
} else { /* from terminal */
|
||||||
ch = ttychar();
|
ch = ttychar();
|
||||||
}
|
}
|
||||||
if (ch == EOF) { /* fix up end of file */
|
|
||||||
closeinput();
|
|
||||||
ch = EOF;
|
|
||||||
}
|
|
||||||
if (depth > 0)
|
if (depth > 0)
|
||||||
cip->i_char = ch; /* save for rereads */
|
cip->i_char = ch; /* save for rereads */
|
||||||
if (ch == '\n')
|
if (ch == '\n')
|
||||||
@@ -634,6 +639,9 @@ ttychar(void)
|
|||||||
if (*cmd == '\0' || *cmd == '\n')
|
if (*cmd == '\0' || *cmd == '\n')
|
||||||
cmd = shell;
|
cmd = shell;
|
||||||
if (allow_exec) {
|
if (allow_exec) {
|
||||||
|
if (conf->calc_debug & CALCDBG_SYSTEM) {
|
||||||
|
printf("%s\n", cmd);
|
||||||
|
}
|
||||||
system(cmd);
|
system(cmd);
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "execution disallowed by -m flag\n");
|
fprintf(stderr, "execution disallowed by -m flag\n");
|
||||||
@@ -663,6 +671,16 @@ inputisterminal(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Return depth of current input source
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
inputlevel(void)
|
||||||
|
{
|
||||||
|
return depth - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Return the name of the current input file.
|
* Return the name of the current input file.
|
||||||
* Returns NULL for terminal or strings.
|
* Returns NULL for terminal or strings.
|
||||||
@@ -710,35 +728,37 @@ runrcfiles(void)
|
|||||||
{
|
{
|
||||||
char path[MAX_CALCRC+1+1]; /* name being searched for */
|
char path[MAX_CALCRC+1+1]; /* name being searched for */
|
||||||
char *cp;
|
char *cp;
|
||||||
char *newcp;
|
|
||||||
char *p;
|
char *p;
|
||||||
int i;
|
|
||||||
|
|
||||||
/* execute each file in the list */
|
/* execute each file in the list */
|
||||||
for (cp=calcrc, newcp=(char *)strchr(calcrc, LISTCHAR);
|
while (calcrc != NULL && *calcrc) {
|
||||||
cp != NULL && *cp;
|
cp = calcrc;
|
||||||
cp = newcp,
|
calcrc = (char *) strchr(calcrc + 1, LISTCHAR);
|
||||||
newcp=(newcp) ? (char *)strchr(newcp+1, LISTCHAR) : NULL) {
|
|
||||||
|
|
||||||
/* load file name into the path */
|
/* load file name into the path */
|
||||||
if (newcp == NULL) {
|
if (calcrc == NULL) {
|
||||||
strcpy(path, cp);
|
strcpy(path, cp);
|
||||||
} else {
|
} else {
|
||||||
strncpy(path, cp, newcp-cp);
|
strncpy(path, cp, calcrc - cp);
|
||||||
path[newcp-cp] = '\0';
|
path[calcrc - cp] = '\0';
|
||||||
}
|
}
|
||||||
|
|
||||||
/* find the start of the path */
|
/* find the start of the path */
|
||||||
p = (path[0] == ':') ? path+1 : path;
|
p = (path[0] == ':') ? path + 1 : path;
|
||||||
if (p[0] == '\0') {
|
if (p[0] == '\0') {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* process the current file in the list */
|
/* process the current file in the list */
|
||||||
i = openfile(p);
|
if (openfile(p) < 0) {
|
||||||
if (i < 0)
|
/* Unable to open rcfile */
|
||||||
|
if (c_flag && !d_flag)
|
||||||
|
fprintf(stderr,
|
||||||
|
"Unable to open rcfile \"%s\"\n", p);
|
||||||
continue;
|
continue;
|
||||||
|
}
|
||||||
getcommands(FALSE);
|
getcommands(FALSE);
|
||||||
|
closeinput();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
12
lib/Makefile
12
lib/Makefile
@@ -44,7 +44,7 @@ CALC_FILES= README bigprime.cal deg.cal ellip.cal lucas.cal lucas_chk.cal \
|
|||||||
test2700.cal test3100.cal test3300.cal test3400.cal prompt.cal \
|
test2700.cal test3100.cal test3300.cal test3400.cal prompt.cal \
|
||||||
test3500.cal seedrandom.cal test4000.cal test4100.cal test4600.cal \
|
test3500.cal seedrandom.cal test4000.cal test4100.cal test4600.cal \
|
||||||
beer.cal hello.cal test5100.cal test5200.cal randombitrun.cal \
|
beer.cal hello.cal test5100.cal test5200.cal randombitrun.cal \
|
||||||
randomrun.cal xx_print.cal natnumset.cal
|
randomrun.cal xx_print.cal natnumset.cal qtime.cal test8400.cal
|
||||||
|
|
||||||
# These files are found (but not built) in the distribution
|
# These files are found (but not built) in the distribution
|
||||||
#
|
#
|
||||||
@@ -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:
|
||||||
|
|
||||||
|
146
lib/README
146
lib/README
@@ -1,20 +1,44 @@
|
|||||||
# Copyright (c) 1997 David I. Bell and Landon Curt Noll
|
To load a library, try:
|
||||||
# Permission is granted to use, distribute, or modify this source,
|
|
||||||
# provided that this copyright notice remains intact.
|
|
||||||
|
|
||||||
The following calc library files are provided because they serve as
|
read filename
|
||||||
examples of how use the calc language, and/or because the authors thought
|
|
||||||
them to be useful!
|
You to not need to add the .cal extension to the filename. Calc
|
||||||
|
will search along the $CALCPATH (see ``help environment'').
|
||||||
|
|
||||||
|
Normally a library will simply define some functions. By default,
|
||||||
|
most libraries will print out a short message when thei are read.
|
||||||
|
For example:
|
||||||
|
|
||||||
|
> read lucas
|
||||||
|
lucas(h,n) defined
|
||||||
|
gen_u0(h,n,v1) defined
|
||||||
|
gen_v1(h,n) defined
|
||||||
|
ldebug(funct,str) defined
|
||||||
|
|
||||||
|
will cause calc to load and execute the 'lucas.cal' library.
|
||||||
|
Executing the library will cause several functions to be defined.
|
||||||
|
Executing the lucas function:
|
||||||
|
|
||||||
|
> lucas(149,60)
|
||||||
|
1
|
||||||
|
> lucas(146,61)
|
||||||
|
0
|
||||||
|
|
||||||
|
shows that 149*2^60-1 is prime whereas 146*2^61-1 is not.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
Calc library files are provided because they serve as examples of how use
|
||||||
|
the calc language, and/or because the authors thought them to be useful!
|
||||||
|
|
||||||
If you write something that you think is useful, please send it to:
|
If you write something that you think is useful, please send it to:
|
||||||
|
|
||||||
dbell@auug.org.au
|
calc-tester@postofc.corp.sgi.com
|
||||||
chongo@toad.com {uunet,pyramid,sun}!hoptoad!chongo
|
|
||||||
|
|
||||||
By convention, a lib file only defines and/or initializes functions,
|
By convention, a lib file only defines and/or initializes functions,
|
||||||
objects and variables. (The regression test is an exception.) Also by
|
objects and variables. (The regress.cal and testxxx.cal regression test
|
||||||
convention, the a usage message regarding each important object and
|
suite is an exception.) Also by convention, an additional usage message
|
||||||
function is printed at the time of the read.
|
regarding important object and functions is printed.
|
||||||
|
|
||||||
If a lib file needs to load another lib file, it should use the -once
|
If a lib file needs to load another lib file, it should use the -once
|
||||||
version of read:
|
version of read:
|
||||||
@@ -26,37 +50,52 @@ version of read:
|
|||||||
This will cause the needed library files to be read once. If these
|
This will cause the needed library files to be read once. If these
|
||||||
files have already been read, the read -once will act as a noop.
|
files have already been read, the read -once will act as a noop.
|
||||||
|
|
||||||
By convention, the config parameter "lib_debug" is used to control
|
The "lib_debug" parameter is intended for controlling the possible
|
||||||
the verbosity of debug information printed by lib files. By default,
|
display of special information relating to functions, objects, and
|
||||||
the "lib_debug" has a value of 0.
|
other structures created by instructions in calc scripts.
|
||||||
|
Zero value of config("lib_debug") means that no such information
|
||||||
|
is displayed. For other values, the non-zero bits which currently
|
||||||
|
have meanings are as follows:
|
||||||
|
|
||||||
The "lib_debug" config parameter takes the place of the lib_debug
|
n Meaning of bit n of config("lib_debug")
|
||||||
global variable. By convention, "lib_debug" has the following meanings:
|
|
||||||
|
|
||||||
<-1 no debug messages are printed though some internal
|
0 When a function is defined, redefined or undefined at
|
||||||
debug actions and information may be collected
|
interactive level, a message saying what has been done
|
||||||
|
is displayed.
|
||||||
|
|
||||||
-1 no debug messages are printed, no debug actions will be taken
|
1 When a function is defined, redefined or undefined during
|
||||||
|
the reading of a file, a message saying what has been done
|
||||||
|
is displayed.
|
||||||
|
|
||||||
0 only usage message regarding each important object are
|
The value for config("lib_debug") in both oldstd and newstd is 3,
|
||||||
printed at the time of the read (default)
|
but if calc is invoked with the -d flag, its initial value is zero.
|
||||||
|
Thus, if calc is started without the -d flag, until config("lib_debug")
|
||||||
|
is changed, a message will be output when a function is defined
|
||||||
|
either interactively or during the reading of a file.
|
||||||
|
|
||||||
>0 messages regarding each important object are
|
Sometimes the information printed is not enough. In addition to the
|
||||||
printed at the time of the read in addition
|
standard information, one might want to print:
|
||||||
to other debug messages
|
|
||||||
|
|
||||||
To conform to the above convention, your lib files should end with
|
* useful obj definitions
|
||||||
lines of the form:
|
* functions with optional args
|
||||||
|
* functions with optional args where the param() interface is used
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
For these cases we suggest that you place at the bottom of your code
|
||||||
|
something that prints extra information if config("lib_debug") has
|
||||||
|
either of the bottom 2 bits set:
|
||||||
|
|
||||||
|
if (config("lib_debug") & 3) {
|
||||||
print "obj xyz defined";
|
print "obj xyz defined";
|
||||||
print "funcA(side_a, side_b, side_c) defined";
|
print "funcA([val1 [, val2]]) defined";
|
||||||
print "funcB(size, mass) defined";
|
print "funcB(size, mass, ...) defined";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
=-=
|
=-=
|
||||||
|
|
||||||
|
The following is a brief description of some of the calc library files
|
||||||
|
that are shipped with calc. See above for example of how to read in
|
||||||
|
and execute these files.
|
||||||
|
|
||||||
beer.cal
|
beer.cal
|
||||||
|
|
||||||
Calc's contribution to the 99 Bottles of Beer web page:
|
Calc's contribution to the 99 Bottles of Beer web page:
|
||||||
@@ -100,7 +139,7 @@ deg.cal
|
|||||||
|
|
||||||
ellip.cal
|
ellip.cal
|
||||||
|
|
||||||
factor(iN, ia, B, force)
|
efactor(iN, ia, B, force)
|
||||||
|
|
||||||
Attempt to factor using the elliptic functions: y^2 = x^3 + a*x + b.
|
Attempt to factor using the elliptic functions: y^2 = x^3 + a*x + b.
|
||||||
|
|
||||||
@@ -160,7 +199,7 @@ mfactor.cal
|
|||||||
|
|
||||||
mod.cal
|
mod.cal
|
||||||
|
|
||||||
mod(a)
|
lmod(a)
|
||||||
mod_print(a)
|
mod_print(a)
|
||||||
mod_one()
|
mod_one()
|
||||||
mod_cmp(a, b)
|
mod_cmp(a, b)
|
||||||
@@ -234,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
|
||||||
|
|
||||||
@@ -250,7 +297,7 @@ pix.cal
|
|||||||
|
|
||||||
pollard.cal
|
pollard.cal
|
||||||
|
|
||||||
factor(N, N, ai, af)
|
pfactor(N, N, ai, af)
|
||||||
|
|
||||||
Factor using Pollard's p-1 method.
|
Factor using Pollard's p-1 method.
|
||||||
|
|
||||||
@@ -276,6 +323,13 @@ psqrt.cal
|
|||||||
Calculate square roots modulo a prime
|
Calculate square roots modulo a prime
|
||||||
|
|
||||||
|
|
||||||
|
qtime.cal
|
||||||
|
|
||||||
|
qtime(utc_hr_offset)
|
||||||
|
|
||||||
|
Print the time as English sentence given the hours offset from UTC.
|
||||||
|
|
||||||
|
|
||||||
quat.cal
|
quat.cal
|
||||||
|
|
||||||
quat(a, b, c, d)
|
quat(a, b, c, d)
|
||||||
@@ -520,6 +574,20 @@ test3400.cal
|
|||||||
This script is used by regress.cal to test trig functions.
|
This script is used by regress.cal to test trig functions.
|
||||||
containing objects.
|
containing objects.
|
||||||
|
|
||||||
|
test3500.cal
|
||||||
|
|
||||||
|
global defaultverbose
|
||||||
|
global err
|
||||||
|
testfrem(x, y, verbose)
|
||||||
|
testgcdrem(x, y, verbose)
|
||||||
|
testf(str, n, verbose)
|
||||||
|
testg(str, n, verbose)
|
||||||
|
testh(str, n, N, verbose)
|
||||||
|
test3500(verbose, n, N)
|
||||||
|
|
||||||
|
This script is used by regress.cal to test the functions frem,
|
||||||
|
fcnt, gcdrem.
|
||||||
|
|
||||||
test4000.cal
|
test4000.cal
|
||||||
|
|
||||||
global defaultverbose
|
global defaultverbose
|
||||||
@@ -617,7 +685,7 @@ varargs.cal
|
|||||||
|
|
||||||
xx_print.cal
|
xx_print.cal
|
||||||
|
|
||||||
isoctet(a) defined
|
is_octet(a) defined
|
||||||
list_print(a) defined
|
list_print(a) defined
|
||||||
mat_print (a) defined
|
mat_print (a) defined
|
||||||
octet_print(a) defined
|
octet_print(a) defined
|
||||||
@@ -628,3 +696,9 @@ xx_print.cal
|
|||||||
error_print(a) defined
|
error_print(a) defined
|
||||||
|
|
||||||
Demo for the xx_print object routines.
|
Demo for the xx_print object routines.
|
||||||
|
|
||||||
|
=-=
|
||||||
|
|
||||||
|
# Copyright (c) 1999 David I. Bell and Landon Curt Noll
|
||||||
|
# Permission is granted to use, distribute, or modify this source,
|
||||||
|
# provided that this copyright notice remains intact.
|
||||||
|
@@ -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
|
||||||
|
@@ -20,7 +20,3 @@ for (i=99; i > 0;) {
|
|||||||
bottles = (i!=1) ? "bottles" : "bottle";
|
bottles = (i!=1) ? "bottles" : "bottle";
|
||||||
print less, bottles, "of beer on the wall!\n";
|
print less, bottles, "of beer on the wall!\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
/* nothing to do! */
|
|
||||||
}
|
|
||||||
|
@@ -60,7 +60,3 @@ define B(n)
|
|||||||
Bnmax = n;
|
Bnmax = n;
|
||||||
return Bn[n];
|
return Bn[n];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "B(n) defined";
|
|
||||||
}
|
|
||||||
|
@@ -25,7 +25,3 @@ define bigprime(a, m, p)
|
|||||||
print " " : n;
|
print " " : n;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "bigprime(a, m, p) defined";
|
|
||||||
}
|
|
||||||
|
@@ -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 <chongo@toad.com>
|
* 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 */
|
||||||
@@ -174,7 +174,7 @@ define chrem()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "chrem(r1,m1 [,r2,m2 ...]) defined";
|
print "chrem(r1,m1 [,r2,m2 ...]) defined";
|
||||||
print "chrem(rlist [,mlist]) defined";
|
print "chrem(rlist [,mlist]) defined";
|
||||||
}
|
}
|
||||||
|
@@ -111,13 +111,6 @@ define fixdms(a)
|
|||||||
a.deg %= 360;
|
a.deg %= 360;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "obj dms {deg, min, sec} defined";
|
print "obj dms {deg, min, sec} defined";
|
||||||
print "dms(deg, min, sec) defined";
|
|
||||||
print "dms_add(a, b) defined";
|
|
||||||
print "dms_neg(a) defined";
|
|
||||||
print "dms_sub(a, b) defined";
|
|
||||||
print "dms_mul(a, b) defined";
|
|
||||||
print "dms_print(a) defined";
|
|
||||||
print "dms_abs(a) defined";
|
|
||||||
}
|
}
|
||||||
|
@@ -24,7 +24,7 @@
|
|||||||
* only an approximation, read "A Course in Number Theory and Cryptography"
|
* only an approximation, read "A Course in Number Theory and Cryptography"
|
||||||
* by Neal Koblitz for a good explanation.
|
* by Neal Koblitz for a good explanation.
|
||||||
*
|
*
|
||||||
* factor(iN, ia, B, force)
|
* efactor(iN, ia, B, force)
|
||||||
* iN is the number to be factored.
|
* iN is the number to be factored.
|
||||||
* ia is the initial value of a in the equation, and each successive
|
* ia is the initial value of a in the equation, and each successive
|
||||||
* value of a is an independent attempt at factoring (default 1).
|
* value of a is an independent attempt at factoring (default 1).
|
||||||
@@ -66,7 +66,7 @@ global b; /* second coefficient */
|
|||||||
global f; /* found factor */
|
global f; /* found factor */
|
||||||
|
|
||||||
|
|
||||||
define factor(iN, ia, B, force)
|
define efactor(iN, ia, B, force)
|
||||||
{
|
{
|
||||||
local C, x, p;
|
local C, x, p;
|
||||||
|
|
||||||
@@ -165,7 +165,3 @@ define point_pow(p, pow)
|
|||||||
}
|
}
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "factor(N, I, B, force) defined";
|
|
||||||
}
|
|
||||||
|
@@ -6,7 +6,3 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
while(1) print "Hello World!";
|
while(1) print "Hello World!";
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
/* nothing to do */
|
|
||||||
}
|
|
||||||
|
@@ -19,7 +19,10 @@
|
|||||||
* 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 /\../\ chongo@toad.com
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* lucas - perform a Lucas primality test on h*2^n-1
|
* lucas - perform a Lucas primality test on h*2^n-1
|
||||||
@@ -1024,12 +1027,8 @@ gen_v1(h, n)
|
|||||||
define
|
define
|
||||||
ldebug(funct, str)
|
ldebug(funct, str)
|
||||||
{
|
{
|
||||||
if (config("lib_debug") > 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "DEBUG:", funct:":", str;
|
print "DEBUG:", funct:":", str;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "lucas(h, n) defined";
|
|
||||||
}
|
|
||||||
|
@@ -19,7 +19,10 @@
|
|||||||
* 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 /\../\ chongo@toad.com
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* primes of the form h*2^n-1 for 1<=h<200 and 1<=n<1000
|
* primes of the form h*2^n-1 for 1<=h<200 and 1<=n<1000
|
||||||
@@ -328,7 +331,7 @@ lucas_chk(high_n, quiet)
|
|||||||
|
|
||||||
/* skip primes where h>=2^n */
|
/* skip primes where h>=2^n */
|
||||||
if (highbit(h_p[i]) >= n_p[i]) {
|
if (highbit(h_p[i]) >= n_p[i]) {
|
||||||
if (config("lib_debug") > 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "h>=2^n skip:", h_p[i]:"*2^":n_p[i]:"-1";
|
print "h>=2^n skip:", h_p[i]:"*2^":n_p[i]:"-1";
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
@@ -374,7 +377,3 @@ lucas_chk(high_n, quiet)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "lucas_chk(high_n) defined";
|
|
||||||
}
|
|
||||||
|
@@ -19,7 +19,10 @@
|
|||||||
* 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 /\../\ chongo@toad.com
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
/*
|
/*
|
||||||
* Lucasian criteria for primality
|
* Lucasian criteria for primality
|
||||||
@@ -149,7 +152,7 @@ d_val[97]=1045; a_val[97]=33; b_val[97]=1; r_val[97]=44;
|
|||||||
d_val[99]=9797; a_val[99]=97; b_val[99]=1; r_val[99]=388;
|
d_val[99]=9797; a_val[99]=97; b_val[99]=1; r_val[99]=388;
|
||||||
d_val[100]= 51; a_val[100]= 7; b_val[100]=1; r_val[100]=2;
|
d_val[100]= 51; a_val[100]= 7; b_val[100]=1; r_val[100]=2;
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "d_val[100] defined";
|
print "d_val[100] defined";
|
||||||
print "a_val[100] defined";
|
print "a_val[100] defined";
|
||||||
print "b_val[100] defined";
|
print "b_val[100] defined";
|
||||||
|
@@ -31,7 +31,3 @@ define mersenne(p)
|
|||||||
/* 2^p-1 is prime iff u(p) = 0 mod 2^p-1 */
|
/* 2^p-1 is prime iff u(p) = 0 mod 2^p-1 */
|
||||||
return (u == 0);
|
return (u == 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "mersenne(p) defined";
|
|
||||||
}
|
|
||||||
|
@@ -19,7 +19,10 @@
|
|||||||
* 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 /\../\ chongo@toad.com
|
* Landon Curt Noll
|
||||||
|
* http://reality.sgi.com/chongo/
|
||||||
|
*
|
||||||
|
* chongo <was here> /\../\
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
@@ -309,6 +312,6 @@ define mfactor(n, start_k, rept_loop, p_elim)
|
|||||||
return q;
|
return q;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "mfactor(n [, start_k=1 [, rept_loop=10000 [, p_elim=17]]])"
|
print "mfactor(n [, start_k=1 [, rept_loop=10000 [, p_elim=17]]])"
|
||||||
}
|
}
|
||||||
|
30
lib/mod.cal
30
lib/mod.cal
@@ -12,12 +12,12 @@ obj mod {a}; /* definition of the object */
|
|||||||
global mod_value = 100; /* modulus value (value of N) */
|
global mod_value = 100; /* modulus value (value of N) */
|
||||||
|
|
||||||
|
|
||||||
define mod(a)
|
define lmod(a)
|
||||||
{
|
{
|
||||||
local obj mod x;
|
local obj mod x;
|
||||||
|
|
||||||
if (!isreal(a) || !isint(a))
|
if (!isreal(a) || !isint(a))
|
||||||
quit "Bad argument for mod function";
|
quit "Bad argument for lmod function";
|
||||||
x.a = a % mod_value;
|
x.a = a % mod_value;
|
||||||
return x;
|
return x;
|
||||||
}
|
}
|
||||||
@@ -34,7 +34,7 @@ define mod_print(a)
|
|||||||
|
|
||||||
define mod_one()
|
define mod_one()
|
||||||
{
|
{
|
||||||
return mod(1);
|
return lmod(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -51,9 +51,9 @@ define mod_cmp(a, b)
|
|||||||
define mod_rel(a, b)
|
define mod_rel(a, b)
|
||||||
{
|
{
|
||||||
if (isnum(a))
|
if (isnum(a))
|
||||||
a = mod(a);
|
a = lmod(a);
|
||||||
if (isnum(b))
|
if (isnum(b))
|
||||||
b = mod(b);
|
b = lmod(b);
|
||||||
if (a.a < b.a)
|
if (a.a < b.a)
|
||||||
return -1;
|
return -1;
|
||||||
return a.a != b.a;
|
return a.a != b.a;
|
||||||
@@ -163,9 +163,9 @@ define mod_div(a, b)
|
|||||||
|
|
||||||
obj mod x, y;
|
obj mod x, y;
|
||||||
if (isnum(a))
|
if (isnum(a))
|
||||||
a = mod(a);
|
a = lmod(a);
|
||||||
if (isnum(b))
|
if (isnum(b))
|
||||||
b = mod(b);
|
b = lmod(b);
|
||||||
c = gcd(a.a, b.a);
|
c = gcd(a.a, b.a);
|
||||||
x.a = a.a / c;
|
x.a = a.a / c;
|
||||||
y.a = b.a / c;
|
y.a = b.a / c;
|
||||||
@@ -189,22 +189,8 @@ define mod_pow(a, b)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "obj mod {a} defined";
|
print "obj mod {a} defined";
|
||||||
print "mod(a) defined";
|
|
||||||
print "mod_print(a) defined";
|
|
||||||
print "mod_one(a) defined";
|
|
||||||
print "mod_cmp(a, b) defined";
|
|
||||||
print "mod_rel(a, b) defined";
|
|
||||||
print "mod_add(a, b) defined";
|
|
||||||
print "mod_sub(a, b) defined";
|
|
||||||
print "mod_mod(a, b) defined";
|
|
||||||
print "mod_square(a) defined";
|
|
||||||
print "mod_inc(a) defined";
|
|
||||||
print "mod_dec(a) defined";
|
|
||||||
print "mod_inv(a) defined";
|
|
||||||
print "mod_div(a, b) defined";
|
|
||||||
print "mod_pow(a, b) defined";
|
|
||||||
print "mod_value defined";
|
print "mod_value defined";
|
||||||
print "set mod_value as needed";
|
print "set mod_value as needed";
|
||||||
}
|
}
|
||||||
|
@@ -592,41 +592,3 @@ define set_print(a)
|
|||||||
}
|
}
|
||||||
|
|
||||||
local N, M; /* End scope of static variables N, M */
|
local N, M; /* End scope of static variables N, M */
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "isset(a) defined";
|
|
||||||
print "setbound(n) defined";
|
|
||||||
print "empty() defined";
|
|
||||||
print "full() defined";
|
|
||||||
print "isin(a, b) defined";
|
|
||||||
print "addmember(a, n) defined";
|
|
||||||
print "rmmember(a, n) defined";
|
|
||||||
print "set() defined";
|
|
||||||
print "mkset(s) defined";
|
|
||||||
print "primes(a, b) defined";
|
|
||||||
print "set_max(a) defined";
|
|
||||||
print "set_min(a) defined";
|
|
||||||
print "set_not(a) defined";
|
|
||||||
print "set_cmp(a, b) defined";
|
|
||||||
print "set_rel(a, b) defined";
|
|
||||||
print "set_or(a, b) defined";
|
|
||||||
print "set_and(a, b) defined";
|
|
||||||
print "set_comp(a) defined";
|
|
||||||
print "set_setminus(a, b) defined";
|
|
||||||
print "set_xor(a,b) defined";
|
|
||||||
print "set_content(a) defined";
|
|
||||||
print "set_add(a, b) defined";
|
|
||||||
print "set_sub(a, b) defined";
|
|
||||||
print "set_mul(a, b) defined";
|
|
||||||
print "set_square(a) defined";
|
|
||||||
print "set_pow(a, n) defined";
|
|
||||||
print "set_sum(a) defined";
|
|
||||||
print "set_plus(a) defined";
|
|
||||||
print "interval(a, b) defined";
|
|
||||||
print "isinterval(a) defined";
|
|
||||||
print "set_mod(a, b) defined";
|
|
||||||
print "randset(n, a, b) defined";
|
|
||||||
print "polyvals(L, A) defined";
|
|
||||||
print "polyvals2(L, A, B) defined";
|
|
||||||
print "set_print(a) defined";
|
|
||||||
}
|
|
||||||
|
@@ -66,8 +66,3 @@ define pellx(D)
|
|||||||
}
|
}
|
||||||
return Q1;
|
return Q1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "pell(D) defined";
|
|
||||||
print "pellx(D) defined";
|
|
||||||
}
|
|
||||||
|
72
lib/pi.cal
72
lib/pi.cal
@@ -48,6 +48,74 @@ define qpi(epsilon)
|
|||||||
return (bround(1/an, bits));
|
return (bround(1/an, bits));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "qpi(epsilon) defined";
|
/*
|
||||||
|
* 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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -38,7 +38,3 @@ define pi_of_x(x)
|
|||||||
}
|
}
|
||||||
return primes;
|
return primes;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "pi_of_x(x) defined";
|
|
||||||
}
|
|
||||||
|
@@ -6,7 +6,7 @@
|
|||||||
* Factor using Pollard's p-1 method.
|
* Factor using Pollard's p-1 method.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
define factor(N, B, ai, af)
|
define pfactor(N, B, ai, af)
|
||||||
{
|
{
|
||||||
local a, k, i, d;
|
local a, k, i, d;
|
||||||
|
|
||||||
@@ -28,7 +28,3 @@ define factor(N, B, ai, af)
|
|||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "factor(N, B, ai, af) defined";
|
|
||||||
}
|
|
||||||
|
37
lib/poly.cal
37
lib/poly.cal
@@ -687,41 +687,6 @@ a=pol(1,4,4,2,3,1);
|
|||||||
b=pol(5,16,8,1);
|
b=pol(5,16,8,1);
|
||||||
c=pol(1+2i,3+4i,5+6i);
|
c=pol(1+2i,3+4i,5+6i);
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "obj poly {p} defined";
|
print "obj poly {p} defined";
|
||||||
print "pol() defined";
|
|
||||||
print "poly_print(a) defined";
|
|
||||||
print "poly_add(a, b) defined";
|
|
||||||
print "poly_sub(a, b) defined";
|
|
||||||
print "poly_mul(a, b) defined";
|
|
||||||
print "poly_div(a, b) defined";
|
|
||||||
print "poly_quo(a,b) defined";
|
|
||||||
print "poly_mod(a,b) defined";
|
|
||||||
print "poly_neg(a) defined";
|
|
||||||
print "poly_conj(a) defined";
|
|
||||||
print "poly_cmp(a,b) defined";
|
|
||||||
print "iszero(a) defined";
|
|
||||||
print "plist(a) defined";
|
|
||||||
print "listmul(a,b) defined";
|
|
||||||
print "ev(a,t) defined";
|
|
||||||
print "evp(s,t) defined";
|
|
||||||
print "ispoly(a) defined";
|
|
||||||
print "isstring(a) defined";
|
|
||||||
print "var(name) defined";
|
|
||||||
print "pcoeff(a) defined";
|
|
||||||
print "pterm(a,n) defined";
|
|
||||||
print "deg(a) defined";
|
|
||||||
print "polydiv(a,b) defined";
|
|
||||||
print "D(a,n) defined";
|
|
||||||
print "Dp(a,n) defined";
|
|
||||||
print "pgcd(a,b) defined";
|
|
||||||
print "plcm(a,b) defined";
|
|
||||||
print "monic(a) defined";
|
|
||||||
print "pfgcd(a,b) defined";
|
|
||||||
print "interp(X,Y,x) defined";
|
|
||||||
print "makediffs(X,Y) defined";
|
|
||||||
print "evalfd(T,x) defined";
|
|
||||||
print "mdet(A) defined";
|
|
||||||
print "M(A,n,I,J) defined";
|
|
||||||
print "mprint(A) defined";
|
|
||||||
}
|
}
|
||||||
|
@@ -94,8 +94,3 @@ define showvalues(str) {
|
|||||||
print "\t":eval(str);
|
print "\t":eval(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "adder() defined";
|
|
||||||
print "showvalues(str) defined";
|
|
||||||
}
|
|
||||||
|
@@ -48,8 +48,3 @@ define psqrt(u, p)
|
|||||||
}
|
}
|
||||||
return min(v, p - v);
|
return min(v, p - v);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "psqrt(u, p) defined";
|
|
||||||
}
|
|
||||||
|
60
lib/qtime.cal
Normal file
60
lib/qtime.cal
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
/*
|
||||||
|
* qtime - Display time as English sentence
|
||||||
|
*
|
||||||
|
* usage:
|
||||||
|
* qtime(utc_hr_offset)
|
||||||
|
*
|
||||||
|
* utc_hr_offset Offset from UTC in hours.
|
||||||
|
*
|
||||||
|
* Written by: Klaus Alexander Seistrup <kseis@magnetic-ink.dk>
|
||||||
|
* With minor mods by: Landon Curt Noll <http://reality.sgi.com/chongo/>
|
||||||
|
*
|
||||||
|
* See:
|
||||||
|
* http://www.magnetic-ink.dk/download/qtime.html
|
||||||
|
*
|
||||||
|
* for examples of qtime() written on other languages.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* qtime - Display time as English sentence
|
||||||
|
*/
|
||||||
|
define qtime(utc_hr_offset)
|
||||||
|
{
|
||||||
|
static mat hr[12] = {
|
||||||
|
"twelve", "one", "two", "three", "four", "five",
|
||||||
|
"six", "seven", "eight", "nine", "ten", "eleven"
|
||||||
|
};
|
||||||
|
static mat mn[7] = {
|
||||||
|
"", "five ", "ten ", "a quarter ", "twenty ", "twenty-five ", "half "
|
||||||
|
};
|
||||||
|
static mat ny[5] = {
|
||||||
|
"nearly ", "almost ", "", "just after ", "after "
|
||||||
|
};
|
||||||
|
static mat up[3] = {
|
||||||
|
"to ", "", "past "
|
||||||
|
};
|
||||||
|
local adj_mins = (((time() + utc_hr_offset*3600) % 86400) + 30) // 60 + 27;
|
||||||
|
local hours = (adj_mins // 60) % 12;
|
||||||
|
local minutes = adj_mins % 60;
|
||||||
|
local almost = minutes % 5;
|
||||||
|
local divisions = (minutes // 5) - 5;
|
||||||
|
local to_past_idx = divisions > 0 ? 1 : 0;
|
||||||
|
|
||||||
|
if (divisions < 0) {
|
||||||
|
divisions = -divisions;
|
||||||
|
to_past_idx = -1;
|
||||||
|
}
|
||||||
|
++to_past_idx;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Print the English sentence
|
||||||
|
*
|
||||||
|
* We avoid forward and back quotes just to show that the char()
|
||||||
|
* builtin function can be used in conjunction with a printf.
|
||||||
|
*/
|
||||||
|
printf("It%cs %s%s%s%s",
|
||||||
|
char(0x27), ny[almost], mn[divisions], up[to_past_idx], hr[hours]);
|
||||||
|
if (divisions == 0)
|
||||||
|
printf(" o%cclock", char(0x27));
|
||||||
|
printf (".\n");
|
||||||
|
}
|
17
lib/quat.cal
17
lib/quat.cal
@@ -195,21 +195,6 @@ define quat_shift(a, b)
|
|||||||
return x.s;
|
return x.s;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
if (config("lib_debug") & 3) {
|
||||||
print "obj quat {s, v} defined";
|
print "obj quat {s, v} defined";
|
||||||
print "quat(a, b, c, d) defined";
|
|
||||||
print "quat_print(a) defined";
|
|
||||||
print "quat_norm(a) defined";
|
|
||||||
print "quat_abs(a, e) defined";
|
|
||||||
print "quat_conj(a) defined";
|
|
||||||
print "quat_add(a, e) defined";
|
|
||||||
print "quat_sub(a, e) defined";
|
|
||||||
print "quat_inc(a) defined";
|
|
||||||
print "quat_dec(a) defined";
|
|
||||||
print "quat_neg(a) defined";
|
|
||||||
print "quat_mul(a, b) defined";
|
|
||||||
print "quat_div(a, b) defined";
|
|
||||||
print "quat_inv(a) defined";
|
|
||||||
print "quat_scale(a, b) defined";
|
|
||||||
print "quat_shift(a, b) defined";
|
|
||||||
}
|
}
|
||||||
|
@@ -112,7 +112,3 @@ define randbitrun(run_cnt)
|
|||||||
printf("length>%d\t\t\t\t\tcount=%d\n", MAX_RUN, long_run_cnt);
|
printf("length>%d\t\t\t\t\tcount=%d\n", MAX_RUN, long_run_cnt);
|
||||||
printf("max length=%d\n", max_run);
|
printf("max length=%d\n", max_run);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (config("lib_debug") >= 0) {
|
|
||||||
print "randbitrun([run_length]) defined";
|
|
||||||
}
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user