| /* |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| */ |
| package org.apache.airavata.datacat.parsers.gridchem.gmcscfa; |
| |
| import java_cup.runtime.lr_parser; |
| import org.apache.airavata.datacat.parsers.gridchem.GridChemQueueParser; |
| |
| import javax.swing.*; |
| import java.io.FileReader; |
| import java.util.ArrayList; |
| import java.util.HashMap; |
| |
| |
| public class GmcscfaParser extends java_cup.runtime.lr_parser implements GridChemQueueParser { |
| |
| /** Default constructor. */ |
| public GmcscfaParser() {super();} |
| |
| /** Constructor which sets the default scanner. */ |
| public GmcscfaParser(java_cup.runtime.Scanner s) {super(s);} |
| |
| /** |
| * Constructor which uses a file reader. |
| */ |
| public GmcscfaParser(final FileReader fileReader) { |
| super(new GMCSCFaLexer(fileReader)); |
| } |
| |
| /** Production table. */ |
| protected static final short _production_table[][] = |
| lr_parser.unpackFromStrings(new String[]{ |
| "\000\010\000\002\003\005\000\002\002\004\000\002\004" + |
| "\003\000\002\005\004\000\002\005\003\000\002\010\002" + |
| "\000\002\006\012\000\002\007\003"}); |
| |
| /** Access to production table. */ |
| public short[][] production_table() {return _production_table;} |
| |
| /** Parse-action table. */ |
| protected static final short[][] _action_table = |
| lr_parser.unpackFromStrings(new String[]{ |
| "\000\022\000\004\004\005\001\002\000\004\011\012\001" + |
| "\002\000\004\011\uffff\001\002\000\004\002\007\001\002" + |
| "\000\004\002\000\001\002\000\006\005\023\011\012\001" + |
| "\002\000\006\005\ufffd\011\ufffd\001\002\000\004\016\ufffc" + |
| "\001\002\000\004\016\015\001\002\000\004\013\016\001" + |
| "\002\000\004\013\ufffa\001\002\000\004\014\017\001\002" + |
| "\000\004\015\020\001\002\000\004\006\021\001\002\000" + |
| "\004\017\022\001\002\000\006\005\ufffb\011\ufffb\001\002" + |
| "\000\004\002\001\001\002\000\006\005\ufffe\011\ufffe\001" + |
| "\002"}); |
| |
| /** Access to parse-action table. */ |
| public short[][] action_table() {return _action_table;} |
| |
| /** <code>reduce_goto</code> table. */ |
| protected static final short[][] _reduce_table = |
| lr_parser.unpackFromStrings(new String[]{ |
| "\000\022\000\006\003\005\004\003\001\001\000\006\005" + |
| "\007\006\010\001\001\000\002\001\001\000\002\001\001" + |
| "\000\002\001\001\000\004\006\023\001\001\000\002\001" + |
| "\001\000\004\010\012\001\001\000\004\007\013\001\001" + |
| "\000\002\001\001\000\002\001\001\000\002\001\001\000" + |
| "\002\001\001\000\002\001\001\000\002\001\001\000\002" + |
| "\001\001\000\002\001\001\000\002\001\001"}); |
| |
| /** Access to <code>reduce_goto</code> table. */ |
| public short[][] reduce_table() {return _reduce_table;} |
| |
| /** Instance of action encapsulation class. */ |
| protected CUP$parser$actions action_obj; |
| |
| //Each string is of the format |
| //energy, iteration |
| private ArrayList<String> result = new ArrayList<String>(); |
| private String tempStr = ""; |
| |
| public void addToResult(String value) { |
| result.add(value); |
| } |
| |
| |
| public ArrayList<String> getResult() { |
| return result; |
| } |
| |
| public String getTempStr() { |
| return tempStr; |
| } |
| |
| public void setTempStr(String s) { |
| this.tempStr = s; |
| } |
| |
| /*Adding the parsed data to the hash map */ |
| @Override |
| public HashMap<String, String> getParsedData() throws Exception { |
| parse(); |
| HashMap<String,String> results= new HashMap<String,String>(); |
| int energy=0; |
| int iteration=0; |
| for (int i=0;i<result.size();i++){ |
| String singleResult=result.get(i); |
| String[] temp= singleResult.split(" "); |
| if(temp.length>1){ |
| String keyElement=temp[0]; |
| String dataEelement=temp[1]; |
| if(keyElement.equals("ENERGY")){ |
| results.put("GmcscfaParser_ENERGY_"+energy,dataEelement); |
| energy++; |
| }else if (keyElement.equals("ITERATION")){ |
| results.put("GmcscfaParser_ITERATION_"+iteration,dataEelement); |
| iteration++; |
| } |
| } |
| } |
| return results; |
| } |
| |
| /** Action encapsulation object initializer. */ |
| protected void init_actions() |
| { |
| action_obj = new CUP$parser$actions(this); |
| } |
| |
| /** Invoke a user supplied parse action. */ |
| public java_cup.runtime.Symbol do_action( |
| int act_num, |
| java_cup.runtime.lr_parser parser, |
| java.util.Stack stack, |
| int top) |
| throws java.lang.Exception |
| { |
| /* call code in generated class */ |
| return action_obj.CUP$parser$do_action(act_num, parser, stack, top); |
| } |
| |
| /** Indicates start state. */ |
| public int start_state() {return 0;} |
| /** Indicates start production. */ |
| public int start_production() {return 1;} |
| |
| /** <code>EOF</code> Symbol index. */ |
| public int EOF_sym() {return 0;} |
| |
| /** <code>error</code> Symbol index. */ |
| public int error_sym() {return 1;} |
| |
| |
| } |
| |
| /** Cup generated class to encapsulate user supplied action code.*/ |
| class CUP$parser$actions { |
| |
| |
| //__________________________________ |
| public static boolean DEBUG = true; |
| private static JTable table; |
| private static final String tableLabel = "SCF Intermediate Results:"; |
| // private static String cycle = "0"; |
| |
| |
| public static JTable getTable() { |
| return table; |
| } |
| |
| public static String getTableLabel() { |
| return tableLabel; |
| } |
| |
| /* public static void main(String[] args) throws IOException { |
| File temp = new File("temporary"); |
| boolean append = true; |
| try{ |
| FileWriter temp1 = new FileWriter(temp, append); |
| PrintWriter temp2 = new PrintWriter(temp1);} |
| |
| catch (FileNotFoundException e) { |
| System.out.println("no file, dude!"); |
| } */ |
| // } |
| |
| private final GmcscfaParser GmcscfaParser; |
| |
| /** Constructor */ |
| CUP$parser$actions(GmcscfaParser GmcscfaParser) { |
| this.GmcscfaParser = GmcscfaParser; |
| } |
| |
| /** Method with the actual generated action code. */ |
| public final java_cup.runtime.Symbol CUP$parser$do_action( |
| int CUP$parser$act_num, |
| java_cup.runtime.lr_parser CUP$parser$parser, |
| java.util.Stack CUP$parser$stack, |
| int CUP$parser$top) |
| throws java.lang.Exception |
| { |
| /* Symbol object for return from actions */ |
| java_cup.runtime.Symbol CUP$parser$result; |
| |
| /* select the action based on the action number */ |
| switch (CUP$parser$act_num) |
| { |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 7: // en ::= ENERGY |
| { |
| Object RESULT = null; |
| int eleft = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).left; |
| int eright = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right; |
| Float e = (Float)((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-0)).value; |
| //___________________________________________________________________ |
| if (DEBUG) System.out.println("CUP:gscfa:scfcycle: ENERGY "+e); |
| GmcscfaParser.addToResult("ENERGY "+e); |
| // temp2.println(e); |
| // parseSCF.putField("iteration "+cycle, "energy", e); |
| |
| CUP$parser$result = new java_cup.runtime.Symbol(5/*en*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 6: // scfcycle ::= INTCycle NT$0 en FLOAT1 FLOAT2 FLOAT3 INT1 FLOAT4 |
| { |
| Object RESULT = null; |
| // propagate RESULT from NT$0 |
| if ( ((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-6)).value != null ) |
| RESULT = (Object) ((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-6)).value; |
| int cleft = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-7)).left; |
| int cright = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-7)).right; |
| Integer c = (Integer)((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-7)).value; |
| |
| CUP$parser$result = new java_cup.runtime.Symbol(4/*scfcycle*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-7)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 5: // NT$0 ::= |
| { |
| Object RESULT = null; |
| int cleft = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).left; |
| int cright = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right; |
| Integer c = (Integer)((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-0)).value; |
| //___________________________________________________________________ |
| if (DEBUG) System.out.println("CUP:gscfa:scfcycle: ITERATION "+c); |
| GmcscfaParser.addToResult("ITERATION "+c); |
| // temp2.print(c); |
| // temp2.print(" "); |
| // cycle = c; |
| |
| // parseSCF.putField("iteration "+cycle, cycle); |
| |
| CUP$parser$result = new java_cup.runtime.Symbol(6/*NT$0*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 4: // scfpat ::= scfcycle |
| { |
| Object RESULT = null; |
| |
| CUP$parser$result = new java_cup.runtime.Symbol(3/*scfpat*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 3: // scfpat ::= scfpat scfcycle |
| { |
| Object RESULT = null; |
| if (DEBUG) System.out.println("CUP:gscfa: in scfpat"); |
| CUP$parser$result = new java_cup.runtime.Symbol(3/*scfpat*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-1)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 2: // scfintro ::= FOUNDITER |
| { |
| Object RESULT = null; |
| if (DEBUG) System.out.println("CUP:gscfa: found start of SCF Iteration"); |
| CUP$parser$result = new java_cup.runtime.Symbol(2/*scfintro*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 1: // $START ::= startpt EOF |
| { |
| Object RESULT = null; |
| int start_valleft = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-1)).left; |
| int start_valright = ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-1)).right; |
| Object start_val = (Object)((java_cup.runtime.Symbol) CUP$parser$stack.elementAt(CUP$parser$top-1)).value; |
| RESULT = start_val; |
| CUP$parser$result = new java_cup.runtime.Symbol(0/*$START*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-1)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| /* ACCEPT */ |
| CUP$parser$parser.done_parsing(); |
| return CUP$parser$result; |
| |
| /*. . . . . . . . . . . . . . . . . . . .*/ |
| case 0: // startpt ::= scfintro scfpat SCFDONE |
| { |
| Object RESULT = null; |
| if (DEBUG) System.out.println("CUP:gscfa: end of parse tree "); |
| table = new JTable(); |
| |
| // table = parseSCF.getTable(); |
| |
| CUP$parser$result = new java_cup.runtime.Symbol(1/*startpt*/, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-2)).left, ((java_cup.runtime.Symbol)CUP$parser$stack.elementAt(CUP$parser$top-0)).right, RESULT); |
| } |
| return CUP$parser$result; |
| |
| /* . . . . . .*/ |
| default: |
| throw new Exception( |
| "Invalid action number found in internal parse table"); |
| |
| } |
| } |
| } |
| |