corba/src/share/classes/com/sun/tools/corba/se/idl/PragmaHandler.java
author ohair
Tue, 25 May 2010 15:52:11 -0700
changeset 5555 b2b5ed3f0d0d
parent 4 02bb8761fcce
permissions -rw-r--r--
6943119: Rebrand source copyright notices Reviewed-by: darcy
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     1
/*
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     2
 * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
02bb8761fcce Initial load
duke
parents:
diff changeset
     4
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
02bb8761fcce Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
4
02bb8761fcce Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
    10
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
02bb8761fcce Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
02bb8761fcce Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
02bb8761fcce Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
02bb8761fcce Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
02bb8761fcce Initial load
duke
parents:
diff changeset
    16
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
02bb8761fcce Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
02bb8761fcce Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
02bb8761fcce Initial load
duke
parents:
diff changeset
    20
 *
5555
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
b2b5ed3f0d0d 6943119: Rebrand source copyright notices
ohair
parents: 4
diff changeset
    23
 * questions.
4
02bb8761fcce Initial load
duke
parents:
diff changeset
    24
 */
02bb8761fcce Initial load
duke
parents:
diff changeset
    25
/*
02bb8761fcce Initial load
duke
parents:
diff changeset
    26
 * COMPONENT_NAME: idl.parser
02bb8761fcce Initial load
duke
parents:
diff changeset
    27
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    28
 * ORIGINS: 27
02bb8761fcce Initial load
duke
parents:
diff changeset
    29
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    30
 * Licensed Materials - Property of IBM
02bb8761fcce Initial load
duke
parents:
diff changeset
    31
 * 5639-D57 (C) COPYRIGHT International Business Machines Corp. 1997, 1999
02bb8761fcce Initial load
duke
parents:
diff changeset
    32
 * RMI-IIOP v1.0
02bb8761fcce Initial load
duke
parents:
diff changeset
    33
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    34
 */
02bb8761fcce Initial load
duke
parents:
diff changeset
    35
02bb8761fcce Initial load
duke
parents:
diff changeset
    36
package com.sun.tools.corba.se.idl;
02bb8761fcce Initial load
duke
parents:
diff changeset
    37
02bb8761fcce Initial load
duke
parents:
diff changeset
    38
// NOTES:
02bb8761fcce Initial load
duke
parents:
diff changeset
    39
// - Add openScope and closeScope.
02bb8761fcce Initial load
duke
parents:
diff changeset
    40
02bb8761fcce Initial load
duke
parents:
diff changeset
    41
import java.io.IOException;
02bb8761fcce Initial load
duke
parents:
diff changeset
    42
02bb8761fcce Initial load
duke
parents:
diff changeset
    43
public abstract class PragmaHandler
02bb8761fcce Initial load
duke
parents:
diff changeset
    44
{
02bb8761fcce Initial load
duke
parents:
diff changeset
    45
  public abstract boolean process (String pragma, String currentToken) throws IOException;
02bb8761fcce Initial load
duke
parents:
diff changeset
    46
02bb8761fcce Initial load
duke
parents:
diff changeset
    47
  void init (Preprocessor p)
02bb8761fcce Initial load
duke
parents:
diff changeset
    48
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    49
    preprocessor = p;
02bb8761fcce Initial load
duke
parents:
diff changeset
    50
  } // init
02bb8761fcce Initial load
duke
parents:
diff changeset
    51
02bb8761fcce Initial load
duke
parents:
diff changeset
    52
  // Utility methods.
02bb8761fcce Initial load
duke
parents:
diff changeset
    53
02bb8761fcce Initial load
duke
parents:
diff changeset
    54
  /** Get the current token. */
02bb8761fcce Initial load
duke
parents:
diff changeset
    55
  protected String currentToken ()
02bb8761fcce Initial load
duke
parents:
diff changeset
    56
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    57
    return preprocessor.currentToken ();
02bb8761fcce Initial load
duke
parents:
diff changeset
    58
  } // currentToken
02bb8761fcce Initial load
duke
parents:
diff changeset
    59
