MarpaX::Languages::ECMAScript::AST - Translate a ECMAScript source to an AST
version 0.020
use strict; use warnings FATAL => 'all'; use MarpaX::Languages::ECMAScript::AST; use Log::Log4perl qw/:easy/; use Log::Any::Adapter; use Log::Any qw/$log/; # # Init log # our $defaultLog4perlConf = ' log4perl.rootLogger = WARN, Screen log4perl.appender.Screen = Log::Log4perl::Appender::Screen log4perl.appender.Screen.stderr = 0 log4perl.appender.Screen.layout = PatternLayout log4perl.appender.Screen.layout.ConversionPattern = %d %-5p %6P %m{chomp}%n '; Log::Log4perl::init(\$defaultLog4perlConf); Log::Any::Adapter->set('Log4perl'); # # Parse ECMAScript # my $ecmaSourceCode = 'var i = 0;'; my $ecmaAstObject = MarpaX::Languages::ECMAScript::AST->new(); $log->infof('%s', $ecmaAstObject->parse($ecmaSourceCode));
This module translates ECMAScript source into an AST tree. If you want to enable logging, be aware that this module is using Log::Any.
Instantiate a new object. Takes as parameter an optional hash of options that can be:
Name of a grammar. Default is 'ECMAScript-262-5'.
Produced AST can be cached: very often the same ECMAScript is used again and again, so there is no need to always compute it at each call. The cache key is the buffer MD4 checksum, eventual collisions being handled. The cache location is the my_dist_data directory provided by File::HomeDir package. Default is a false value.
Any other option that will be specific to the ECMAScript specific implementation. In practice these are:
Reference to a hash for template options. C.f. per-ECMAScript documentation.
Reference to a hash for StringNumericLiteral grammar options. C.f. per-ECMAScript documentation.
Reference to a hash for Pattern grammar options. C.f. per-ECMAScript documentation.
Get a description of the G1 grammar. Returns a reference to hash, that has this structure: key => value, where
'G1' or 'G0', with value being a reference to all rules, LHS being the first.
Returns the grammar alias, i.e. the one that is used within this distribution, corresponding to a true directory on the filesystem.
Returns the templates absolute path.
Get an AST from the ECMAScript source, pointed by $source. This method will call all the intermediary steps (lexical, transformation, evaluation) necessary to produce the AST. An AST is a reference to nested arrays, containing either:
An entry describing a G1 rule (i.e. a non-terminal) is a reference to an array. The array contains the values of the right-hand side of the rule, followed by the rule Id.
An entry describing a lexeme (i.e. a terminal) is a reference to an array. The array contains the start location in the stream, length and lexeme as perl's utf8 string.
Return the generic template for this grammar. This template is doing nothing else but reproduce an ECMAScript source that, if parsed, would have an AST similar to the original source.
Return the generic stringNumericLiteral for this grammar.
Return the generic Pattern for this grammar.
Return the generic JSON for this grammar.
Return the generic URI for this grammar.
Log::Any
Marpa::R2
Digest::MD4
CHI::Driver::File
MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5
Please report any bugs or feature requests through the issue tracker at https://rt.cpan.org/Public/Dist/Display.html?Name=MarpaX-Languages-ECMAScript-AST. You will be notified automatically of any progress on your issue.
This is open source software. The code repository is available for public review and contribution under the terms of the license.
https://github.com/jddurand/marpax-languages-ecmascript-ast
git clone git://github.com/jddurand/marpax-languages-ecmascript-ast.git
Jean-Damien Durand <jeandamiendurand@free.fr>
jddurand <jeandamiendurand@free.fr>
This software is copyright (c) 2013 by Jean-Damien Durand.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
To install MarpaX::Languages::ECMAScript::AST, copy and paste the appropriate command in to your terminal.
cpanm
cpanm MarpaX::Languages::ECMAScript::AST
CPAN shell
perl -MCPAN -e shell install MarpaX::Languages::ECMAScript::AST
For more information on module installation, please visit the detailed CPAN module installation guide.