/[suikacvs]/webroot/regexp/lib/Regexp/Parser/JavaScript.html
Suika

Contents of /webroot/regexp/lib/Regexp/Parser/JavaScript.html

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (show annotations) (download) (as text)
Sun Mar 8 14:30:51 2009 UTC (15 years, 7 months ago) by wakaba
Branch: MAIN
CVS Tags: HEAD
File MIME type: text/html
++ swe/lib/Regexp/Parser/ChangeLog	8 Mar 2009 14:30:01 -0000
2009-03-08  Wakaba  <wakaba@suika.fam.cx>

	* Makefile: New file.

	* JavaScript.pod, Perl58.pod: New documentations.

++ swe/lib/ChangeLog	8 Mar 2009 14:29:22 -0000
2009-03-08  Wakaba  <wakaba@suika.fam.cx>

	* .htaccess: New file.

1 <?xml version="1.0" ?>
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml">
4 <head>
5 <title>Regexp::Parser::JavaScript - A Regexp::Parser Subclass for JavaScript
6 Regular Expressions</title>
7 <link rel="stylesheet" href="http://suika.fam.cx/www/style/html/pod.css" type="text/css" />
8 <meta http-equiv="content-type" content="text/html; charset=utf-8" />
9 <link rev="made" href="mailto:wakaba@suika.fam.cx" />
10 </head>
11
12 <body>
13
14
15 <!-- INDEX BEGIN -->
16 <div name="index">
17 <p><a name="__index__"></a></p>
18
19 <ul>
20
21 <li><a href="#name">NAME</a></li>
22 <li><a href="#synopsis">SYNOPSIS</a></li>
23 <li><a href="#description">DESCRIPTION</a></li>
24 <li><a href="#methods">METHODS</a></li>
25 <li><a href="#error_types">ERROR TYPES</a></li>
26 <li><a href="#dependency">DEPENDENCY</a></li>
27 <li><a href="#see_also">SEE ALSO</a></li>
28 <li><a href="#development">DEVELOPMENT</a></li>
29 <li><a href="#author">AUTHOR</a></li>
30 <li><a href="#license">LICENSE</a></li>
31 </ul>
32
33 <hr name="index" />
34 </div>
35 <!-- INDEX END -->
36
37 <p>
38 </p>
39 <h1><a name="name">NAME</a></h1>
40 <p>Regexp::Parser::JavaScript - A Regexp::Parser Subclass for JavaScript
41 Regular Expressions</p>
42 <p>
43 </p>
44 <hr />
45 <h1><a name="synopsis">SYNOPSIS</a></h1>
46 <pre>
47 use Regexp::Parser::JavaScript;
48
49 my $parser = Regexp::Parser::JavaScript-&gt;new;
50
51 my @error;
52
53 ## Prepare a callback function invoked whenever an error or warning
54 ## is raised by the parser.
55 $parser-&gt;onerror (sub {
56 my %args = @_;
57
58 my $error_message = '';
59 if ($args{level} eq 'w') {
60 $error_message .= 'Warning: ';
61 } else {
62 $error_message .= 'Error: ';
63 }
64
65 $error_message .= sprintf $args{type}, @{$args{args}};
66
67 $error_message .= ' (';
68 $error_message .= substr ${$args{valueref}},
69 $args{pos_start}, $args{pos_end} - $args{pos_start};
70 $error_message .= ')';
71
72 $error_message .= &quot;\n&quot;;
73
74 push @error, $error_message;
75 });
76
77 ## Parse the regular expression given as a string.
78 ## Use |eval| to catch an exception that would be thrown if the
79 ## regular expression contains a fatal error.
80 eval {
81 $parser-&gt;parse ($regexp_as_string);
82 };
83
84 if ($parser-&gt;errnum) {
85 ## @error contains at least one fatal error.
86 warn @error;
87 } else {
88 ## @error contains no fatal error.
89 warn @error;
90
91 ## Now, $parser-&gt;root contains the root node of the parsed regular
92 ## expression tree. See |perldoc Regexp::Parser| for more information.
93 }</pre>
94 <p>
95 </p>
96 <hr />
97 <h1><a name="description">DESCRIPTION</a></h1>
98 <p>The <code>Regexp::Parser::JavaScript</code> modules provides a subclass of the
99 <code>Regexp::Parser</code>, a regular expression parser module. The
100 <code>Regexp::Parser::JavaScript</code> module provides an implementation of the
101 parser for the regular expression language as defined by ECMA 376
102 Third Edition (the ECMAScript specification), modified for
103 compatibility with Web browser implementations.</p>
104 <p>Apart from this additional function, this module provides the same
105 interface as the one applied by the <code>Regexp::Parser::Perl58</code> module.
106 For more information, see <a href="../../Regexp/Parser/Perl58.html">the Regexp::Parser::Perl58 manpage</a>.</p>
107 <p>
108 </p>
109 <hr />
110 <h1><a name="methods">METHODS</a></h1>
111 <p>The <code>Regexp::Parser::JavaScript</code> module provides same methods as
112 <code>Regexp::Parser::JavaScript</code>. See <a href="../../Regexp/Parser/Perl58.html">the Regexp::Parser::Perl58 manpage</a>.</p>
113 <p>
114 </p>
115 <hr />
116 <h1><a name="error_types">ERROR TYPES</a></h1>
117 <p>The <code>Regexp::Parser::JavaScript</code> module reports same kinds of errors
118 as the <code>Regexp::Parser</code> module does to the callback function
119 specified by the <code>onerror</code> method, if any. In addition, it might
120 also have an additional error type: <a href="#rpjse_octesc"><code>RPJSe_OCTESC</code></a>.</p>
121 <dl>
122 <dt><strong><a name="rpjse_octesc" class="item">RPJSe_OCTESC</a></strong>
123
124 <dd>
125 <p>This error is reported when an octal escape sequence is used in the
126 regular expression. The octal escape sequence is <em>not</em> part of the
127 ECMAScript specification though it is supported by Web browsers for
128 backward compatibility.</p>
129 </dd>
130 </li>
131 </dl>
132 <p>
133 </p>
134 <hr />
135 <h1><a name="dependency">DEPENDENCY</a></h1>
136 <p>This module requires Perl 5.10.0 or later.</p>
137 <p>This module depends on <code>Regexp::Parser</code> and <code>Regexp::Parser::Perl58</code>
138 modules.</p>
139 <p>
140 </p>
141 <hr />
142 <h1><a name="see_also">SEE ALSO</a></h1>
143 <p>The latest version of this module is available at
144 <a href="http://suika.fam.cx/regexp/">http://suika.fam.cx/regexp/</a>.</p>
145 <p>Regular expression visualizer
146 <a href="http://suika.fam.cx/regexp/visualizer/input">http://suika.fam.cx/regexp/visualizer/input</a>. It uses this module
147 to parse Perl 5.8 regular expressions.</p>
148 <p><a href="../../Regexp/Parser.html">the Regexp::Parser manpage</a> - A superclass, available from CPAN.</p>
149 <p><a href="../../Regexp/Parser/Perl58.html">the Regexp::Parser::Perl58 manpage</a> - A superclass.</p>
150 <p>
151 </p>
152 <hr />
153 <h1><a name="development">DEVELOPMENT</a></h1>
154 <p>CVS log:
155 <a href="http://suika.fam.cx/regexp/lib/Regexp/Parser/JavaScript.pm,cvslog">http://suika.fam.cx/regexp/lib/Regexp/Parser/JavaScript.pm,cvslog</a>.</p>
156 <p>Bug tracking system: <a href="http://manakai.g.hatena.ne.jp/task/7/">http://manakai.g.hatena.ne.jp/task/7/</a>.</p>
157 <p>
158 </p>
159 <hr />
160 <h1><a name="author">AUTHOR</a></h1>
161 <p>Wakaba &lt;<a href="mailto:w@suika.fam.cx">w@suika.fam.cx</a>&gt;.</p>
162 <p>
163 </p>
164 <hr />
165 <h1><a name="license">LICENSE</a></h1>
166 <p>Copyright 2008-2009 Wakaba &lt;<a href="mailto:w@suika.fam.cx">w@suika.fam.cx</a>&gt;.</p>
167 <p>This library is free software; you can redistribute it and/or modify
168 it under the same terms as Perl itself.</p>
169
170 </body>
171
172 </html>

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24