home *** CD-ROM | disk | FTP | other *** search
/ Amiga Magazin: Amiga-CD 1996 July / AMIGA_1996_7.BIN / ausgabe_7_96 / pd-programmierung / perl5_002bin.lha / man / catp / perltrap.0 < prev    next >
Text File  |  1996-03-02  |  21KB  |  529 lines

  1.  
  2.  
  3.  
  4. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  5.  
  6.  
  7. NNNNAAAAMMMMEEEE
  8.        perltrap - Perl traps for the unwary
  9.  
  10. DDDDEEEESSSSCCCCRRRRIIIIPPPPTTTTIIIIOOOONNNN
  11.        The biggest trap of all is forgetting to use the ----wwww
  12.        switch; see the _p_e_r_l_r_u_n manpage.  The second biggest trap
  13.        is not making your entire program runnable under uuuusssseeee
  14.        ssssttttrrrriiiicccctttt.
  15.  
  16.        AAAAwwwwkkkk TTTTrrrraaaappppssss
  17.  
  18.        Accustomed aaaawwwwkkkk users should take special note of the
  19.        following:
  20.  
  21.        +o   The English module, loaded via
  22.  
  23.                uuuusssseeee EEEEnnnngggglllliiiisssshhhh;;;;
  24.  
  25.            allows you to refer to special variables (like $$$$RRRRSSSS) as
  26.            though they were in aaaawwwwkkkk; see the _p_e_r_l_v_a_r manpage for
  27.            details.
  28.  
  29.        +o   Semicolons are required after all simple statements in
  30.            Perl (except at the end of a block).  Newline is not a
  31.            statement delimiter.
  32.  
  33.        +o   Curly brackets are required on iiiiffffs and wwwwhhhhiiiilllleeees.
  34.  
  35.        +o   Variables begin with "$" or "@" in Perl.
  36.  
  37.        +o   Arrays index from 0.  Likewise string positions in
  38.            _s_u_b_s_t_r_(_) and _i_n_d_e_x_(_).
  39.  
  40.        +o   You have to decide whether your array has numeric or
  41.            string indices.
  42.  
  43.        +o   Associative array values do not spring into existence
  44.            upon mere reference.
  45.  
  46.        +o   You have to decide whether you want to use string or
  47.            numeric comparisons.
  48.  
  49.        +o   Reading an input line does not split it for you.  You
  50.            get to split it yourself to an array.  And _s_p_l_i_t_(_)
  51.            operator has different arguments.
  52.  
  53.        +o   The current input line is normally in $$$$____, not $$$$0000.  It
  54.            generally does not have the newline stripped.  ($0 is
  55.            the name of the program executed.)  See the _p_e_r_l_v_a_r
  56.            manpage.
  57.  
  58.        +o   $<_d_i_g_i_t> does not refer to fields--it refers to
  59.            substrings matched by the last match pattern.
  60.  
  61.  
  62.  
  63.  
  64. 30/Jan/96                perl 5.002 with                        1
  65.  
  66.  
  67.  
  68.  
  69.  
  70. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  71.  
  72.  
  73.        +o   The _p_r_i_n_t_(_) statement does not add field and record
  74.            separators unless you set $$$$,,,, and $$$$.....  You can set $$$$OOOOFFFFSSSS
  75.            and $$$$OOOORRRRSSSS if you're using the English module.
  76.  
  77.        +o   You must open your files before you print to them.
  78.  
  79.        +o   The range operator is "..", not comma.  The comma
  80.            operator works as in C.
  81.  
  82.        +o   The match operator is "=~", not "~".  ("~" is the
  83.            one's complement operator, as in C.)
  84.  
  85.        +o   The exponentiation operator is "**", not "^".  "^" is
  86.            the XOR operator, as in C.  (You know, one could get
  87.            the feeling that aaaawwwwkkkk is basically incompatible with
  88.            C.)
  89.  
  90.        +o   The concatenation operator is ".", not the null
  91.            string.  (Using the null string would render ////ppppaaaatttt////
  92.            ////ppppaaaatttt//// unparsable, since the third slash would be
  93.            interpreted as a division operator--the tokener is in
  94.            fact slightly context sensitive for operators like
  95.            "/", "?", and ">".  And in fact, "." itself can be the
  96.            beginning of a number.)
  97.  
  98.        +o   The nnnneeeexxxxtttt, eeeexxxxiiiitttt, and ccccoooonnnnttttiiiinnnnuuuueeee keywords work
  99.            differently.
  100.  
  101.        +o   The following variables work differently:
  102.  
  103.                  AAAAwwwwkkkk       PPPPeeeerrrrllll
  104.                  AAAARRRRGGGGCCCC      $$$$####AAAARRRRGGGGVVVV oooorrrr ssssccccaaaallllaaaarrrr @@@@AAAARRRRGGGGVVVV
  105.                  AAAARRRRGGGGVVVV[[[[0000]]]]   $$$$0000
  106.                  FFFFIIIILLLLEEEENNNNAAAAMMMMEEEE  $$$$AAAARRRRGGGGVVVV
  107.                  FFFFNNNNRRRR       $$$$.... ---- ssssoooommmmeeeetttthhhhiiiinnnngggg
  108.                  FFFFSSSS        ((((wwwwhhhhaaaatttteeeevvvveeeerrrr yyyyoooouuuu lllliiiikkkkeeee))))
  109.                  NNNNFFFF        $$$$####FFFFlllldddd,,,, oooorrrr ssssoooommmmeeee ssssuuuucccchhhh
  110.                  NNNNRRRR        $$$$....
  111.                  OOOOFFFFMMMMTTTT      $$$$####
  112.                  OOOOFFFFSSSS       $$$$,,,,
  113.                  OOOORRRRSSSS       $$$$\\\\
  114.                  RRRRLLLLEEEENNNNGGGGTTTTHHHH   lllleeeennnnggggtttthhhh(((($$$$&&&&))))
  115.                  RRRRSSSS        $$$$////
  116.                  RRRRSSSSTTTTAAAARRRRTTTT    lllleeeennnnggggtttthhhh(((($$$$````))))
  117.                  SSSSUUUUBBBBSSSSEEEEPPPP    $$$$;;;;
  118.  
  119.  
  120.        +o   You cannot set $$$$RRRRSSSS to a pattern, only a string.
  121.  
  122.        +o   When in doubt, run the aaaawwwwkkkk construct through aaaa2222pppp and
  123.            see what it gives you.
  124.  
  125.  
  126.  
  127.  
  128.  
  129.  
  130. 30/Jan/96                perl 5.002 with                        2
  131.  
  132.  
  133.  
  134.  
  135.  
  136. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  137.  
  138.  
  139.        CCCC TTTTrrrraaaappppssss
  140.  
  141.        Cerebral C programmers should take note of the following:
  142.  
  143.        +o   Curly brackets are required on iiiiffff's and wwwwhhhhiiiilllleeee's.
  144.  
  145.        +o   You must use eeeellllssssiiiiffff rather than eeeellllsssseeee iiiiffff.
  146.  
  147.        +o   The bbbbrrrreeeeaaaakkkk and ccccoooonnnnttttiiiinnnnuuuueeee keywords from C become in Perl
  148.            llllaaaasssstttt and nnnneeeexxxxtttt, respectively.  Unlike in C, these do
  149.            _N_O_T work within a ddddoooo {{{{ }}}} wwwwhhhhiiiilllleeee construct.
  150.  
  151.        +o   There's no switch statement.  (But it's easy to build
  152.            one on the fly.)
  153.  
  154.        +o   Variables begin with "$" or "@" in Perl.
  155.  
  156.        +o   _p_r_i_n_t_f_(_) does not implement the "*" format for
  157.            interpolating field widths, but it's trivial to use
  158.            interpolation of double-quoted strings to achieve the
  159.            same effect.
  160.  
  161.        +o   Comments begin with "#", not "/*".
  162.  
  163.        +o   You can't take the address of anything, although a
  164.            similar operator in Perl 5 is the backslash, which
  165.            creates a reference.
  166.  
  167.        +o   AAAARRRRGGGGVVVV must be capitalized.  $$$$AAAARRRRGGGGVVVV[[[[0000]]]] is C's aaaarrrrggggvvvv[[[[1111]]]],
  168.            and aaaarrrrggggvvvv[[[[0000]]]] ends up in $$$$0000.
  169.  
  170.        +o   System calls such as _l_i_n_k_(_), _u_n_l_i_n_k_(_), _r_e_n_a_m_e_(_), etc.
  171.            return nonzero for success, not 0.
  172.  
  173.        +o   Signal handlers deal with signal names, not numbers.
  174.            Use kkkkiiiillllllll ----llll to find their names on your system.
  175.  
  176.        SSSSeeeedddd TTTTrrrraaaappppssss
  177.  
  178.        Seasoned sssseeeedddd programmers should take note of the
  179.        following:
  180.  
  181.        +o   Backreferences in substitutions use "$" rather than
  182.            "\".
  183.  
  184.        +o   The pattern matching metacharacters "(", ")", and "|"
  185.            do not have backslashes in front.
  186.  
  187.        +o   The range operator is ............, rather than comma.
  188.  
  189.        SSSShhhheeeellllllll TTTTrrrraaaappppssss
  190.  
  191.        Sharp shell programmers should take note of the following:
  192.  
  193.  
  194.  
  195.  
  196. 30/Jan/96                perl 5.002 with                        3
  197.  
  198.  
  199.  
  200.  
  201.  
  202. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  203.  
  204.  
  205.        +o   The backtick operator does variable interpretation
  206.            without regard to the presence of single quotes in the
  207.            command.
  208.  
  209.        +o   The backtick operator does no translation of the
  210.            return value, unlike ccccsssshhhh.
  211.  
  212.        +o   Shells (especially ccccsssshhhh) do several levels of
  213.            substitution on each command line.  Perl does
  214.            substitution only in certain constructs such as double
  215.            quotes, backticks, angle brackets, and search
  216.            patterns.
  217.  
  218.        +o   Shells interpret scripts a little bit at a time.  Perl
  219.            compiles the entire program before executing it
  220.            (except for BBBBEEEEGGGGIIIINNNN blocks, which execute at compile
  221.            time).
  222.  
  223.        +o   The arguments are available via @@@@AAAARRRRGGGGVVVV, not $$$$1111, $$$$2222,
  224.            etc.
  225.  
  226.        +o   The environment is not automatically made available as
  227.            separate scalar variables.
  228.  
  229.        PPPPeeeerrrrllll TTTTrrrraaaappppssss
  230.  
  231.        Practicing Perl Programmers should take note of the
  232.        following:
  233.  
  234.        +o   Remember that many operations behave differently in a
  235.            list context than they do in a scalar one.  See the
  236.            _p_e_r_l_d_a_t_a manpage for details.
  237.  
  238.        +o   Avoid barewords if you can, especially all lower-case
  239.            ones.  You can't tell just by looking at it whether a
  240.            bareword is a function or a string.  By using quotes
  241.            on strings and parens on function calls, you won't
  242.            ever get them confused.
  243.  
  244.        +o   You cannot discern from mere inspection which built-
  245.            ins are unary operators (like _c_h_o_p_(_) and _c_h_d_i_r_(_)) and
  246.            which are list operators (like _p_r_i_n_t_(_) and _u_n_l_i_n_k_(_)).
  247.            (User-defined subroutines can oooonnnnllllyyyy be list operators,
  248.            never unary ones.)  See the _p_e_r_l_o_p manpage.
  249.  
  250.        +o   People have a hard time remembering that some
  251.            functions default to $$$$____, or @@@@AAAARRRRGGGGVVVV, or whatever, but
  252.            that others which you might expect to do not.
  253.  
  254.        +o   The <FH> construct is not the name of the filehandle,
  255.            it is a readline operation on that handle.  The data
  256.            read is only assigned to $$$$____ if the file read is the
  257.            sole condition in a while loop:
  258.  
  259.  
  260.  
  261.  
  262. 30/Jan/96                perl 5.002 with                        4
  263.  
  264.  
  265.  
  266.  
  267.  
  268. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  269.  
  270.  
  271.                wwwwhhhhiiiilllleeee ((((<<<<FFFFHHHH>>>>))))      {{{{ }}}}
  272.                wwwwhhhhiiiilllleeee (((($$$$____ ==== <<<<FFFFHHHH>>>>)))) {{{{ }}}}........
  273.                <<<<FFFFHHHH>>>>;;;;  #### ddddaaaattttaaaa ddddiiiissssccccaaaarrrrddddeeeedddd!!!!
  274.  
  275.  
  276.        +o   Remember not to use "====" when you need "====~~~~"; these two
  277.            constructs are quite different:
  278.  
  279.                $$$$xxxx ====  ////ffffoooooooo////;;;;
  280.                $$$$xxxx ====~~~~ ////ffffoooooooo////;;;;
  281.  
  282.  
  283.        +o   The ddddoooo {{{{}}}} construct isn't a real loop that you can use
  284.            loop control on.
  285.  
  286.        +o   Use _m_y_(_) for local variables whenever you can get away
  287.            with it (but see the _p_e_r_l_f_o_r_m manpage for where you
  288.            can't).  Using _l_o_c_a_l_(_) actually gives a local value to
  289.            a global variable, which leaves you open to unforeseen
  290.            side-effects of dynamic scoping.
  291.  
  292.        +o   If you localize an exported variable in a module, its
  293.            exported value will not change.  The local name
  294.            becomes an alias to a new value but the external name
  295.            is still an alias for the original.
  296.  
  297.        PPPPeeeerrrrllll4444 TTTTrrrraaaappppssss
  298.  
  299.        Penitent Perl 4 Programmers should take note of the
  300.        following incompatible changes that occurred between
  301.        release 4 and release 5:
  302.  
  303.        +o   @@@@ now always interpolates an array in double-quotish
  304.            strings.  Some programs may now need to use backslash
  305.            to protect any @@@@ that shouldn't interpolate.
  306.  
  307.        +o   Barewords that used to look like strings to Perl will
  308.            now look like subroutine calls if a subroutine by that
  309.            name is defined before the compiler sees them.  For
  310.            example:
  311.  
  312.                ssssuuuubbbb SSSSeeeeeeeeYYYYaaaa {{{{ ddddiiiieeee """"HHHHaaaassssttttaaaa llllaaaa vvvviiiissssttttaaaa,,,, bbbbaaaabbbbyyyy!!!!"""" }}}}
  313.                $$$$SSSSIIIIGGGG{{{{''''QQQQUUUUIIIITTTT''''}}}} ==== SSSSeeeeeeeeYYYYaaaa;;;;
  314.  
  315.            In Perl 4, that set the signal handler; in Perl 5, it
  316.            actually calls the function!  You may use the ----wwww
  317.            switch to find such places.
  318.  
  319.        +o   Symbols starting with ____ are no longer forced into
  320.            package mmmmaaaaiiiinnnn, except for $$$$____ itself (and @@@@____, etc.).
  321.  
  322.        +o   Double-colon is now a valid package separator in an
  323.            identifier.  Thus these behave differently in perl4
  324.            vs. perl5:
  325.  
  326.  
  327.  
  328. 30/Jan/96                perl 5.002 with                        5
  329.  
  330.  
  331.  
  332.  
  333.  
  334. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  335.  
  336.  
  337.                pppprrrriiiinnnntttt """"$$$$aaaa::::::::$$$$bbbb::::::::$$$$cccc\\\\nnnn"""";;;;
  338.                pppprrrriiiinnnntttt """"$$$$vvvvaaaarrrr::::::::aaaabbbbcccc::::::::xxxxyyyyzzzz\\\\nnnn"""";;;;
  339.  
  340.  
  341.        +o   ssss''''$$$$llllhhhhssss''''$$$$rrrrhhhhssss'''' now does no interpolation on either side.
  342.            It used to interpolate $$$$llllhhhhssss but not $$$$rrrrhhhhssss.
  343.  
  344.        +o   The second and third arguments of _s_p_l_i_c_e_(_) are now
  345.            evaluated in scalar context (as the book says) rather
  346.            than list context.
  347.  
  348.        +o   These are now semantic errors because of precedence:
  349.  
  350.                sssshhhhiiiifffftttt @@@@lllliiiisssstttt ++++ 22220000;;;;
  351.                $$$$nnnn ==== kkkkeeeeyyyyssss %%%%mmmmaaaapppp ++++ 22220000;;;;
  352.  
  353.            Because if that were to work, then this couldn't:
  354.  
  355.                sssslllleeeeeeeepppp $$$$ddddoooorrrrmmmmaaaannnnccccyyyy ++++ 22220000;;;;
  356.  
  357.  
  358.        +o   The precedence of assignment operators is now the same
  359.            as the precedence of assignment.  Perl 4 mistakenly
  360.            gave them the precedence of the associated operator.
  361.            So you now must parenthesize them in expressions like
  362.  
  363.                ////ffffoooooooo//// ???? (((($$$$aaaa ++++==== 2222)))) :::: (((($$$$aaaa ----==== 2222))));;;;
  364.  
  365.            Otherwise
  366.  
  367.                ////ffffoooooooo//// ???? $$$$aaaa ++++==== 2222 :::: $$$$aaaa ----==== 2222;;;;
  368.  
  369.            would be erroneously parsed as
  370.  
  371.                ((((////ffffoooooooo//// ???? $$$$aaaa ++++==== 2222 :::: $$$$aaaa)))) ----==== 2222;;;;
  372.  
  373.            On the other hand,
  374.  
  375.                $$$$aaaa ++++==== ////ffffoooooooo//// ???? 1111 :::: 2222;;;;
  376.  
  377.            now works as a C programmer would expect.
  378.  
  379.        +o   ooooppppeeeennnn FFFFOOOOOOOO |||||||| ddddiiiieeee is now incorrect.  You need parens
  380.            around the filehandle.  While temporarily supported,
  381.            using such a construct will generate a non-fatal (but
  382.            non-suppressible) warning.
  383.  
  384.        +o   The elements of argument lists for formats are now
  385.            evaluated in list context.  This means you can
  386.            interpolate list values now.
  387.  
  388.        +o   You can't do a ggggoooottttoooo into a block that is optimized
  389.            away.  Darn.
  390.  
  391.  
  392.  
  393.  
  394. 30/Jan/96                perl 5.002 with                        6
  395.  
  396.  
  397.  
  398.  
  399.  
  400. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  401.  
  402.  
  403.        +o   It is no longer syntactically legal to use whitespace
  404.            as the name of a variable, or as a delimiter for any
  405.            kind of quote construct.  Double darn.
  406.  
  407.        +o   The _c_a_l_l_e_r_(_) function now returns a false value in a
  408.            scalar context if there is no caller.  This lets
  409.            library files determine if they're being required.
  410.  
  411.        +o   mmmm////////gggg now attaches its state to the searched string
  412.            rather than the regular expression.
  413.  
  414.        +o   rrrreeeevvvveeeerrrrsssseeee is no longer allowed as the name of a sort
  415.            subroutine.
  416.  
  417.        +o   ttttaaaaiiiinnnnttttppppeeeerrrrllll is no longer a separate executable.  There
  418.            is now a ----TTTT switch to turn on tainting when it isn't
  419.            turned on automatically.
  420.  
  421.        +o   Double-quoted strings may no longer end with an
  422.            unescaped $$$$ or @@@@.
  423.  
  424.        +o   The archaic wwwwhhhhiiiilllleeee////iiiiffff BLOCK BLOCK syntax is no longer
  425.            supported.
  426.  
  427.        +o   Negative array subscripts now count from the end of
  428.            the array.
  429.  
  430.        +o   The comma operator in a scalar context is now
  431.            guaranteed to give a scalar context to its arguments.
  432.  
  433.        +o   The ******** operator now binds more tightly than unary
  434.            minus.  It was documented to work this way before, but
  435.            didn't.
  436.  
  437.        +o   Setting $$$$####aaaarrrrrrrraaaayyyy lower now discards array elements.
  438.  
  439.        +o   _d_e_l_e_t_e_(_) is not guaranteed to return the old value for
  440.            _t_i_e_(_)d arrays, since this capability may be onerous
  441.            for some modules to implement.
  442.  
  443.        +o   The construct "this is $$x" used to interpolate the
  444.            pid at that point, but now tries to dereference $$$$xxxx.
  445.            $$$$$$$$ by itself still works fine, however.
  446.  
  447.        +o   The meaning of foreach has changed slightly when it is
  448.            iterating over a list which is not an array.  This
  449.            used to assign the list to a temporary array, but no
  450.            longer does so (for efficiency).  This means that
  451.            you'll now be iterating over the actual values, not
  452.            over copies of the values.  Modifications to the loop
  453.            variable can change the original values.  To retain
  454.            Perl 4 semantics you need to assign your list
  455.            explicitly to a temporary array and then iterate over
  456.            that.  For example, you might need to change
  457.  
  458.  
  459.  
  460. 30/Jan/96                perl 5.002 with                        7
  461.  
  462.  
  463.  
  464.  
  465.  
  466. PERLTRAP(1)    User Contributed Perl Documentation    PERLTRAP(1)
  467.  
  468.  
  469.                ffffoooorrrreeeeaaaacccchhhh $$$$vvvvaaaarrrr ((((ggggrrrreeeepppp ////xxxx////,,,, @@@@lllliiiisssstttt)))) {{{{ ............ }}}}
  470.  
  471.            to
  472.  
  473.                ffffoooorrrreeeeaaaacccchhhh $$$$vvvvaaaarrrr ((((mmmmyyyy @@@@ttttmmmmpppp ==== ggggrrrreeeepppp ////xxxx////,,,, @@@@lllliiiisssstttt)))) {{{{ ............ }}}}
  474.  
  475.            Otherwise changing $$$$vvvvaaaarrrr will clobber the values of
  476.            @@@@lllliiiisssstttt.  (This most often happens when you use $$$$____ for
  477.            the loop variable, and call subroutines in the loop
  478.            that don't properly localize $$$$____.)
  479.  
  480.        +o   Some error messages will be different.
  481.  
  482.        +o   Some bugs may have been inadvertently removed.
  483.  
  484.  
  485.  
  486.  
  487.  
  488.  
  489.  
  490.  
  491.  
  492.  
  493.  
  494.  
  495.  
  496.  
  497.  
  498.  
  499.  
  500.  
  501.  
  502.  
  503.  
  504.  
  505.  
  506.  
  507.  
  508.  
  509.  
  510.  
  511.  
  512.  
  513.  
  514.  
  515.  
  516.  
  517.  
  518.  
  519.  
  520.  
  521.  
  522.  
  523.  
  524.  
  525.  
  526. 30/Jan/96                perl 5.002 with                        8
  527.  
  528.  
  529.