Provided by: libperl-critic-perl_1.134-1_all bug


       Perl::Critic::Policy::BuiltinFunctions::ProhibitComplexMappings - Map blocks should have a
       single statement.


       This Policy is part of the core Perl::Critic distribution.


       The map function can be confusing to novices in the best of circumstances.  Mappings with
       multiple statements are even worse.  They're also a maintainer's nightmare because any
       added complexity decreases readability precipitously.  Why?  Because map is traditionally
       a one-liner converting one array to another.  Trying to cram lots of functionality into a
       one-liner is a bad idea in general.

       The best solutions to a complex mapping are: 1) write a subroutine that performs the
       manipulation and call that from map; 2) rewrite the map as a for loop.


       This policy currently misses some compound statements inside of the map.  For example, the
       following code incorrectly does not trigger a violation:

           map { do { foo(); bar() } } @list


       By default this policy flags any mappings with more than one statement.  While we do not
       recommend it, you can increase this limit as follows in a .perlcriticrc file:

           max_statements = 2


       Chris Dolan <>


       Initial development of this policy was supported by a grant from the Perl Foundation.


       Copyright (c) 2007-2011 Chris Dolan.

       This program is free software; you can redistribute it and/or modify it under the same
       terms as Perl itself.

perl v5.28.1                 Perl::Critic::Policy::BuiltinFunctions::ProhibitComplexMappings(3pm)