Categories:
Audio (13)
Biotech (29)
Bytecode (36)
Database (77)
Framework (7)
Game (7)
General (507)
Graphics (53)
I/O (35)
IDE (2)
JAR Tools (101)
JavaBeans (21)
JDBC (121)
JDK (426)
JSP (20)
Logging (108)
Mail (58)
Messaging (8)
Network (84)
PDF (97)
Report (7)
Scripting (84)
Security (32)
Server (121)
Servlet (26)
SOAP (24)
Testing (54)
Web (15)
XML (309)
Collections:
Other Resources:
ANTLR Tool Source Code
ANTLR is a powerful parser generator for multiple programming languages including Java.
ANTLR contains 2 major modules:
ANTLR Tool Source Code files are provided in the distribution packge (antlr4-4.10.1.zip). You can download them at ANTLR Website.
You can also browse the source code below:
✍: FYIcenter
⏎ org/antlr/v4/codegen/OutputModelWalker.java
/* * Copyright (c) 2012-2017 The ANTLR Project. All rights reserved. * Use of this file is governed by the BSD 3-clause license that * can be found in the LICENSE.txt file in the project root. */ package org.antlr.v4.codegen; import org.antlr.v4.Tool; import org.antlr.v4.codegen.model.ModelElement; import org.antlr.v4.codegen.model.OutputModelObject; import org.antlr.v4.tool.ErrorType; import org.stringtemplate.v4.ST; import org.stringtemplate.v4.STGroup; import org.stringtemplate.v4.compiler.FormalArgument; import java.lang.reflect.Field; import java.util.Arrays; import java.util.Collection; import java.util.HashSet; import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; /** Convert an output model tree to template hierarchy by walking * the output model. Each output model object has a corresponding template * of the same name. An output model object can have nested objects. * We identify those nested objects by the list of arguments in the template * definition. For example, here is the definition of the parser template: * * Parser(parser, scopes, funcs) ::= <<...>> * * The first template argument is always the output model object from which * this walker will create the template. Any other arguments identify * the field names within the output model object of nested model objects. * So, in this case, template Parser is saying that output model object * Parser has two fields the walker should chase called a scopes and funcs. * * This simple mechanism means we don't have to include code in every * output model object that says how to create the corresponding template. */ public class OutputModelWalker { Tool tool; STGroup templates; public OutputModelWalker(Tool tool, STGroup templates) { this.tool = tool; this.templates = templates; } public ST walk(OutputModelObject omo, boolean header) { // CREATE TEMPLATE FOR THIS OUTPUT OBJECT Class<? extends OutputModelObject> cl = omo.getClass(); String templateName = cl.getSimpleName(); if ( templateName == null ) { tool.errMgr.toolError(ErrorType.NO_MODEL_TO_TEMPLATE_MAPPING, cl.getSimpleName()); return new ST("["+templateName+" invalid]"); } if (header) templateName += "Header"; ST st = templates.getInstanceOf(templateName); if ( st == null ) { tool.errMgr.toolError(ErrorType.CODE_GEN_TEMPLATES_INCOMPLETE, templateName); return new ST("["+templateName+" invalid]"); } if ( st.impl.formalArguments == null ) { tool.errMgr.toolError(ErrorType.CODE_TEMPLATE_ARG_ISSUE, templateName, "<none>"); return st; } Map<String,FormalArgument> formalArgs = st.impl.formalArguments; // PASS IN OUTPUT MODEL OBJECT TO TEMPLATE AS FIRST ARG Set<String> argNames = formalArgs.keySet(); Iterator<String> arg_it = argNames.iterator(); String modelArgName = arg_it.next(); // ordered so this is first arg st.add(modelArgName, omo); // COMPUTE STs FOR EACH NESTED MODEL OBJECT MARKED WITH @ModelElement AND MAKE ST ATTRIBUTE Set<String> usedFieldNames = new HashSet<String>(); Field fields[] = cl.getFields(); for (Field fi : fields) { ModelElement annotation = fi.getAnnotation(ModelElement.class); if (annotation == null) { continue; } String fieldName = fi.getName(); if (!usedFieldNames.add(fieldName)) { tool.errMgr.toolError(ErrorType.INTERNAL_ERROR, "Model object " + omo.getClass().getSimpleName() + " has multiple fields named '" + fieldName + "'"); continue; } // Just don't set @ModelElement fields w/o formal arg in target ST if ( formalArgs.get(fieldName)==null ) continue; try { Object o = fi.get(omo); if ( o instanceof OutputModelObject ) { // SINGLE MODEL OBJECT? OutputModelObject nestedOmo = (OutputModelObject)o; ST nestedST = walk(nestedOmo, header); // System.out.println("set ModelElement "+fieldName+"="+nestedST+" in "+templateName); st.add(fieldName, nestedST); } else if ( o instanceof Collection || o instanceof OutputModelObject[] ) { // LIST OF MODEL OBJECTS? if ( o instanceof OutputModelObject[] ) { o = Arrays.asList((OutputModelObject[])o); } Collection<?> nestedOmos = (Collection<?>)o; for (Object nestedOmo : nestedOmos) { if ( nestedOmo==null ) continue; ST nestedST = walk((OutputModelObject)nestedOmo, header); // System.out.println("set ModelElement "+fieldName+"="+nestedST+" in "+templateName); st.add(fieldName, nestedST); } } else if ( o instanceof Map ) { Map<?, ?> nestedOmoMap = (Map<?, ?>)o; Map<Object, ST> m = new LinkedHashMap<Object, ST>(); for (Map.Entry<?, ?> entry : nestedOmoMap.entrySet()) { ST nestedST = walk((OutputModelObject)entry.getValue(), header); // System.out.println("set ModelElement "+fieldName+"="+nestedST+" in "+templateName); m.put(entry.getKey(), nestedST); } st.add(fieldName, m); } else if ( o!=null ) { tool.errMgr.toolError(ErrorType.INTERNAL_ERROR, "not recognized nested model element: "+fieldName); } } catch (IllegalAccessException iae) { tool.errMgr.toolError(ErrorType.CODE_TEMPLATE_ARG_ISSUE, templateName, fieldName); } } //st.impl.dump(); return st; } }
⏎ org/antlr/v4/codegen/OutputModelWalker.java
Or download all of them as a single archive file:
File name: antlr-tool-4.10.1-sources.jar File size: 347718 bytes Release date: 2022-04-15 Download
2022-04-24, 32006👍, 0💬
Popular Posts:
JDK 11 java.xml.crypto.jmod is the JMOD file for JDK 11 XML (eXtensible Markup Language) Crypto modu...
What Is javaws.jar in JRE (Java Runtime Environment) 8? javaws.jar in JRE (Java Runtime Environment)...
maven-core-3.8.6.jar is the JAR file for Apache Maven 3.8.6 Core module. Apache Maven is a software ...
JDK 11 jdk.charsets.jmod is the JMOD file for JDK 11 Charsets module. JDK 11 Charsets module compile...
JRE 8 rt.jar is the JAR file for JRE 8 RT (Runtime) libraries. JRE (Java Runtime) 8 is the runtime e...