NAME
PPIx::EditorTools::RenameVariable - Lexically replace a variable name in Perl code
VERSION
version 0.21
SYNOPSIS
my $munged = PPIx::EditorTools::RenameVariable->new->rename(
code => $code,
line => 15,
column => 13,
replacement => 'stuff',
);
my $code_as_strig = $munged->code;
my $code_as_ppi = $munged->ppi;
my $location = $munged->element->location;
DESCRIPTION
This module will lexically replace a variable name.
METHODS
- new()
-
Constructor. Generally shouldn't be called with any arguments.
- rename( ppi => PPI::Document $ppi, line => Int, column => Int, replacement => Str )
- rename( code => Str $code, line => Int, column => Int, replacement => Str )
- rename( code => Str $code, line => Int, column => Int, to_camel_case => Bool, [ucfirst => Bool] )
- rename( code => Str $code, line => Int, column => Int, from_camel_case => Bool, [ucfirst => Bool] )
-
Accepts either a
PPI::Documentto process or a string containing the code (which will be converted into aPPI::Document) to process. Renames the variable found at line, column with that supplied in thereplacementparameter and returns aPPIx::EditorTools::ReturnObjectwith the new code available via theppiorcodeaccessors, as aPPI::Documentorstring, respectively. ThePPI::Tokenfound at line, column is available via theelementaccessor.Instead of specifying an explicit replacement variable name, you may choose to use the
to_camel_caseorfrom_camel_caseoptions that automatically convert to/from camelCase. In that mode, theucfirstoption will force uppercasing of the first letter.You can not specify a replacement name and use the
to/from_camel_caseoptions.Croaks with a "no token" exception if no token is found at the location. Croaks with a "no declaration" exception if unable to find the declaration.
SEE ALSO
This class inherits from PPIx::EditorTools. Also see App::EditorTools, Padre, and PPI.
AUTHORS
Steffen Mueller
smueller@cpan.orgMark Grimes
mgrimes@cpan.orgAhmad M. Zawawi <ahmad.zawawi@gmail.com>
Gabor Szabo <gabor@szabgab.com>
Yanick Champoux <yanick@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2017, 2014, 2012 by The Padre development team as listed in Padre.pm..
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.