line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
1
|
|
|
1
|
|
8
|
use strict; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
43
|
|
2
|
1
|
|
|
1
|
|
7
|
use warnings FATAL => 'all'; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
65
|
|
3
|
|
|
|
|
|
|
|
4
|
|
|
|
|
|
|
package MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Pattern; |
5
|
1
|
|
|
1
|
|
5
|
use parent qw/MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Base/; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
22
|
|
6
|
1
|
|
|
1
|
|
889
|
use MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Pattern::Semantics; |
|
1
|
|
|
|
|
4
|
|
|
1
|
|
|
|
|
41
|
|
7
|
1
|
|
|
1
|
|
9
|
use MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::CharacterClasses; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
24
|
|
8
|
1
|
|
|
1
|
|
7
|
use SUPER; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
59
|
|
9
|
1
|
|
|
1
|
|
7
|
use Carp qw/croak/; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
46
|
|
10
|
1
|
|
|
1
|
|
7
|
use Scalar::Util qw/blessed/; |
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
633
|
|
11
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
# ABSTRACT: ECMAScript-262, Edition 5, pattern grammar written in Marpa BNF |
13
|
|
|
|
|
|
|
|
14
|
|
|
|
|
|
|
our $VERSION = '0.018'; # VERSION |
15
|
|
|
|
|
|
|
|
16
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
# |
18
|
|
|
|
|
|
|
# Note that this grammar is NOT supposed to be injected in Program |
19
|
|
|
|
|
|
|
# |
20
|
|
|
|
|
|
|
our $grammar_content = do {local $/; }; |
21
|
|
|
|
|
|
|
|
22
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
sub new { |
24
|
0
|
|
|
0
|
1
|
|
my ($class, $optionsp) = @_; |
25
|
|
|
|
|
|
|
|
26
|
0
|
|
0
|
|
|
|
$optionsp //= {}; |
27
|
|
|
|
|
|
|
|
28
|
0
|
0
|
|
|
|
|
my $semantics_package = exists($optionsp->{semantics_package}) ? $optionsp->{semantics_package} : join('::', $class, 'Semantics'); |
29
|
|
|
|
|
|
|
|
30
|
0
|
|
|
|
|
|
my $self = $class->SUPER(); |
31
|
|
|
|
|
|
|
|
32
|
|
|
|
|
|
|
# |
33
|
|
|
|
|
|
|
# Add semantics package to self |
34
|
|
|
|
|
|
|
# |
35
|
0
|
|
|
|
|
|
$self->{_semantics_package} = $semantics_package; |
36
|
|
|
|
|
|
|
# |
37
|
|
|
|
|
|
|
# Add tracking of disjunction positions |
38
|
|
|
|
|
|
|
# |
39
|
0
|
|
|
|
|
|
$self->{_lparen} = []; |
40
|
|
|
|
|
|
|
|
41
|
0
|
|
|
|
|
|
return $self; |
42
|
|
|
|
|
|
|
} |
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
|
45
|
|
|
|
|
|
|
sub make_grammar_content { |
46
|
0
|
|
|
0
|
1
|
|
my ($class) = @_; |
47
|
0
|
|
|
|
|
|
return $grammar_content; |
48
|
|
|
|
|
|
|
} |
49
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
sub lparen { |
52
|
0
|
|
|
0
|
1
|
|
my ($self) = @_; |
53
|
|
|
|
|
|
|
|
54
|
0
|
|
|
|
|
|
return $self->{_lparen}; |
55
|
|
|
|
|
|
|
} |
56
|
|
|
|
|
|
|
|
57
|
|
|
|
|
|
|
|
58
|
|
|
|
|
|
|
sub recce_option { |
59
|
0
|
|
|
0
|
1
|
|
my ($self) = @_; |
60
|
|
|
|
|
|
|
# |
61
|
|
|
|
|
|
|
# Get default hash |
62
|
|
|
|
|
|
|
# |
63
|
0
|
|
|
|
|
|
my $default = $self->SUPER(); |
64
|
|
|
|
|
|
|
# |
65
|
|
|
|
|
|
|
# And overwrite the semantics_package |
66
|
|
|
|
|
|
|
# |
67
|
0
|
|
|
|
|
|
$default->{semantics_package} = $self->{_semantics_package}; |
68
|
|
|
|
|
|
|
|
69
|
0
|
|
|
|
|
|
return $default; |
70
|
|
|
|
|
|
|
} |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
|
73
|
|
|
|
|
|
|
sub parse { |
74
|
0
|
|
|
0
|
1
|
|
my ($self, $source, $impl) = @_; |
75
|
|
|
|
|
|
|
# |
76
|
|
|
|
|
|
|
# Reset tracking of disjunction positions |
77
|
|
|
|
|
|
|
# |
78
|
0
|
|
|
|
|
|
$self->{_lparen} = []; |
79
|
0
|
|
|
|
|
|
return $self->SUPER($source, $impl, |
80
|
|
|
|
|
|
|
{ |
81
|
|
|
|
|
|
|
callback => \&_eventCallback, |
82
|
|
|
|
|
|
|
callbackargs => [ $self ], |
83
|
|
|
|
|
|
|
}); |
84
|
|
|
|
|
|
|
} |
85
|
|
|
|
|
|
|
|
86
|
|
|
|
|
|
|
sub _eventCallback { |
87
|
0
|
|
|
0
|
|
|
my ($self, $source, $pos, $max, $impl) = @_; |
88
|
|
|
|
|
|
|
|
89
|
|
|
|
|
|
|
# |
90
|
|
|
|
|
|
|
# $pos is the exact position where SLIF stopped because of an event |
91
|
|
|
|
|
|
|
# |
92
|
0
|
|
|
|
|
|
my $rc = $pos; |
93
|
|
|
|
|
|
|
|
94
|
0
|
|
|
|
|
|
foreach (@{$impl->events()}) { |
|
0
|
|
|
|
|
|
|
95
|
0
|
|
|
|
|
|
my ($name) = @{$_}; |
|
0
|
|
|
|
|
|
|
96
|
|
|
|
|
|
|
# |
97
|
|
|
|
|
|
|
# Events are always in this order: |
98
|
|
|
|
|
|
|
# |
99
|
|
|
|
|
|
|
# --------------------------------- |
100
|
|
|
|
|
|
|
# 1. Completion events first (XXX$) |
101
|
|
|
|
|
|
|
# --------------------------------- |
102
|
|
|
|
|
|
|
# |
103
|
0
|
0
|
|
|
|
|
if ($name eq 'LPAREN_ATOM_DISJUNCTION$') { |
104
|
|
|
|
|
|
|
# |
105
|
|
|
|
|
|
|
# By definition, the current position here is exactly |
106
|
|
|
|
|
|
|
# after the '(', so position in the stream of this |
107
|
|
|
|
|
|
|
# lexeme is $pos-1. |
108
|
0
|
|
|
|
|
|
push(@{$self->{_lparen}}, $pos-1); |
|
0
|
|
|
|
|
|
|
109
|
|
|
|
|
|
|
} |
110
|
|
|
|
|
|
|
} |
111
|
|
|
|
|
|
|
|
112
|
0
|
|
|
|
|
|
return $rc; |
113
|
|
|
|
|
|
|
} |
114
|
|
|
|
|
|
|
|
115
|
|
|
|
|
|
|
|
116
|
|
|
|
|
|
|
sub value { |
117
|
0
|
|
|
0
|
1
|
|
my ($self, $impl) = @_; |
118
|
|
|
|
|
|
|
|
119
|
|
|
|
|
|
|
# |
120
|
|
|
|
|
|
|
# Left-parenthesis locations, so that they are visible when Marpa will call |
121
|
|
|
|
|
|
|
# semantics_package's new(). |
122
|
|
|
|
|
|
|
# |
123
|
0
|
|
|
|
|
|
local $MarpaX::Languages::ECMAScript::AST::Grammar::Pattern::lparen = $self->{_lparen}; |
124
|
|
|
|
|
|
|
|
125
|
0
|
|
|
|
|
|
return $self->SUPER($impl); |
126
|
|
|
|
|
|
|
} |
127
|
|
|
|
|
|
|
|
128
|
|
|
|
|
|
|
|
129
|
|
|
|
|
|
|
|
130
|
|
|
|
|
|
|
1; |
131
|
|
|
|
|
|
|
|
132
|
|
|
|
|
|
|
=pod |
133
|
|
|
|
|
|
|
|
134
|
|
|
|
|
|
|
=encoding utf-8 |
135
|
|
|
|
|
|
|
|
136
|
|
|
|
|
|
|
=head1 NAME |
137
|
|
|
|
|
|
|
|
138
|
|
|
|
|
|
|
MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Pattern - ECMAScript-262, Edition 5, pattern grammar written in Marpa BNF |
139
|
|
|
|
|
|
|
|
140
|
|
|
|
|
|
|
=head1 VERSION |
141
|
|
|
|
|
|
|
|
142
|
|
|
|
|
|
|
version 0.018 |
143
|
|
|
|
|
|
|
|
144
|
|
|
|
|
|
|
=head1 SYNOPSIS |
145
|
|
|
|
|
|
|
|
146
|
|
|
|
|
|
|
use strict; |
147
|
|
|
|
|
|
|
use warnings FATAL => 'all'; |
148
|
|
|
|
|
|
|
use MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Pattern; |
149
|
|
|
|
|
|
|
|
150
|
|
|
|
|
|
|
my $grammar = MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Pattern->new(); |
151
|
|
|
|
|
|
|
|
152
|
|
|
|
|
|
|
my $grammar_content = $grammar->content(); |
153
|
|
|
|
|
|
|
my $grammar_option = $grammar->grammar_option(); |
154
|
|
|
|
|
|
|
my $recce_option = $grammar->recce_option(); |
155
|
|
|
|
|
|
|
|
156
|
|
|
|
|
|
|
=head1 DESCRIPTION |
157
|
|
|
|
|
|
|
|
158
|
|
|
|
|
|
|
This modules returns describes the ECMAScript 262, Edition 5 pattern grammar written in Marpa BNF, as of L, section 15.10.1. This module inherits the methods from MarpaX::Languages::ECMAScript::AST::Grammar::ECMAScript_262_5::Base package. |
159
|
|
|
|
|
|
|
|
160
|
|
|
|
|
|
|
=head1 SUBROUTINES/METHODS |
161
|
|
|
|
|
|
|
|
162
|
|
|
|
|
|
|
=head2 new($optionsp) |
163
|
|
|
|
|
|
|
|
164
|
|
|
|
|
|
|
$optionsp is a reference to hash that may contain the following key/value pair: |
165
|
|
|
|
|
|
|
|
166
|
|
|
|
|
|
|
=over |
167
|
|
|
|
|
|
|
|
168
|
|
|
|
|
|
|
=item semantics_package |
169
|
|
|
|
|
|
|
|
170
|
|
|
|
|
|
|
As per Marpa::R2, The semantics package is used when resolving action names to fully qualified Perl names. This package must support and behave as documented in the Semantics package (c.f. SEE ALSO). |
171
|
|
|
|
|
|
|
|
172
|
|
|
|
|
|
|
=back |
173
|
|
|
|
|
|
|
|
174
|
|
|
|
|
|
|
=head2 make_grammar_content($class) |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
Returns the grammar. This will be injected in the Program's grammar. |
177
|
|
|
|
|
|
|
|
178
|
|
|
|
|
|
|
=head2 lparen($self) |
179
|
|
|
|
|
|
|
|
180
|
|
|
|
|
|
|
Returns current lexer left parenthesis offsets of captures. |
181
|
|
|
|
|
|
|
|
182
|
|
|
|
|
|
|
=head2 recce_option($self) |
183
|
|
|
|
|
|
|
|
184
|
|
|
|
|
|
|
Returns option for Marpa::R2::Scanless::R->new(), returned as a reference to a hash. |
185
|
|
|
|
|
|
|
|
186
|
|
|
|
|
|
|
=head2 parse($self, $source, $impl) |
187
|
|
|
|
|
|
|
|
188
|
|
|
|
|
|
|
Parse the source given as $source using implementation $impl. |
189
|
|
|
|
|
|
|
|
190
|
|
|
|
|
|
|
=head2 value($self, $impl) |
191
|
|
|
|
|
|
|
|
192
|
|
|
|
|
|
|
Return the parse tree (unique) value. $impl is the recognizer instance for the grammar. Will raise an InternalError exception if there is no parse tree value, or more than one parse tree value. Please note that this method explicity destroys the recognizer using $impl->destroy_R. Value itself is an AST where every string is a perl string. This a subclass of MarpaX::Languages::ECMAScript::AST::Grammar::Base::value() because the position of disjunction left parenthesis is localized, so that value() will see them. |
193
|
|
|
|
|
|
|
|
194
|
|
|
|
|
|
|
This method is explicitely setting a localized MarpaX::Languages::ECMAScript::AST::Grammar::Pattern::lparen variable that is an array reference of all disjunctions left parenthesis locations in the regular expression perl string. |
195
|
|
|
|
|
|
|
|
196
|
|
|
|
|
|
|
=head1 SEE ALSO |
197
|
|
|
|
|
|
|
|
198
|
|
|
|
|
|
|
L |
199
|
|
|
|
|
|
|
|
200
|
|
|
|
|
|
|
L |
201
|
|
|
|
|
|
|
|
202
|
|
|
|
|
|
|
=head1 AUTHOR |
203
|
|
|
|
|
|
|
|
204
|
|
|
|
|
|
|
Jean-Damien Durand |
205
|
|
|
|
|
|
|
|
206
|
|
|
|
|
|
|
=head1 COPYRIGHT AND LICENSE |
207
|
|
|
|
|
|
|
|
208
|
|
|
|
|
|
|
This software is copyright (c) 2013 by Jean-Damien Durand. |
209
|
|
|
|
|
|
|
|
210
|
|
|
|
|
|
|
This is free software; you can redistribute it and/or modify it under |
211
|
|
|
|
|
|
|
the same terms as the Perl 5 programming language system itself. |
212
|
|
|
|
|
|
|
|
213
|
|
|
|
|
|
|
=cut |
214
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
__DATA__ |