NAME

    Perl::Critic::Policy::Plicease::ProhibitArrayAssignAref - Don't assign
    an anonymous arrayref to an array

VERSION

    version 100.00

DESCRIPTION

    This policy is a fork of
    Perl::Critic::Policy::ValuesAndExpressions::ProhibitArrayAssignAref. It
    differs from the original by not having a dependency on
    List::MoreUtils. It is unfortunately still licensed as GPL3.

    It asks you not to assign an anonymous arrayref to an array

        @array = [ 1, 2, 3 ];       # bad

    The idea is that it's rather unclear whether an arrayref is intended,
    or might have meant to be a list like

        @array = ( 1, 2, 3 );

    This policy is under the "bugs" theme (see "POLICY THEMES" in
    Perl::Critic) for the chance [] is a mistake, and since even if it's
    correct it will likely make anyone reading it wonder.

    A single arrayref can still be assigned to an array, but with parens to
    make it clear,

        @array = ( [1,2,3] );       # ok

    Dereferences or array and hash slices (see "Slices" in perldata) are
    recognised as an array target and treated similarly,

        @$ref = [1,2,3];            # bad assign to deref
        @{$ref} = [1,2,3];          # bad assign to deref
        @x[1,2,3] = ['a','b','c'];  # bad assign to array slice
        @x{'a','b'} = [1,2];        # bad assign to hash slice

 List Assignment Parens

    This policy is not a blanket requirement for () parens on array
    assignments. It's normal and unambiguous to have a function call or
    grep etc without parens.

        @array = foo();                    # ok
        @array = grep {/\.txt$/} @array;   # ok

    The only likely problem from lack of parens in such cases is that the ,
    comma operator has lower precedence than = (see perlop), so something
    like

        @array = 1,2,3;   # oops, not a list

    means

        @array = (1);
        2;
        3;

    Normally the remaining literals in void context provoke a warning from
    Perl itself.

    An intentional single element assignment is quite common as a
    statement, for instance

        @ISA = 'My::Parent::Class';   # ok

    And for reference the range operator precedence is high enough,

        @array = 1..10;               # ok

    But of course parens are needed if concatenating some disjoint ranges
    with the comma operator,

        @array = (1..5, 10..15);      # parens needed

    The qw form gives a list too

        @array = qw(a b c);           # ok

SEE ALSO

    Perl::Critic

    Perl::Critic::Policy::ValuesAndExpressions::ProhibitArrayAssignAref

HOME PAGE

    https://github.com/uperl/Perl-Critic-Policy-Plicease-ProhibitArrayAssignAref

COPYRIGHT

    Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2019, 2021 Kevin
    Ryde

    Perl-Critic-Policy-Plicease-ProhibitArrayAssignAref is free software;
    you can redistribute it and/or modify it under the terms of the GNU
    General Public License as published by the Free Software Foundation;
    either version 3, or (at your option) any later version.

    Perl-Critic-Policy-Plicease-ProhibitArrayAssignAref is distributed in
    the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
    the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
    PURPOSE. See the GNU General Public License for more details.

    You should have received a copy of the GNU General Public License along
    with Perl-Critic-Policy-Plicease-ProhibitArrayAssignAref. If not, see
    <http://www.gnu.org/licenses>.

AUTHOR

    Original author: Kevin Ryde

    Current maintainer: Graham Ollis <plicease@cpan.org>

COPYRIGHT AND LICENSE

    This software is Copyright (c) 2011-2021 by Kevin Ryde.

    This is free software, licensed under:

      The GNU General Public License, Version 3, June 2007