package multidimensional; # ABSTRACT: disables multidimensional array emulation $multidimensional::VERSION = '0.014'; { use 5.008001; } use strict; use warnings; use if "$]" < 5.012, 'Lexical::SealRequireHints'; use B::Hooks::OP::Check 0.19; use XSLoader; XSLoader::load( __PACKAGE__, # we need to be careful not to touch $VERSION at compile time, otherwise # DynaLoader will assume it's set and check against it, which will cause # fail when being run in the checkout without dzil having set the actual # $VERSION exists $multidimensional::{VERSION} ? ${ $multidimensional::{VERSION} } : (), ); sub unimport { $^H |= 0x20000; $^H{__PACKAGE__.'/disabled'} = 1 } sub import { delete $^H{__PACKAGE__.'/disabled'} } 1; __END__ =pod =encoding UTF-8 =head1 NAME multidimensional - disables multidimensional array emulation =head1 VERSION version 0.014 =head1 SYNOPSIS no multidimensional; $hash{1, 2}; # dies $hash{join($;, 1, 2)}; # doesn't die =head1 DESCRIPTION Perl's multidimensional array emulation stems from the days before the language had references, but these days it mostly serves to bite you when you typo a hash slice by using the C<$> sigil instead of C<@>. This module lexically makes using multidimensional array emulation a fatal error at compile time. =head1 METHODS =head2 unimport Disables multidimensional array emulation for the remainder of the scope being compiled. =head2 import Enables multidimensional array emulation for the remainder of the scope being compiled; =head1 SEE ALSO L, L. =head1 AUTHOR Dagfinn Ilmari Mannsåker =head1 COPYRIGHT AND LICENSE This software is copyright (c) 2010 - 2016 by Dagfinn Ilmari Mannsåker. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself. =cut