annotate admin/notes/iftc @ 109274:a91e94388547
Minor doc/misc/*.texi direntry fixes.
* ada-mode.texi, auth.texi, autotype.texi, calc.texi, cc-mode.texi:
* dired-x.texi, ebrowse.texi, ede.texi, edt.texi, eieio.texi:
* emacs-mime.texi, epa.texi, erc.texi, eshell.texi, eudc.texi:
* flymake.texi, gnus.texi, info.texi, mairix-el.texi, message.texi:
* newsticker.texi, org.texi, pgg.texi, rcirc.texi, reftex.texi:
* remember.texi, sasl.texi, semantic.texi, ses.texi, smtpmail.texi:
* speedbar.texi, tramp.texi, url.texi, viper.texi, widget.texi:
* woman.texi:
Start direntry descriptions in column 32, per Texinfo convention.
Make them end with a period.
author |
Glenn Morris <rgm@gnu.org> |
date |
Thu, 24 Jun 2010 00:10:51 -0700 |
parents |
695cf19ef79e |
children |
375f2633d815 ef719132ddfa |
rev |
line source |
45625
|
1 Iso-Functional Type Contour
|
|
2
|
|
3
|
|
4 This is a term coined to describe "column int->float" change approach, and can
|
|
5 be used whenever low-level types need to change (hopefully not often!) but the
|
|
6 meanings of the values (whose type has changed) do not.
|
|
7
|
|
8 The premise is that changing a low-level type potentially means lots of code
|
|
9 needs to be changed as well, and the question is how to do this incrementally,
|
|
10 which is the preferred way to change things.
|
|
11
|
|
12 Say LOW and HIGH are C functions:
|
|
13
|
|
14 int LOW (void) { return 1; }
|
|
15 void HIGH (void) { int value = LOW (); }
|
|
16
|
|
17 We want to convert LOW to return float, so we cast HIGH usage:
|
|
18
|
|
19 float LOW (void) { return 1.0; }
|
|
20 void HIGH (void) { int value = (int) LOW (); } /* iftc */
|
|
21
|
|
22 The comment /* iftc */ is used to mark this type of casting to differentiate
|
|
23 it from other casting. We commit the changes and can now go about modifying
|
|
24 LOW and HIGH separately. When HIGH is ready to handle the type change, the
|
|
25 cast can be removed.
|
52401
|
26
|
|
27 ;;; arch-tag: 3309cc41-5d59-421b-b7be-c94b04083bb5
|