KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jruby > parser > Parser


1 /***** BEGIN LICENSE BLOCK *****
2  * Version: CPL 1.0/GPL 2.0/LGPL 2.1
3  *
4  * The contents of this file are subject to the Common Public
5  * License Version 1.0 (the "License"); you may not use this file
6  * except in compliance with the License. You may obtain a copy of
7  * the License at http://www.eclipse.org/legal/cpl-v10.html
8  *
9  * Software distributed under the License is distributed on an "AS
10  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
11  * implied. See the License for the specific language governing
12  * rights and limitations under the License.
13  *
14  * Copyright (C) 2002-2004 Anders Bengtsson <ndrsbngtssn@yahoo.se>
15  * Copyright (C) 2002-2004 Jan Arne Petersen <jpetersen@uni-bonn.de>
16  * Copyright (C) 2004 Thomas E Enebo <enebo@acm.org>
17  * Copyright (C) 2004 Stefan Matthias Aust <sma@3plus4.de>
18  *
19  * Alternatively, the contents of this file may be used under the terms of
20  * either of the GNU General Public License Version 2 or later (the "GPL"),
21  * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
22  * in which case the provisions of the GPL or the LGPL are applicable instead
23  * of those above. If you wish to allow use of your version of this file only
24  * under the terms of either the GPL or the LGPL, and not to allow others to
25  * use your version of this file under the terms of the CPL, indicate your
26  * decision by deleting the provisions above and replace them with the notice
27  * and other provisions required by the GPL or the LGPL. If you do not delete
28  * the provisions above, a recipient may use your version of this file under
29  * the terms of any one of the CPL, the GPL or the LGPL.
30  ***** END LICENSE BLOCK *****/

31 package org.jruby.parser;
32
33 import java.io.Reader JavaDoc;
34 import java.io.StringReader JavaDoc;
35
36 import org.jruby.Ruby;
37 import org.jruby.RubyFile;
38 import org.jruby.ast.Node;
39 import org.jruby.lexer.yacc.LexerSource;
40 import org.jruby.lexer.yacc.SyntaxException;
41 import org.jruby.runtime.DynamicScope;
42 import org.jruby.runtime.ThreadContext;
43 import org.jruby.util.collections.SinglyLinkedList;
44
45 /**
46  * Serves as a simple facade for all the parsing magic.
47  */

48 public class Parser {
49     private final Ruby runtime;
50
51     public Parser(Ruby runtime) {
52         this.runtime = runtime;
53     }
54
55     public Node parse(String JavaDoc file, String JavaDoc content, DynamicScope blockScope) {
56         return parse(file, new StringReader JavaDoc(content), blockScope);
57     }
58
59     public Node parse(String JavaDoc file, Reader JavaDoc content, DynamicScope blockScope) {
60         RubyParserConfiguration configuration = new RubyParserConfiguration();
61         SinglyLinkedList cref = runtime.getObject().getCRef();
62         ThreadContext tc = runtime.getCurrentContext();
63
64         // We only need to pass in current scope if we are evaluating as a block (which
65
// is only done for evals). We need to pass this in so that we can appropriately scope
66
// down to captured scopes when we are parsing.
67
if (blockScope != null) {
68             configuration.parseAsBlock(blockScope);
69         }
70         
71         DefaultRubyParser parser = null;
72         RubyParserResult result = null;
73         try {
74             parser = RubyParserPool.getInstance().borrowParser();
75             parser.setWarnings(runtime.getWarnings());
76             tc.setCRef(cref);
77             LexerSource lexerSource = LexerSource.getSource(file, content);
78             result = parser.parse(configuration, lexerSource);
79             if (result.isEndSeen()) {
80                 org.jruby.runtime.builtin.IRubyObject verbose = runtime.getVerbose();
81                 runtime.setVerbose(runtime.getNil());
82                 runtime.defineGlobalConstant("DATA", new RubyFile(runtime, file, content));
83                 runtime.setVerbose(verbose);
84                 result.setEndSeen(false);
85             }
86         } catch (SyntaxException e) {
87             StringBuffer JavaDoc buffer = new StringBuffer JavaDoc(100);
88             buffer.append(e.getPosition().getFile()).append(':');
89             buffer.append(e.getPosition().getEndLine()).append(": ");
90             buffer.append(e.getMessage());
91             throw runtime.newSyntaxError(buffer.toString());
92         } finally {
93             RubyParserPool.getInstance().returnParser(parser);
94             tc.unsetCRef();
95         }
96         
97         // If variables were added then we may need to grow the dynamic scope to match the static
98
// one.
99
// FIXME: Make this so we only need to check this for blockScope != null. We cannot
100
// currently since we create the DynamicScope for a LocalStaticScope before parse begins.
101
// Refactoring should make this fixable.
102
if (result.getScope() != null) {
103             result.getScope().growIfNeeded();
104         }
105
106         // FIXME: We should move this into ParserSupport.addRootNode since actual parser should do this.
107
result.addAppendBeginAndEndNodes();
108         return result.getAST();
109     }
110 }
111
Popular Tags