- COPYRIGHT & LICENSE
Perl::Critic::Policy::CodeLayout::TabIndentSpaceAlign - Use tabs for indenting, spaces for aligning.
This is a standalone policy not part of a larger PerlCritic Policies group.
Hard tabs are a perfectly fine way to indent code for accessibility and usability purposes, allowing different users to tweak indentation settings to suit their needs and habits. However, hard tabs should not be used for formatting / aligning, as this makes the display dependent on the tab-to-space ratio of the user.
Perl/Critic/Policy/CodeLayout/ProhibitHardTabs has a setting that allows leading tabs, but this not not fully represent the paradigm where tabs are reserved for indenting and spaces for formatting/aligning. In particular, it does not prevent indenting with spaces, while this module detects and prevents it.
This Policy examines your source code, including POD, quotes, and HEREDOCs. The contents of the
__DATA__ section are not examined.
There is no configuration option available for this policy.
Beware that Perl::Critic may report the location of the string that contains the tab, not the actual location of the tab, so you may need to do some hunting.
Return an array with information about the parameters supported.
my @supported_parameters = $policy->supported_parameters();
Return the default severify for this policy.
my $default_severity = $policy->default_severity();
Return the default themes this policy is included in.
my $default_themes = $policy->default_themes();
Return the class of elements this policy applies to.
my $class = $policy->applies_to();
Check an element for violations against this policy.
my $policy->violates( $element, $document, );
Return a boolean indicating if a multiline string has violations against this policy.
my $string_has_violations = _has_violations_in_multiline_string( $string );
Please report any bugs or feature requests through the web interface at https://github.com/guillaumeaubert/Perl-Critic-Policy-CodeLayout-TabIndentSpaceAlign/issues. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
You can find documentation for this module with the perldoc command.
You can also look for information at:
GitHub (report bugs there)
AnnoCPAN: Annotated CPAN documentation
<aubertg at cpan.org>.
I originally developed this project for ThinkGeek (http://www.thinkgeek.com/). Thanks for allowing me to open-source it!
Copyright 2012-2014 Guillaume Aubert.
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License version 3 as published by the Free Software Foundation.
This program 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 this program. If not, see http://www.gnu.org/licenses/