]> git.eshelyaron.com Git - emacs.git/commit
* lisp/calc/: Use lexical scoping in all the files
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 10 Oct 2020 20:00:51 +0000 (16:00 -0400)
committerStefan Monnier <monnier@iro.umontreal.ca>
Sat, 10 Oct 2020 20:00:51 +0000 (16:00 -0400)
commitf342b7c96929dcb0324c6eded32be4d98a764708
treeae0b3f20208f1f23e9a953957570488d48768544
parent46c0f28c0e4e212687e90ec0ecb239d994105a19
* lisp/calc/: Use lexical scoping in all the files

Includes the following pervasive changes:
- Move some defvars earlier in the file so they cover earlier let-bindings
- Change dynamically scoped `calc-FOO` or `math-FOO` function arguments
  to just FOO and then let-bind the `calc-FOO` or `math-FOO` variable
  explicitly in the body of the function.  In some cases, the
  beginning of the function was changed to refer to FOO so as to delay
  the binding to a nearby `let` when I could ensure that it did
  not make a difference.
- Add an underscore in front of unused vars or comment them out altogether.
- Replace unused `err` arg to `condition-case` with nil.

Plus the additional itemized changes below.

* lisp/calc/calc-map.el (calcFunc-reducer):
* lisp/calc/calc-arith.el (math-setup-declarations):
* lisp/calc/calc-help.el (calc-full-help, calc-help-index-entries)
(calc-full-help): Use `ignore-errors`.

* lisp/calc/calc-embed.el (calc-embedded-modes-change):
Declare `the-language` and `the-display-just` as dynamically scoped.

* lisp/calc/calc-forms.el (math-setup-year-holidays): Use `dolist`.

* lisp/calc/calc-graph.el (calc-graph-set-styles): Use `symbol-value`
rather than `eval.`
(calc-graph-delete-temps, calc-graph-set-styles): Use ignore-errors.

* lisp/calc/calc-macs.el (calc-with-trail-buffer): Add artificial use
of `save-buf` to silence compiler warnings in all the cases where
`body` doesn't make use of it.

* lisp/calc/calc-math.el (math-largest-emacs-expt)
(math-smallest-emacs-expt, math-use-emacs-fn): Use ignore-errors.

* lisp/calc/calc-mode.el (calc-total-algebraic-mode): Remove "P" from
interactive spec since it's not used anyway.

* lisp/calc/calc-rewr.el (calc-match): Simplify.

* lisp/calc/calc.el (calc-buffer): Give it a global nil value,
so it's automatically declared dynbound in any file that requires `calc`.
(calcDigit-nondigit): Adjust accordingly.

* lisp/calc/calcalg2.el (calcFunc-table): Declare `var-dummy` as dynbound.
(math-scan-for-limits): Comment out dead code.

* lisp/calc/calcalg3.el (math-general-fit): Declare `var-YVAL` and
`var-YVALX` as dynbound.
39 files changed:
lisp/calc/calc-aent.el
lisp/calc/calc-arith.el
lisp/calc/calc-bin.el
lisp/calc/calc-comb.el
lisp/calc/calc-cplx.el
lisp/calc/calc-embed.el
lisp/calc/calc-ext.el
lisp/calc/calc-fin.el
lisp/calc/calc-forms.el
lisp/calc/calc-frac.el
lisp/calc/calc-funcs.el
lisp/calc/calc-graph.el
lisp/calc/calc-help.el
lisp/calc/calc-incom.el
lisp/calc/calc-keypd.el
lisp/calc/calc-lang.el
lisp/calc/calc-macs.el
lisp/calc/calc-map.el
lisp/calc/calc-math.el
lisp/calc/calc-menu.el
lisp/calc/calc-misc.el
lisp/calc/calc-mode.el
lisp/calc/calc-mtx.el
lisp/calc/calc-nlfit.el
lisp/calc/calc-prog.el
lisp/calc/calc-rewr.el
lisp/calc/calc-rules.el
lisp/calc/calc-sel.el
lisp/calc/calc-stat.el
lisp/calc/calc-store.el
lisp/calc/calc-stuff.el
lisp/calc/calc-trail.el
lisp/calc/calc-undo.el
lisp/calc/calc-vec.el
lisp/calc/calc-yank.el
lisp/calc/calc.el
lisp/calc/calcalg2.el
lisp/calc/calcalg3.el
lisp/calc/calcsel2.el