Trailing whitepace deleted.
[emacs.git] / lisp / calc / README
blobc33e5d92c8ff69ca4d0007154a3c3d5b2ec827af
2 This directory contains Calc, an advanced desk calculator for GNU
3 Emacs.
5 "Calc"  Copyright 1990, 1991, 1992, 1993, 2001 Free Software Foundation, Inc.
7 Written by:
8         Dave Gillespie
9         c/o Synaptics, Inc.
10         2698 Orchard Parkway
11         San Jose CA 95134
12         daveg@synaptics.com, uunet!synaptx!daveg
14 Currently maintained by:
15      D. Goel <deego@gnufans.org> and Colin Walters <walters@debian.org>
17 From the introduction to the manual:
19   "Calc" is an advanced calculator and mathematical tool that runs as
20   part of the GNU Emacs environment.  Very roughly based on the HP-28/48
21   series of calculators, its many features include:
23     * Choice of algebraic or RPN (stack-based) entry of calculations.
25     * Arbitrary precision integers and floating-point numbers.
27     * Arithmetic on rational numbers, complex numbers (rectangular and
28       polar), error forms with standard deviations, open and closed
29       intervals, vectors and matrices, dates and times, infinities,
30       sets, quantities with units, and algebraic formulas.
32     * Mathematical operations such as logarithms and trigonometric functions.
34     * Programmer's features (bitwise operations, non-decimal numbers).
36     * Financial functions such as future value and internal rate of return.
38     * Number theoretical features such as prime factorization and
39       arithmetic modulo M for any M.
41     * Algebraic manipulation features, including symbolic calculus.
43     * Moving data to and from regular editing buffers.
45     * "Embedded mode" for manipulating Calc formulas and data directly
46       inside any editing buffer.
48     * Graphics using GNUPLOT, a versatile (and free) plotting program.
50     * Easy programming using keyboard macros, algebraic formulas,
51       algebraic rewrite rules, or extended Emacs Lisp.
54 Calc is written entirely in Emacs Lisp, for maximum portability.
55 You do not need to recompile Emacs to install and use Calc.
57 You will need about six megabytes of disk space to install Calc
58 and its Info documentation.
60 See the file INSTALL for installation instructions.  The instructions
61 may seem long, but on typical systems you will only need to follow the
62 steps shown in the first section.
64 Don't even try to run Calc in uncompiled (.el) form!  It's far too slow.
67 I am anxious to hear about your experiences using Calc.  Send mail to
68 "daveg@synaptics.com".  A bug report is most useful if you include the
69 exact input and output that occurred, any modes in effect (such as the
70 current precision), and so on.  If you find Calc is difficult to operate
71 in any way, or if you have other suggestions, don't hesitate to let me
72 know.  If you find errors (including simple typos) in the manual, let
73 me know.  Even if you find no bugs at all I would love to hear your
74 opinions.
76 The latest Calc tar files and patches are always available for anonymous
77 FTP on prep.ai.mit.edu.
79 Thanks,
81                                                                 -- Dave
87 Summary of changes to "Calc"
88 ------- -- ------- --  ----
91 Version 2.02f:
93  * Fixed a bug which broke `I', `H', `K' prefix keys in recent Emacs.
95  * Fixed a bug in calc.texinfo which prevented "make tex2" from working.
97  * Updated `C-y' (calc-yank) to understand Emacs 19 generalized kill ring.
99  * Added a copy of "calccard.tex", the Calc quick reference card.
102 Version 2.02e:
104  * Fixed an installation bug caused by recent changes to `write-region'.
107 Version 2.02d:
109  * Fixed a minor installation problem with a Emacs 19.29 byte-compiler bug.
111  * Removed archaic "macedit" package (superseded by "edmacro").
114 Version 2.02c:
116  * Patch to port Calc to Lucid Emacs 19; still works with GNU 18 and GNU 19.
118  * Fixed a bug that broke `C-x C-c' after Calc graphics had been used.
121 Version 2.02b:
123  * Minor patch to port Calc to GNU Emacs 19.  Will be superseded by Calc 3.00.
126 Version 2.02:
128  * Revamped the manual a bit; rearranged some sections.
130  * Added marginal notes for Key/Function Index refs in printed manual.
132  * Changed `M-# r' to deal more gracefully with blank lines.
134  * Made reductions like `V R +' and `M-# :' considerably faster.
136  * Improved parsing and display of cases like "[a + b]".
138  * Added `t +' and `t -' for doing business date arithmetic.
140  * Added "syntax tables," the opposite of compositions.
142  * Added another Rewrites Tutorial exercise.
144  * Added the "vmatches" function.
146  * Added the `Modes' variable and `m g' command.
148  * Improved `u s' to cancel, e.g., "11 mph hr / yd" to get a number.
150  * Added "quick units" commands "u 0" through "u 9".
152  * Moved `M-%' to calc.el to avoid autoloading problems.
154  * Added `M-=' during algebraic entry, acts like `RET ='.
156  * Made `LFD' prevent evaluation when finishing a calc-edit command.
158  * Changed calc-store commands to use `t .' mode for trail display.
160  * Improved integrator to understand forms involving "erf".
162  * Fixed parser to make sense of "[1....1e2]" input.
164  * Fixed FORTRAN parser to treat a(i,j) as a_i_j if a is declared matrix.
166  * Got rid of some version number stamps to reduce size of patches.
168  * Fixed a bug in defmath treating "<=" and ">=" predicates.
170  * Fixed a bug in which Calc crashed multiplying two date forms.
172  * Fixed a bug in line breaker that crashed for large, nested formulas.
174  * Fixed a bug using ` to edit string("foo").
176  * Fixed a bug where `M-# y' in Big mode copied stack level number.
178  * Fixed a bug where `g O' used wrong default directory, no completion.
180  * Fixed a bug where "foo_bar(i)" parsed in C mode but showed as foo#bar.
182  * Fixed several bugs where large calculations got "computation too long."
185 Version 2.01:
187  * Added percentage commands `M-%', `b %', and `c %'.
189  * Changed Big mode to force radix-10 in superscripts.
191  * Improved display of fractions in various language modes.
193  * Changed `a n' to work properly with equations and inequalities.
195  * The problem with cross references to Index nodes in TeX has been fixed.
197  * Fixed a bug where recursive esc-maps make calc-ext/-aent unloadable.
199  * Fixed a bug in `M-# k', then `OFF' right away, with fresh Emacs.
201  * Fixed a bug in which "S_i_j" was formatted wrong after `j s'.
203  * Fixed a bug in which `h k u c' positioned cursor on wrong line.
205  * Fixed a bug where `z ?' crashed if `z %' was defined.
207  * Fixed a bug in `j O' (calc-select-once-maybe).
209  * Fixed "make private" not to ask "Delete excess versions" and crash.
212 Version 2.00:
214  * First complete posting of Calc since 1.01.
216  * Most parts of Calc have seen changes since version 1.07.  See
217    section "New for Calc 2.00" in the manual for a summary.  In
218    the FTP version of the Calc distribution, the file README.prev
219    contains a detailed change history from 1.00 up to 2.00.