* src/insdel.c (prepare_to_modify_buffer): Revert last change as suggested
[emacs.git] / lisp / calc / README
blobc44ffe5aef0ad89b945dd0bb6d9c7eecb0e79032
1 Copyright (C) 2001-2013 Free Software Foundation, Inc.
2 See the end of the file for license conditions.
5 This directory contains Calc, an advanced desk calculator for GNU
6 Emacs.
8 "Calc"  Copyright (C) 1990-1993, 2001-2013 Free Software Foundation, Inc.
10 Written by:
11         Dave Gillespie
12         c/o Synaptics, Inc.
13         2698 Orchard Parkway
14         San Jose CA 95134
15         daveg@synaptics.com, uunet!synaptx!daveg
17 Currently maintained by:
18      Jay Belanger <jay.p.belanger@gmail.com>
20 From the introduction to the manual:
22   "Calc" is an advanced calculator and mathematical tool that runs as
23   part of the GNU Emacs environment.  Very roughly based on the HP-28/48
24   series of calculators, its many features include:
26     * Choice of algebraic or RPN (stack-based) entry of calculations.
28     * Arbitrary precision integers and floating-point numbers.
30     * Arithmetic on rational numbers, complex numbers (rectangular and
31       polar), error forms with standard deviations, open and closed
32       intervals, vectors and matrices, dates and times, infinities,
33       sets, quantities with units, and algebraic formulas.
35     * Mathematical operations such as logarithms and trigonometric functions.
37     * Programmer's features (bitwise operations, non-decimal numbers).
39     * Financial functions such as future value and internal rate of return.
41     * Number theoretical features such as prime factorization and
42       arithmetic modulo M for any M.
44     * Algebraic manipulation features, including symbolic calculus.
46     * Moving data to and from regular editing buffers.
48     * "Embedded mode" for manipulating Calc formulas and data directly
49       inside any editing buffer.
51     * Graphics using GNUPLOT, a versatile (and free) plotting program.
53     * Easy programming using keyboard macros, algebraic formulas,
54       algebraic rewrite rules, or extended Emacs Lisp.
57 Calc is written entirely in Emacs Lisp, for maximum portability.
59 I am anxious to hear about your experiences using Calc.  Send mail to
60 "jay.p.belanger@gmail.com".  A bug report is most useful if you include the
61 exact input and output that occurred, any modes in effect (such as the
62 current precision), and so on.  If you find Calc is difficult to operate
63 in any way, or if you have other suggestions, don't hesitate to let me
64 know.  If you find errors (including simple typos) in the manual, let
65 me know.  Even if you find no bugs at all I would love to hear your
66 opinions.
70 Summary of changes to "Calc"
71 ------- -- ------- --  ----
73 Emacs 24.4
75 * The date forms use the Gregorian calendar for all dates.
76   (Previously they were a combination of Julian and Gregorian
77   dates.)  This can be configured with the customizable variable
78   `calc-gregorian-switch'.
80 * Support for ISO 8601 dates added.
81 Emacs 24.3
83 * Algebraic simplification mode is now the default.
84   To restrict to the limited simplifications given by the former
85   default simplification mode, use `m I'.
87 Emacs 24.1
89 * Support for musical notes added.
91 * Support for logarithmic units added.
93 * Calc no longer uses the tex prefix for TeX specific unit 
94 names when using TeX or LaTeX mode.
96 * Added option to highlight selections using faces.
98 * Gave `calc-histogram' the option of using a vector to determine the bins.
100 * Added "O" option prefix.
102 * Used "O" prefix to "d r" (`calc-radix') to turn on twos-complement mode.
104 Emacs 23.2
106 * Added twos-complement display.
108 Emacs 23.1:
110 * Gave `j *' (cal-sel-mult-both-sides) an option to expand the
111   denominator.
113 * Use `calc-embedded-word-regexp' for finding words in
114   `calc-embedded-word' in place of delimiters.
116 * Remove version numbering; use Emacs version for reference.
118 * Added support for using registers.
120 * Added support for Yacas, Maxima and Giac languages.
122 * Added a menu.
124 * Added logistic non-linear curves to curve-fitting.
126 * Added option of plotting data points and curve when curve-fitting.
128 * Made unit conversions exact when possible.
130 * Lowered the precedence of negation.
132 Version 2.1:
134 * New matrix mode for square matrices.  Improved handling of
135   non-commutative products.
137 * New functions: powerexpand and ldiv.
139 * Added new functions: sec, csc, cot, sech, csch, coth.
141 * 0^0 now evaluates to 1.
143 * Added a new language mode for LaTeX.
145 * Calc now tries to use an appropriate language mode in embedded mode.
147 * Calc now restores original modes when leaving embedded mode.
149 * User settable variables which are not set with keystrokes are now
150   customizable.
152 * Made ~/.calc.el the default Calc settings file.
154 * Miscellaneous updates and bugfixes.
157 Version 2.02f:
159  * Fixed a bug which broke `I', `H', `K' prefix keys in recent Emacs.
161  * Fixed a bug in calc.texinfo which prevented "make tex2" from working.
163  * Updated `C-y' (calc-yank) to understand Emacs 19 generalized kill ring.
165  * Added a copy of "calccard.tex", the Calc quick reference card.
168 Version 2.02e:
170  * Fixed an installation bug caused by recent changes to `write-region'.
173 Version 2.02d:
175  * Fixed a minor installation problem with a Emacs 19.29 byte-compiler bug.
177  * Removed archaic "macedit" package (superseded by "edmacro").
180 Version 2.02c:
182  * Patch to port Calc to Lucid Emacs 19; still works with GNU 18 and GNU 19.
184  * Fixed a bug that broke `C-x C-c' after Calc graphics had been used.
187 Version 2.02b:
189  * Minor patch to port Calc to GNU Emacs 19.  Will be superseded by Calc 3.00.
192 Version 2.02:
194  * Revamped the manual a bit; rearranged some sections.
196  * Added marginal notes for Key/Function Index refs in printed manual.
198  * Changed `M-# r' to deal more gracefully with blank lines.
200  * Made reductions like `V R +' and `M-# :' considerably faster.
202  * Improved parsing and display of cases like "[a + b]".
204  * Added `t +' and `t -' for doing business date arithmetic.
206  * Added "syntax tables," the opposite of compositions.
208  * Added another Rewrites Tutorial exercise.
210  * Added the "vmatches" function.
212  * Added the `Modes' variable and `m g' command.
214  * Improved `u s' to cancel, e.g., "11 mph hr / yd" to get a number.
216  * Added "quick units" commands "u 0" through "u 9".
218  * Moved `M-%' to calc.el to avoid autoloading problems.
220  * Added `M-=' during algebraic entry, acts like `RET ='.
222  * Made `LFD' prevent evaluation when finishing a calc-edit command.
224  * Changed calc-store commands to use `t .' mode for trail display.
226  * Improved integrator to understand forms involving "erf".
228  * Fixed parser to make sense of "[1....1e2]" input.
230  * Fixed FORTRAN parser to treat a(i,j) as a_i_j if a is declared matrix.
232  * Got rid of some version number stamps to reduce size of patches.
234  * Fixed a bug in defmath treating "<=" and ">=" predicates.
236  * Fixed a bug in which Calc crashed multiplying two date forms.
238  * Fixed a bug in line breaker that crashed for large, nested formulas.
240  * Fixed a bug using ` to edit string("foo").
242  * Fixed a bug where `M-# y' in Big mode copied stack level number.
244  * Fixed a bug where `g O' used wrong default directory, no completion.
246  * Fixed a bug where "foo_bar(i)" parsed in C mode but showed as foo#bar.
248  * Fixed several bugs where large calculations got "computation too long."
251 Version 2.01:
253  * Added percentage commands `M-%', `b %', and `c %'.
255  * Changed Big mode to force radix-10 in superscripts.
257  * Improved display of fractions in various language modes.
259  * Changed `a n' to work properly with equations and inequalities.
261  * The problem with cross references to Index nodes in TeX has been fixed.
263  * Fixed a bug where recursive esc-maps make calc-ext/-aent unloadable.
265  * Fixed a bug in `M-# k', then `OFF' right away, with fresh Emacs.
267  * Fixed a bug in which "S_i_j" was formatted wrong after `j s'.
269  * Fixed a bug in which `h k u c' positioned cursor on wrong line.
271  * Fixed a bug where `z ?' crashed if `z %' was defined.
273  * Fixed a bug in `j O' (calc-select-once-maybe).
275  * Fixed "make private" not to ask "Delete excess versions" and crash.
278 Version 2.00:
280  * First complete posting of Calc since 1.01.
282  * Most parts of Calc have seen changes since version 1.07.  See
283    section "New for Calc 2.00" in the manual for a summary.  In
284    the FTP version of the Calc distribution, the file README.prev
285    contains a detailed change history from 1.00 up to 2.00.
288 This file is part of GNU Emacs.
290 GNU Emacs is free software: you can redistribute it and/or modify
291 it under the terms of the GNU General Public License as published by
292 the Free Software Foundation, either version 3 of the License, or
293 (at your option) any later version.
295 GNU Emacs is distributed in the hope that it will be useful,
296 but WITHOUT ANY WARRANTY; without even the implied warranty of
297 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
298 GNU General Public License for more details.
300 You should have received a copy of the GNU General Public License
301 along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.