[net.lang.pascal] X3J9

robertd@tektronix.UUCP (08/30/84)

-------------
Just for the record, the ANSI/IEEE Joint Pascal Committee is X3J9. X3J11 is
the "C" committee.

Regarding the J&W User Manual suggestion that actual parameters passed to 'var'
formal parameters be "distinct", two points:

  First, the User Manual section was exactly that, not a definition of the
  language. As such, it includes style suggestions like this, which seems
  to be suggesting that "aliasing" of variables should be avoided.

  Second, such a restriction is not possible to enforce without examining
  the data flow of a program. Consider the following example:

    var
       x: integer;

    procedure twovars( var a, b: integer);
      begin
          { don't care }
      end;

    procedure sneaky( var p: integer);
      begin
        twovars( p, x);      { aliasing ! }
      end;

    begin
        sneaky( x);
    end;

  Here the passing of x as a var parameter to sneaky results in the call to
  twovars passing x as both actual parameters. It can certainly be argued that
  passing global variables as parameters opens the way for such aliasing, but
  I doubt anyone will seriously suggest prohibiting it. There are certainly
  programs that make use of passing (more) global variables as well as
  aliasing.

Regarding assignment to value parameters: This is practice that amounts
to style preference. I too have been bitten by forgeting to make a parameter
'var', but at the same time I have made use of such assignments. A value
parameter IS a local copy of the actual parameter. The best way to find this
problem (without changing the language and breaking a lot of existing programs)
is to either use a good cross-reference that shows assignments, or bug the
author of your compiler to (optionally!) provide a warning when a value
parameter is assigned a value.

                                              Bob Dietrich
                                              Tektronix, Inc.
                                              (503) 629-1727
{ucb or dec}vax!tektronix!robertd             uucp address
robertd@tektronix                             csnet address
robertd.tektronix@rand-relay                  arpa address