home *** CD-ROM | disk | FTP | other *** search
/ Club Amiga de Montreal - CAM / CAM_CD_1.iso / files / 379a.lha / p2c1_13a / src / src.zoo / NOTES < prev    next >
Text File  |  1990-03-09  |  33KB  |  752 lines

  1.  
  2. THE GRAND P2C NOTES FILE:
  3.  
  4. This file contains notes to myself recording bugs, flaws, and suggested
  5. improvements to p2c.  They have roughly been separated into "old", "older",
  6. and "oldest" groups.  I can't guarantee I'll do any of these.  If you do,
  7. please mail me the diffs so I can incorporate them into the next release.
  8. Thanks!
  9.                         -- Dave Gillespie
  10.                            daveg@csvax.caltech.edu
  11.  
  12. -----------------------------------------------------------------------------
  13.  
  14.    Technically speaking, "for byte := min to max do" is legal even
  15.    if min > 255, i.e., the limits only need to be in range if the
  16.    body of the loop executes.  Thus, FOR loops should really use a
  17.    shadow parameter not just when max is the constant 255, but
  18.    whenever min or max are not provably in byte range.
  19.  
  20. -----------------------------------------------------------------------------
  21.  
  22.    Have a "-M"-like mode in which FREE is suppressed altogether, useful
  23.    in case p2c crashes because bugs have corrupted malloc's free list.
  24.  
  25. -----------------------------------------------------------------------------
  26.  
  27.    For expressions building small-sets whose maximum element is <= 15,
  28.    use "1 << x" instead of "1L << x".
  29.  
  30. -----------------------------------------------------------------------------
  31.  
  32.    Handle VAX Pascal VARYING OF CHARs used as the arguments of WITH
  33.    statements.
  34.  
  35. -----------------------------------------------------------------------------
  36.  
  37.    Have a p2crc feature which identifies a given named constant as
  38.    being a character, not a string of length 1.  Have an option in
  39.    which this is the default interpretation.
  40.  
  41. -----------------------------------------------------------------------------
  42.  
  43.    StringTruncLimit would be helped by expr.c:strmax() interpreting
  44.    sprintf control strings.  For %s, use strmax of the corresponding
  45.    argument.  For %d, use 11, etc.  For %.10s, use min(10, strmax(arg)).
  46.    For %.*s, just use strmax(arg), I guess.
  47.  
  48.    Have a mode in which such assignments are automatically truncated.
  49.  
  50.    Perform truncation testing for non-VAR procedure arguments, too.
  51.  
  52. -----------------------------------------------------------------------------
  53.  
  54.    In cref.p, the "strappend(buf,#0)" statement translates into
  55.    "strcpy(STR1,buf); strcpy(buf,STR1)" with a warning about a null
  56.    character in a sprintf control string!
  57.  
  58. -----------------------------------------------------------------------------
  59.  
  60.    Still having problems where the opening comment of an imported
  61.    module's interface text is copied into the program.
  62.  
  63. -----------------------------------------------------------------------------
  64.  
  65.    VAX Pascal features not yet handled:
  66.  
  67.       [UNSAFE] attribute is only implemented in a few situations.
  68.       [UNBOUND] attribute on a procedure says it doesn't need a static link.
  69.       [TRUNCATE] attribute on a parameter allows optional params w/no default.
  70.       [LIST] attribute on a parameter is like &rest in Lisp.
  71.       Support types like, e.g., [LONG] BOOLEAN.
  72.       Can assign "structurally compatible" but different record types.
  73.       File intrinsics need serious work, especially OPEN.
  74.       If a copy param is [READONLY], don't need to copy it.
  75.       If a procedure is [ASYNCHRONOUS], make all its variables volatile.
  76.       If a procedure is [NOOPTIMIZE], make all its variables volatile.
  77.       Provide a real implementation of BIN function and :BIN read format.
  78.       BIT_OFFSET and CARD intrinsics are not supported.
  79.  
  80. -----------------------------------------------------------------------------
  81.  
  82.    Modula-2 features not yet handled:
  83.  
  84.       Local modules are faked up in a pretty superficial way.
  85.       WORD is compatible with both pointers and CARDINALs.
  86.       WORD parameters are compatible with any word-sized object.
  87.       ARRAY OF WORD parameters are compatible with absolutely anything.
  88.       Improve treatment of character strings.
  89.       Find manuals for real implementations of Modula-2 and implement
  90.          any common language extensions.
  91.       Fix p2c to read system.m2 instead of system.imp automatically.
  92.  
  93. -----------------------------------------------------------------------------
  94.  
  95.    Oregon Software Pascal features not yet handled:
  96.  
  97.     procedure noioerror(var f:file);
  98.         Built-in.  Sets a flag on an already-open file so that
  99.         I/O errors record an error code rather than crashing.
  100.         Each file has its own error code.
  101.  
  102.     function ioerror(var f:file) : boolean;
  103.         True if an error has occurred in the file.
  104.  
  105.     function iostatus(var f:file) : integer;
  106.         The error code, when ioerror was true.
  107.  
  108.     reset and rewrite ignore the third parameter, and allow a fourth
  109.     param which is an integer variable that receives a status code.
  110.     Without this param, open errors are fatal.  An optional param
  111.     may be omitted as in reset(f,'foo',,v);
  112.  
  113. -----------------------------------------------------------------------------
  114.  
  115.    In p_search, if a file contains const/var/type/procedure/function
  116.    declarations without any module declaration, surround the entire
  117.    file with an implicit "module <generated-name>; {PERMANENT}" ... "end.".
  118.    This would help the Oregon Software dialect considerably.
  119.  
  120. -----------------------------------------------------------------------------
  121.  
  122.    Provide an explicit IncludeFrom syntax for "no include file".
  123.    E.g., "IncludeFrom dos 0".
  124.  
  125. -----------------------------------------------------------------------------
  126.  
  127.    In docast, smallsets are converted to large sets of the requested type.
  128.    Wouldn't it be better to convert to a set of 0..31 of the base type?
  129.    This would keep foo([]), where the argument is "set of char", from
  130.    allocating a full 256-bit array for the temporary.
  131.  
  132. -----------------------------------------------------------------------------
  133.  
  134.    When initializing a constant variant record or array of same in which
  135.    non-first variants are initialized, create a function to do the
  136.    initialization, plus, for modules w/o initializers, a note to call
  137.    this function.  Another possibility:  Initialize the array as well as
  138.    possible, but leave zeros in the variant parts.  Then the function
  139.    has only to fix up the non-first variant fields.
  140.  
  141. -----------------------------------------------------------------------------
  142.  
  143.    Figure out some way to initialize packed array constants, e.g., a short
  144.    macro PACK4(x,y)=(((x)<<4)+(y)) which is used inside the C initializer.
  145.    Alternatively, implement initializer functions as above and use those.
  146.  
  147. -----------------------------------------------------------------------------
  148.  
  149.    How about declaring Volatile any variables local to a function which
  150.    are used after the first RECOVER?  GNU also suggests writing the
  151.    statement:  "&foo;" which will have no side effect except to make
  152.    foo essentially volatile, without relying on ANSI features.
  153.  
  154. -----------------------------------------------------------------------------
  155.  
  156.    Test the macros for GET, PUT, etc.
  157.  
  158. -----------------------------------------------------------------------------
  159.  
  160.    Can the #if 0'd code for strinsert in funcs.c be changed to test
  161.    strcpyleft?
  162.  
  163. -----------------------------------------------------------------------------
  164.  
  165.    Even in Ansi mode, p2c seems to be casting Anyptrs into other pointer
  166.    types explicitly.  This is an automatic conversion in Ansi C.
  167.  
  168. -----------------------------------------------------------------------------
  169.  
  170.    A Turbo typed constant or VAX initialized variable with a VarMacro
  171.    loses its initializer!
  172.  
  173. -----------------------------------------------------------------------------
  174.  
  175.    Test the ability of the parser to recover from common problems such
  176.    as too many/few arguments to a procedure, missing/extra semicolon, etc.
  177.    One major problem has been with undeclared identifiers being used as
  178.    type names.
  179.  
  180. -----------------------------------------------------------------------------
  181.  
  182.    Line breaker still needs considerable tuning!
  183.  
  184. -----------------------------------------------------------------------------
  185.  
  186.    How about indenting trailing comments analogously to the code:
  187.    Try to indent to column C+(X-Y), where C=original column number,
  188.    X=output indentation, Y=original input indentation.
  189.  
  190.    Even fancier would be to study all the comment indentations in the
  191.    function or struct decl to discover if most comments are at the same
  192.    absolute indentation; if so, compute the average or minimum amount of
  193.    space preceding the comments and indent the C comments to an analogous
  194.    position.
  195.  
  196. -----------------------------------------------------------------------------
  197.  
  198.    After "type foo = bar;" variables declared as type foo are translated
  199.    as type bar.  Ought to assume the user has two names for a reason,
  200.    and copy the distinction into the C code.
  201.  
  202. -----------------------------------------------------------------------------
  203.  
  204.    Warn if address is taken of an arithmetic expression like "v1+1".
  205.    Allow user to declare certain bicalls as l-values, e.g., so that
  206.    LSC's topLeft and botRight macros won't generate complaints.
  207.  
  208. -----------------------------------------------------------------------------
  209.  
  210.    Consider changing the "language" modes into a set of p2crc files
  211.    which can be included to support the various modes.
  212.  
  213. -----------------------------------------------------------------------------
  214.  
  215.    If we exchange the THEN and ELSE parts of an IF statement, be sure
  216.    to exchange their comments as well!
  217.  
  218. -----------------------------------------------------------------------------
  219.  
  220.    How about checking for a ".p2crc" file in the user's home directory.
  221.  
  222. -----------------------------------------------------------------------------
  223.  
  224.    Store comments in the following situations:
  225.       On the first line of a record decl.
  226.       On the default clause of a CASE statement
  227.         (use same trick as for ELSE clauses).
  228.       On the "end" of a CASE statement.
  229.       On null statements.
  230.       Use stealcomments for, e.g., decl_comments and others.
  231.  
  232. -----------------------------------------------------------------------------
  233.  
  234.    Think of other formatting options for format_gen to support.
  235.  
  236. -----------------------------------------------------------------------------
  237.  
  238.    Consider converting gratuitous BEGIN/END pairs into gratuitous
  239.    { } pairs.
  240.  
  241. -----------------------------------------------------------------------------
  242.  
  243.    The construction "s := copy(s, 1, 3)" converts to a big mess that
  244.    could be simplified to "s[3] = 0".
  245.  
  246. -----------------------------------------------------------------------------
  247.  
  248.    Have a mode (and make it the default!) in which declarations are mixed
  249.    if and only if the original Pascal decls were mixed.  Simply store
  250.    a flag in each meaning to mark "mixed-with-preceding-meaning".
  251.  
  252. -----------------------------------------------------------------------------
  253.  
  254.    Have a column number at which to put names in variable and typedef
  255.    declarations.  Have another option to choose whether a '*' preceding
  256.    a name should be left- or right-justified within the skipped space:
  257.     int     *foo;     or
  258.         int *    foo;
  259.  
  260. -----------------------------------------------------------------------------
  261.  
  262.    Support the /*
  263.                 *
  264.                 */ form for multi-line comments.
  265.  
  266. -----------------------------------------------------------------------------
  267.  
  268.    Have an indentation parameter for the word "else" by itself on a line.
  269.  
  270. -----------------------------------------------------------------------------
  271.  
  272.    Have an option to use C++'s "//" comments when possible.
  273.    (0=never, 1=always, def=only for trailing comments.)
  274.  
  275. -----------------------------------------------------------------------------
  276.  
  277.    Allow real comments to come before top-of-file comments like {Language}.
  278.  
  279. -----------------------------------------------------------------------------
  280.  
  281.    Teach the line breaker to remove spaces around innermost operators
  282.    if in a crunch.
  283.  
  284. -----------------------------------------------------------------------------
  285.  
  286.    Is it possible that the line breaker is losing counts?  A line that
  287.    included lots of invisible parens converted to visible ones was
  288.    allowed to be suspiciously long.
  289.  
  290. -----------------------------------------------------------------------------
  291.  
  292.    The notation t^ where t is a text file should convert \n's to
  293.    spaces if necessary.
  294.  
  295. -----------------------------------------------------------------------------
  296.  
  297.    The assignment and type cast "f4 := tf4(i)" where type
  298.       "tf4 = function (i, j : integer) : str255"
  299.    generates something really weird.
  300.  
  301. -----------------------------------------------------------------------------
  302.  
  303.    The conditional expression  strsub(s,1,4) = 'Spam'
  304.    could be translated as      strncmp(s, "Spam", 4)
  305.  
  306. -----------------------------------------------------------------------------
  307.  
  308.    Consider an option which generates a "file.p2c" or "module.p2c"
  309.    file, that will in the future be read in by p2c as another p2crc
  310.    type of file, both when the module is re-translated later and when
  311.    it is imported.  This file would contain commands like "NoSideEffects"
  312.    for functions which are found to have this property, etc.
  313.  
  314. -----------------------------------------------------------------------------
  315.  
  316.    Extend the "file.log" or "module.log" file to contain a more detailed
  317.    account of the translation, including all notes and warnings which were
  318.    even considered.  For example, ALL calls to na_lsl with non-constant
  319.    shifts would be noted, even if regular notes in this case were not
  320.    requested.  Also, funny transformations along the lines of
  321.    "str[0] := chr(len)" and "ch >= #128" should be mentioned in the log.
  322.    How about a summary of non-default p2crc options and command-line args?
  323.  
  324. -----------------------------------------------------------------------------
  325.  
  326.    Create a TypeMacro analogous to FuncMacro, VarMacro, and ConstMacro.
  327.    Should the definition be expressed in C or Pascal notation?  (Yuck---not
  328.    a C type parser!)
  329.  
  330. -----------------------------------------------------------------------------
  331.  
  332.    In argument type promotions, should "unsigned char" be promoted to
  333.    "unsigned int"?
  334.  
  335. -----------------------------------------------------------------------------
  336.  
  337.    Turbo's FExpand translation is really weird.
  338.  
  339. -----------------------------------------------------------------------------
  340.  
  341.    Can we translate Erase(x) to unlink(x)?  (This could just be a FuncMacro.)
  342.  
  343. -----------------------------------------------------------------------------
  344.  
  345.    There should be an option that causes a type to be explicitly named,
  346.    even if it would not otherwise have had a typedef name.  Have a mode
  347.    that does this for all pointer types.
  348.  
  349. -----------------------------------------------------------------------------
  350.  
  351.    Make sure that the construction:  if blah then {comment} else other
  352.    does not rewrite to if (!blah) other; i.e., a comment in this situation
  353.    should generate an actual placeholder statement.  Or perhaps, a null
  354.    statement written explicitly by the Pascal programmer should always
  355.    produce a placeholder.
  356.  
  357. -----------------------------------------------------------------------------
  358.  
  359.    Allow the line breaker to treat a \003 as if it were a \010.  The penalty
  360.    should be enough less than SameIndentPenalty that same-indent cases will
  361.    cause the introduction of parentheses.
  362.  
  363. -----------------------------------------------------------------------------
  364.  
  365.    A comment of the form "{------}" where the whole comment is 78, 79 or 80
  366.    columns wide, should be reduced by two to take the larger C comment
  367.    brackets into account.  Also, "{*****}", etc.
  368.  
  369. -----------------------------------------------------------------------------
  370.  
  371.    There should be a mode that translates "halt" as "exit(0)", and another
  372.    that translates it as "exit(1)".
  373.  
  374. -----------------------------------------------------------------------------
  375.  
  376.    There should be a mode in which strread's "j" parameter is completely
  377.    ignored.  Also, in this mode, don't make a copy of the string being
  378.    read.
  379.  
  380. -----------------------------------------------------------------------------
  381.  
  382.    Is there an option that generates an fflush(stdout) after every write
  383.    (not writeln) statement?  It should be easy to do---the code is already
  384.    there to support the prompt statement.
  385.  
  386. -----------------------------------------------------------------------------
  387.  
  388.    Check out the Size_T_Long option; size_t appears to be int on most
  389.    machines, not long.
  390.  
  391. -----------------------------------------------------------------------------
  392.  
  393.    The type "size_t" should really be made into a separate type, with a
  394.    function to cast to type "size_t".  This function would always do
  395.    the cast unless sizeof(int) == sizeof(long), or unless the expression
  396.    only involves constants and objects or functions of type "size_t".
  397.  
  398. -----------------------------------------------------------------------------
  399.  
  400.    Finish the Turbo Pascal features (in the file turbo.imp).
  401.  
  402. -----------------------------------------------------------------------------
  403.  
  404.    Are there any ways to take advantage of "x ?: y" in GCC?
  405.    Is it worth using GCC constructor expressions for procedure variables?
  406.    How about generating "volatile" and "const" for suitable functions?
  407.       (doing this in the .h file would be very difficult...)
  408.    Use the "asm" notation of 5.17 to implement var x ['y'] declarations.
  409.  
  410. -----------------------------------------------------------------------------
  411.  
  412.    Recognize GCC extensions in pc_expr().  (By the way, remember
  413.    to implement += and friends in pc_expr(), too!)
  414.  
  415. -----------------------------------------------------------------------------
  416.  
  417.    Lightspeed C can't handle "typedef char foo[];" which arises from a
  418.    MAXINT-sized array type declaration.
  419.  
  420. -----------------------------------------------------------------------------
  421.  
  422.    "Return" and friends are only introduced once.  In code of the form:
  423.  
  424.       if (!done) { foo(); }  if (!done) { bar(); }
  425.  
  426.     p2c should, after patching up bar(), check if the foo() branch is
  427.     now also ripe for rearranging.
  428.  
  429. -----------------------------------------------------------------------------
  430.  
  431.    Have a global "paranoia" flag.  Default=use current defaults for other
  432.    options.  1=conservative defaults for other options.  0=sloppy defaults
  433.    for other options.
  434.  
  435. -----------------------------------------------------------------------------
  436.  
  437.    Rather than just generating a note, have writes of attribute characters
  438.    convert into calls to a "set attribute" procedure, such as nc_sethighlight.
  439.    Is there any way of generalizing this into something useful for
  440.    non-HP-Pascal-workstation users?
  441.  
  442. -----------------------------------------------------------------------------
  443.  
  444.    Warn when character constants which are control codes are produced.
  445.    (E.g., arrow keys, etc.)  Also, have an option which deletes all
  446.    highlighting codes from strings being output.
  447.  
  448. -----------------------------------------------------------------------------
  449.  
  450.    Think how nice things would be if the arithmetic routines actually
  451.    maintained the distinction between tp_int and tp_integer themselves,
  452.    so that makeexpr_longcast didn't have to second-guess them.
  453.  
  454. -----------------------------------------------------------------------------
  455.  
  456.    Importing FS *still* copies its "file support" comment into the importing
  457.    program!
  458.  
  459. -----------------------------------------------------------------------------
  460.  
  461.    Should parameterize those last few hard-wired names, such as "P_eoln",
  462.    "LONG_MAX", ... ?
  463.  
  464. -----------------------------------------------------------------------------
  465.  
  466.    Check if we need to cache away any more options' values, as we did for
  467.    VarStrings.  How about FoldConstants, SetBits, CopyStructs?
  468.  
  469.  
  470. =============================================================================
  471.  
  472.  
  473.    Support the "CSignif" option (by not generating C identifiers which
  474.    would not be unique if only that many characters were significant).
  475.  
  476. -----------------------------------------------------------------------------
  477.  
  478.    What if a procedure accesses strmax of a var-string parameter of a
  479.    parent procedure?  (Right now this generates a note.)
  480.  
  481. -----------------------------------------------------------------------------
  482.  
  483.    Handle full constructors for strings.
  484.    Handle small-array constants.
  485.  
  486. -----------------------------------------------------------------------------
  487.  
  488.    Have an option that causes ANYVAR's to be translated to void *'s.  In
  489.    this mode, all uses of ANYVAR variables will need to be cast to the
  490.    proper type, in the function body rather than in calls to the function.
  491.  
  492. -----------------------------------------------------------------------------
  493.  
  494.    Handle reading enums.  Add full error checking for reading booleans.
  495.    (And integer subranges?)
  496.  
  497. -----------------------------------------------------------------------------
  498.  
  499.    Support the "BigSetConst" option by creating constant arrays just as the
  500.    Pascal compiler does.
  501.  
  502. -----------------------------------------------------------------------------
  503.  
  504.    The 2^(N+1) - 2^M method for generating [M..N] is not safe if N is 31.
  505.    If the small-sets we are dealing with encompass the value 31 (== setbits-1)
  506.    then we must use the bitwise construction instead.  (Currently, the
  507.    translator just issues a note.)
  508.  
  509.    (If N is 31, 2^32 will most likely evaluate to 0 on most machines, which
  510.    is the correct value.  So this is only a minor problem.)
  511.  
  512. -----------------------------------------------------------------------------
  513.  
  514.    Big-set constants right now are always folded.  Provide a mechanism
  515.    for defined set constants, say by having a #define with an argument
  516.    which is the name of the temporary variable to use for the set.
  517.  
  518. -----------------------------------------------------------------------------
  519.  
  520.    Should we convert NA_LONGWORD-type variants into C casts?
  521.  
  522. -----------------------------------------------------------------------------
  523.  
  524.    Are there implementations of strcpy that do not return their first
  525.    argument?  If so, should have an option that says so.
  526.  
  527. -----------------------------------------------------------------------------
  528.  
  529.    Handle absolute-addressed variables better.  For  var a[12345]:integer,
  530.    create an initialized int *.  For  var a['foo']:integer, create an int *
  531.    which is initialized to NULL and accessed by a macro which locates the
  532.    symbol the first time the variable is used.
  533.  
  534. -----------------------------------------------------------------------------
  535.  
  536.    Handle the idiom, "reset(f, name); open(f);"
  537.  
  538. -----------------------------------------------------------------------------
  539.  
  540.    Should have an option that lowercases all file names used in "reset",
  541.    "fixfname", etc.  This should be on by default.
  542.  
  543. -----------------------------------------------------------------------------
  544.  
  545.    Add more complete support for conformant arrays.  Specifically, support
  546.    non-GNU compilers by converting variable-sized array declarations into
  547.    pointer declarations with calls to alloca or malloc/free (what if the
  548.    function uses free and contains return statements)?  Also convert
  549.    variable-array references into explicit index arithmetic.
  550.  
  551. -----------------------------------------------------------------------------
  552.  
  553.    Have a mode in which the body of a TRY-RECOVER is moved out into
  554.    a sub-procedure all its own, communicating with the parent through
  555.    varstructs as usual, so that the ANSI C warning about what longjmp
  556.    can do to the local variables is avoided.  Alternatively, have an
  557.    option in which all necessary locals are declared volatile when
  558.    setjmps are present.
  559.  
  560. -----------------------------------------------------------------------------
  561.  
  562.    If a sub-procedure refers to a parent's variable with the VAX Pascal
  563.    [STATIC] attribute, that variable is declared "static" inside the
  564.    varstruct!  Need to convert it into a varref to a static variable in
  565.    the parent.
  566.  
  567. -----------------------------------------------------------------------------
  568.  
  569.    When comparing records and arrays a la UCSD Pascal, should expand
  570.    into an "&&" expression comparing each field individually.  (What about
  571.    variants?  Maybe just compare the first variant, or the tagged
  572.    variant.)  Probably best to write a struct-comparison function the
  573.    first time a given type of struct is compared; that way, the function
  574.    can include a complete if tree or switch statement in the case of
  575.    tagged unions.
  576.  
  577. -----------------------------------------------------------------------------
  578.  
  579.    In the checkvarchanged code, take aliasing of VAR parameters into account.
  580.    For example, in "procedure p(s1 : string; var s2 : string)" p2c now avoids
  581.    copying s1 if s1 is not changed within p, but probably should also require
  582.    that s2 not change, or at least that s1 have been read and used before s2
  583.    is changed.
  584.  
  585. -----------------------------------------------------------------------------
  586.  
  587.    Provide an option that tells the code generator to provide helpful
  588.    comments of its own when generated code may be obscure.
  589.  
  590.  
  591. =============================================================================
  592.  
  593.  
  594.    Compact the various data structures.  In particular, typical runs
  595.    show the majority of memory is used by Meanings and Symbols for
  596.    global and imported objects.
  597.  
  598. -----------------------------------------------------------------------------
  599.  
  600.    The program wastes memory.  Find ways to reduce memory usage, and to
  601.    avoid leaving dead records on the heap.  (Garbage collection?  Yuck!)
  602.    (Maybe GC between each function declaration would be okay.)
  603.  
  604. -----------------------------------------------------------------------------
  605.  
  606.    Assign better names to temporaries.  Also, could avoid making redundant
  607.    temporaries by generating a unique temporary every time one is needed,
  608.    then crunching them down at the end just before the declarations are
  609.    written out.  Each temporary would maintain a list of all the other
  610.    temporaries (of the same type) with which it would conflict.  (This
  611.    would avoid the current method's waste when several temps are created,
  612.    then most are cancelled.)  Also, note that char STR1[10], STR2[20] can
  613.    be considered type-compatible and merged into STR[20].
  614.  
  615. -----------------------------------------------------------------------------
  616.  
  617.    Don't generate _STR_xxx structure names if they aren't forward-referenced.
  618.  
  619. -----------------------------------------------------------------------------
  620.  
  621.    Can optimize, e.g., "strpos(a,b) = 0" to a call to strstr() or strchr(),
  622.    even though these ANSI functions are not Pascal-like enough to use in 
  623.    the general case.
  624.  
  625. -----------------------------------------------------------------------------
  626.  
  627.    Complete the handling of "usecommas=0" mode.
  628.  
  629. -----------------------------------------------------------------------------
  630.  
  631.    Optimize "s := strltrim(s)", "s := strrtrim(s)", and both together.
  632.  
  633. -----------------------------------------------------------------------------
  634.  
  635.    Convert "(ch < 'a') or (ch > 'z')" to "!islower(ch)", and so on.
  636.    Also do "!islower(ch) && !isupper(ch)" => "!isalpha(ch)", etc.
  637.  
  638. -----------------------------------------------------------------------------
  639.  
  640.    Find other cases in which to call mixassignments().
  641.  
  642. -----------------------------------------------------------------------------
  643.  
  644.    The sequence:   sprintf(buf + strlen(buf), "...", ...);
  645.                    sprintf(buf + strlen(buf), "...", ...);
  646.    could be changed to a single sprintf.
  647.    Also, "sprintf(temp, "...%s", ..., buf); strcpy(buf, temp); (above);"
  648.    could be crunched down.  (This comes from strinsert, then strappend.)
  649.  
  650. -----------------------------------------------------------------------------
  651.  
  652.    If there is only one assignment to a structured function's return
  653.    variable, and that assignment is at the very end and assigns a local
  654.    variable to the return variable, then merge the variables.
  655.    (Example: name_list in netcmp's datastruct module.  RET_name_list
  656.    should be renamed to namestr.)
  657.  
  658. -----------------------------------------------------------------------------
  659.  
  660.    Have an option that causes if-then-else's to be replaced by ? :'s in
  661.    certain cases.  If the branches of the if are either both returns or
  662.    both assignments to the same variable, which has no side effects, and
  663.    if the whole conditional will be simple enough to fit on one line when
  664.    printed, then the ? : transformation is okay.
  665.  
  666. -----------------------------------------------------------------------------
  667.  
  668.    Have an option that makes limited use of variable initialization.
  669.    If the first statement of a function is an assignment of a constant
  670.    to a local variable, then the assignment is changed to an initialization.
  671.    (Non-constant initializers are probably too hard to check for safety.)
  672.    Should variables with initializers still be mixed?
  673.    (Example: valid_node_class in netcmp's datastructs module.)
  674.    File variable initialization is an especially good application for this.
  675.  
  676. -----------------------------------------------------------------------------
  677.  
  678.    Have an option that finds cases of multiple assignment.  For example:
  679.       a := x; b := x;   =>  a = b = x;
  680.       a := x; b := a;   =>  a = b = x;
  681.    (provided the objects in question have the same type).
  682.  
  683. -----------------------------------------------------------------------------
  684.  
  685.    Need an option that causes $if$'s to change to #if's, instead of being
  686.    evaluated at translation-time.  (This is *really hard* in general;
  687.    do it for some common cases, such as entire statements being commented
  688.    out, or fields being commented out of records.)
  689.  
  690. -----------------------------------------------------------------------------
  691.  
  692.    Have an option that prevents generation and inclusion of .h files for
  693.    modules; instead, each module would contain extern declarations for
  694.    the things it imports.  (Only declare names that are actually used---
  695.    this means the declarations will have to be emitted on a procedure-by-
  696.    procedure basis.)
  697.  
  698. -----------------------------------------------------------------------------
  699.  
  700.    Extend the ExpandIncludes option to compile include files as separate
  701.    stand-alone C modules.  The hard part is warning when the new module
  702.    uses a procedure which was declared static in an earlier C module.
  703.    Remember to re-emit all the proper #include's at the beginning.
  704.    Anything else?
  705.  
  706. -----------------------------------------------------------------------------
  707.  
  708.    Consider an option where the variables in a varStruct are made into
  709.    globals instead, or into parameters if there are few of them.
  710.  
  711. -----------------------------------------------------------------------------
  712.  
  713.    Perform a flow analysis after everything else is done; use this to
  714.    eliminate redundant checks, e.g., for nil pointers or non-open or
  715.    already-open files.  Also eliminate redundant "j" variables for
  716.    strwrite statements.
  717.  
  718. -----------------------------------------------------------------------------
  719.  
  720.    Need a method for simple pattern matching predicates in FuncMacros.
  721.    For example, allow special translations of functions where a given
  722.    argument is a known constant, or known to be positive, or two
  723.    arguments are the same, etc.
  724.  
  725. -----------------------------------------------------------------------------
  726.  
  727.    Have some way to provide run-time templates for fixblock/fixexpr-like
  728.    applications.  The user enters two C expressions A and B, possibly including
  729.    Prolog-like logical variables.  If fixexpr sees an expression matching A,
  730.    it rewrites it into the form of B.
  731.  
  732. -----------------------------------------------------------------------------
  733.  
  734.    Have an option to cause selected Pascal procedures or functions to be
  735.    expanded in-line.  Do this either by generating the keyword "inline",
  736.    or by doing the expansion in the translator.
  737.  
  738. -----------------------------------------------------------------------------
  739.  
  740.    Technically speaking, strcmp shouldn't be used to compute < and > for
  741.    strings on a machine with signed chars.  Should we care?
  742.  
  743. -----------------------------------------------------------------------------
  744.  
  745.    Have an option for creating a "display" of LINK pointers local to a
  746.    function.  Should only create such pointers for static levels which are
  747.    referred to in the function body.
  748.  
  749. -----------------------------------------------------------------------------
  750.  
  751.  
  752.