logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

Compiler::Lexer - Lexical Analyzer for Perl5

Author

       Masaaki Goshima (goccy) <goccy(at)cpan.org>

Contributors

       tokuhirom: Tokuhiro Matsuno

Methods

       my $lexer = Compiler::Lexer->new($options);
           create new instance.  You can create object from $options in hash reference.

           optionslist

           filename
           verbose : includes token of Pod, Comment and WhiteSpace
       $lexer->tokenize($script);
           get  token  objects includes parameter of 'name' or 'type' or 'line' and so on.  This method requires
           perl source code in string.

       $lexer->set_library_path(['path1', 'path2' ...])
           set libraries path for reading recursively. Default paths are @INC.

       $lexer->recursive_tokenize($script)
           get hash reference like { 'module_nameA' => [], 'module_nameB' => [] ... }.  This method requires per
           source code in string.

       $lexer->get_used_modules($script);
           get names of used module.  This method requires perl source code in string.

Name

       Compiler::Lexer - Lexical Analyzer for Perl5

Synopsis

         use Compiler::Lexer;
         use Data::Dumper;

         my $filename = $ARGV[0];
         open my $fh, '<', $filename or die "Cannot open $filename: $!";
         my $script = do { local $/; <$fh> };

         my $lexer = Compiler::Lexer->new($filename);
         my $tokens = $lexer->tokenize($script);
         print Dumper $tokens;

         my $modules = $lexer->get_used_modules($script);
         print Dumper $modules;

See Also