02bb8761fcce Initial load
duke
parents:
diff changeset
    60
  /** This method, given an entry name, returns the entry with that name.
02bb8761fcce Initial load
duke
parents:
diff changeset
    61
      It can take fully or partially qualified names and returns the
02bb8761fcce Initial load
duke
parents:
diff changeset
    62
      appropriate entry defined within the current scope.  If no entry
02bb8761fcce Initial load
duke
parents:
diff changeset
    63
      exists, null is returned. */
02bb8761fcce Initial load
duke
parents:
diff changeset
    64
  protected SymtabEntry getEntryForName (String string)
02bb8761fcce Initial load
duke
parents:
diff changeset
    65
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    66
    return preprocessor.getEntryForName (string);
02bb8761fcce Initial load
duke
parents:
diff changeset
    67
  } // getEntryForName
02bb8761fcce Initial load
duke
parents:
diff changeset
    68
02bb8761fcce Initial load
duke
parents:
diff changeset
    69
  /** This method returns a string of all of the characters from the input
02bb8761fcce Initial load
duke
parents:
diff changeset
    70
      file from the current position up to, but not including, the end-of-line
02bb8761fcce Initial load
duke
parents:
diff changeset
    71
      character(s). */
02bb8761fcce Initial load
duke
parents:
diff changeset
    72
  protected String getStringToEOL () throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
    73
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    74
    return preprocessor.getStringToEOL ();
02bb8761fcce Initial load
duke
parents:
diff changeset
    75
  } // getStringToEOL
02bb8761fcce Initial load
duke
parents:
diff changeset
    76
02bb8761fcce Initial load
duke
parents:
diff changeset
    77
  /** This method returns a string of all of the characters from the input
02bb8761fcce Initial load
duke
parents:
diff changeset
    78
      file from the current position up to, but not including, the given
02bb8761fcce Initial load
duke
parents:
diff changeset
    79
      character.  It encapsulates parenthesis and quoted strings, meaning
02bb8761fcce Initial load
duke
parents:
diff changeset
    80
      it does not stop if the given character is found within parentheses
02bb8761fcce Initial load
duke
parents:
diff changeset
    81
      or quotes.  For instance, given the input of `start(inside)end',
02bb8761fcce Initial load
duke
parents:
diff changeset
    82
      getUntil ('n') will return "start(inside)e" */
02bb8761fcce Initial load
duke
parents:
diff changeset
    83
  protected String getUntil (char c) throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
    84
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    85
    return preprocessor.getUntil (c);
02bb8761fcce Initial load
duke
parents:
diff changeset
    86
  } // getUntil
02bb8761fcce Initial load
duke
parents:
diff changeset
    87
02bb8761fcce Initial load
duke
parents:
diff changeset
    88
  /** This method returns the next token String from the input file. */
02bb8761fcce Initial load
duke
parents:
diff changeset
    89
  protected String nextToken () throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
    90
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    91
    return preprocessor.nextToken ();
02bb8761fcce Initial load
duke
parents:
diff changeset
    92
  } // nextToken
02bb8761fcce Initial load
duke
parents:
diff changeset
    93
02bb8761fcce Initial load
duke
parents:
diff changeset
    94
  /** This method assumes that the current token marks the beginning
02bb8761fcce Initial load
duke
parents:
diff changeset
    95
      of a scoped name.  It then parses the subsequent identifier and
02bb8761fcce Initial load
duke
parents:
diff changeset
    96
      double colon tokens, builds the scoped name, and finds the symbol
02bb8761fcce Initial load
duke
parents:
diff changeset
    97
      table entry with that name. */
02bb8761fcce Initial load
duke
parents:
diff changeset
    98
  protected SymtabEntry scopedName () throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
    99
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   100
    return preprocessor.scopedName ();
02bb8761fcce Initial load
duke
parents:
diff changeset
   101
  } // scopedName
02bb8761fcce Initial load
duke
parents:
diff changeset
   102
02bb8761fcce Initial load
duke
parents:
diff changeset
   103
  /** Skip to the end of the line. */
02bb8761fcce Initial load
duke
parents:
diff changeset
   104
  protected void skipToEOL () throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
   105
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   106
    preprocessor.skipToEOL ();
02bb8761fcce Initial load
duke
parents:
diff changeset
   107
  } // skipToEOL
02bb8761fcce Initial load
duke
parents:
diff changeset
   108
02bb8761fcce Initial load
duke
parents:
diff changeset
   109
  /** This method skips the data in the input file until the specified
02bb8761fcce Initial load
duke
parents:
diff changeset
   110
      character is encountered, then it returns the next token. */
02bb8761fcce Initial load
duke
parents:
diff changeset
   111
  protected String skipUntil (char c) throws IOException
02bb8761fcce Initial load
duke
parents:
diff changeset
   112
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   113
    return preprocessor.skipUntil (c);
02bb8761fcce Initial load
duke
parents:
diff changeset
   114
  } // skipUntil
02bb8761fcce Initial load
duke
parents:
diff changeset
   115
02bb8761fcce Initial load
duke
parents:
diff changeset
   116
  /** This method displays a Parser Exception complete with line number
02bb8761fcce Initial load
duke
parents:
diff changeset
   117
      and position information with the given message string. */
02bb8761fcce Initial load
duke
parents:
diff changeset
   118
  protected void parseException (String message)
02bb8761fcce Initial load
duke
parents:
diff changeset
   119
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   120
    preprocessor.parseException (message);
02bb8761fcce Initial load
duke
parents:
diff changeset
   121
  } // parseException
02bb8761fcce Initial load
duke
parents:
diff changeset
   122
02bb8761fcce Initial load
duke
parents:
diff changeset
   123
  /** This method is called when the parser encounters a left curly brace.
02bb8761fcce Initial load
duke
parents:
diff changeset
   124
      An extender of PragmaHandler may find scope information useful.
02bb8761fcce Initial load
duke
parents:
diff changeset
   125
      For example, the prefix pragma takes effect as soon as it is
02bb8761fcce Initial load
duke
parents:
diff changeset
   126
      encountered and stays in effect until the current scope is closed.
02bb8761fcce Initial load
duke
parents:
diff changeset
   127
      If a similar pragma extension is desired, then the openScope and
02bb8761fcce Initial load
duke
parents:
diff changeset
   128
      closeScope methods are available for overriding.
02bb8761fcce Initial load
duke
parents:
diff changeset
   129
      @param entry the symbol table entry whose scope has just been opened.
02bb8761fcce Initial load
duke
parents:
diff changeset
   130
       Be aware that, since the scope has just been entered, this entry is
02bb8761fcce Initial load
duke
parents:
diff changeset
   131
       incomplete at this point.  */
02bb8761fcce Initial load
duke
parents:
diff changeset
   132
  protected void openScope (SymtabEntry entry)
02bb8761fcce Initial load
duke
parents:
diff changeset
   133
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   134
  } // openScope
02bb8761fcce Initial load
duke
parents:
diff changeset
   135
02bb8761fcce Initial load
duke
parents:
diff changeset
   136
  /** This method is called when the parser encounters a right curly brace.
02bb8761fcce Initial load
duke
parents:
diff changeset
   137
      An extender of PragmaHandler may find scope information useful.
02bb8761fcce Initial load
duke
parents:
diff changeset
   138
      For example, the prefix pragma takes effect as soon as it is
02bb8761fcce Initial load
duke
parents:
diff changeset
   139
      encountered and stays in effect until the current scope is closed.
02bb8761fcce Initial load
duke
parents:
diff changeset
   140
      If a similar pragma extension is desired, then the openScope and
02bb8761fcce Initial load
duke
parents:
diff changeset
   141
      closeScope methods are available for overriding.
02bb8761fcce Initial load
duke
parents:
diff changeset
   142
      @param entry the symbol table entry whose scope has just been closed. */
02bb8761fcce Initial load
duke
parents:
diff changeset
   143
  protected void closeScope (SymtabEntry entry)
02bb8761fcce Initial load
duke
parents:
diff changeset
   144
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   145
  } // closeScope
02bb8761fcce Initial load
duke
parents:
diff changeset
   146
02bb8761fcce Initial load
duke
parents:
diff changeset
   147
  private Preprocessor preprocessor = null;
02bb8761fcce Initial load
duke
parents:
diff changeset
   148
} // class PragmaHandler