corba/src/share/classes/com/sun/tools/corba/se/idl/toJavaPortable/TCOffsets.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.toJava
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.toJavaPortable;
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
02bb8761fcce Initial load
duke
parents:
diff changeset
    40
import java.util.Enumeration;
02bb8761fcce Initial load
duke
parents:
diff changeset
    41
import java.util.Hashtable;
02bb8761fcce Initial load
duke
parents:
diff changeset
    42
02bb8761fcce Initial load
duke
parents:
diff changeset
    43
import com.sun.tools.corba.se.idl.*;
02bb8761fcce Initial load
duke
parents:
diff changeset
    44
02bb8761fcce Initial load
duke
parents:
diff changeset
    45
// This class is passed through the JavaGenerator.HelperType methods.
02bb8761fcce Initial load
duke
parents:
diff changeset
    46
// It is ONLY used when a recursive sequence is detected. ie.
02bb8761fcce Initial load
duke
parents:
diff changeset
    47
//
02bb8761fcce Initial load
duke
parents:
diff changeset
    48
//   struct S1
02bb8761fcce Initial load
duke
parents:
diff changeset
    49
//   {
02bb8761fcce Initial load
duke
parents:
diff changeset
    50
//     sequence <S1> others;
02bb8761fcce Initial load
duke
parents:
diff changeset
    51
//   };
02bb8761fcce Initial load
duke
parents:
diff changeset
    52
02bb8761fcce Initial load
duke
parents:
diff changeset
    53
/**
02bb8761fcce Initial load
duke
parents:
diff changeset
    54
 *
02bb8761fcce Initial load
duke
parents:
diff changeset
    55
 **/
02bb8761fcce Initial load
duke
parents:
diff changeset
    56
public class TCOffsets
02bb8761fcce Initial load
duke
parents:
diff changeset
    57
{
02bb8761fcce Initial load
duke
parents:
diff changeset
    58
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
    59
   * Return -1 if the given name is not in the list of types.
02bb8761fcce Initial load
duke
parents:
diff changeset
    60
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
    61
  public int offset (String name)
02bb8761fcce Initial load
duke
parents:
diff changeset
    62
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    63
    Integer value = (Integer)tcs.get (name);
02bb8761fcce Initial load
duke
parents:
diff changeset
    64
    return value == null ? -1 : value.intValue ();
02bb8761fcce Initial load
duke
parents:
diff changeset
    65
  } // offset
02bb8761fcce Initial load
duke
parents:
diff changeset
    66
02bb8761fcce Initial load
duke
parents:
diff changeset
    67
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
    68
   *
02bb8761fcce Initial load
duke
parents:
diff changeset
    69
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
    70
  public void set (SymtabEntry entry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    71
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
    72
    if (entry == null)
02bb8761fcce Initial load
duke
parents:
diff changeset
    73
      offset += 8;
02bb8761fcce Initial load
duke
parents:
diff changeset
    74
    else
02bb8761fcce Initial load
duke
parents:
diff changeset
    75
    {
02bb8761fcce Initial load
duke
parents:
diff changeset
    76
      tcs.put (entry.fullName (), new Integer (offset));
02bb8761fcce Initial load
duke
parents:
diff changeset
    77
      offset += 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
    78
      String repID = Util.stripLeadingUnderscoresFromID (entry.repositoryID ().ID ());
02bb8761fcce Initial load
duke
parents:
diff changeset
    79
      if (entry instanceof InterfaceEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    80
        offset += alignStrLen (repID) + alignStrLen (entry.name ());
02bb8761fcce Initial load
duke
parents:
diff changeset
    81
      else if (entry instanceof StructEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    82
        offset += alignStrLen (repID) + alignStrLen (entry.name ()) + 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
    83
      else if (entry instanceof UnionEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    84
        offset += alignStrLen (repID) + alignStrLen (entry.name ()) + 12;
02bb8761fcce Initial load
duke
parents:
diff changeset
    85
      else if (entry instanceof EnumEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    86
      {
02bb8761fcce Initial load
duke
parents:
diff changeset
    87
        offset += alignStrLen (repID) + alignStrLen (entry.name ()) + 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
    88
        Enumeration e = ((EnumEntry)entry).elements ().elements ();
02bb8761fcce Initial load
duke
parents:
diff changeset
    89
        while (e.hasMoreElements ())
02bb8761fcce Initial load
duke
parents:
diff changeset
    90
          offset += alignStrLen ((String)e.nextElement ());
02bb8761fcce Initial load
duke
parents:
diff changeset
    91
      }
02bb8761fcce Initial load
duke
parents:
diff changeset
    92
      else if (entry instanceof StringEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    93
        offset += 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
    94
      else if (entry instanceof TypedefEntry)
02bb8761fcce Initial load
duke
parents:
diff changeset
    95
      {
02bb8761fcce Initial load
duke
parents:
diff changeset
    96
        offset += alignStrLen (repID) + alignStrLen (entry.name ());
02bb8761fcce Initial load
duke
parents:
diff changeset
    97
        if (((TypedefEntry)entry).arrayInfo ().size () != 0)
02bb8761fcce Initial load
duke
parents:
diff changeset
    98
          offset += 8;
02bb8761fcce Initial load
duke
parents:
diff changeset
    99
      }
02bb8761fcce Initial load
duke
parents:
diff changeset
   100
    }
02bb8761fcce Initial load
duke
parents:
diff changeset
   101
  } // set
02bb8761fcce Initial load
duke
parents:
diff changeset
   102
02bb8761fcce Initial load
duke
parents:
diff changeset
   103
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
   104
   * Return the full length of the string type:  4 byte length, x bytes for
02bb8761fcce Initial load
duke
parents:
diff changeset
   105
   * string + 1 for the null terminator, align it so it ends on a 4-byte
02bb8761fcce Initial load
duke
parents:
diff changeset
   106
   * boundary.  This method assumes the string starts at a 4-byte boundary
02bb8761fcce Initial load
duke
parents:
diff changeset
   107
   * since it doesn't do any leading alignment.
02bb8761fcce Initial load
duke
parents:
diff changeset
   108
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
   109
  public int alignStrLen (String string)
02bb8761fcce Initial load
duke
parents:
diff changeset
   110
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   111
    int len = string.length () + 1;
02bb8761fcce Initial load
duke
parents:
diff changeset
   112
    int align = 4 - (len % 4);
02bb8761fcce Initial load
duke
parents:
diff changeset
   113
    if (align == 4) align = 0;
02bb8761fcce Initial load
duke
parents:
diff changeset
   114
    return len + align + 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
   115
  } // alignStrLen
02bb8761fcce Initial load
duke
parents:
diff changeset
   116
02bb8761fcce Initial load
duke
parents:
diff changeset
   117
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
   118
   *
02bb8761fcce Initial load
duke
parents:
diff changeset
   119
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
   120
  public void setMember (SymtabEntry entry)
02bb8761fcce Initial load
duke
parents:
diff changeset
   121
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   122
    offset += alignStrLen (entry.name ());
02bb8761fcce Initial load
duke
parents:
diff changeset
   123
    if (((TypedefEntry)entry).arrayInfo ().size () != 0)
02bb8761fcce Initial load
duke
parents:
diff changeset
   124
      offset += 4;
02bb8761fcce Initial load
duke
parents:
diff changeset
   125
  } // setMember
02bb8761fcce Initial load
duke
parents:
diff changeset
   126
02bb8761fcce Initial load
duke
parents:
diff changeset
   127
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
   128
   *
02bb8761fcce Initial load
duke
parents:
diff changeset
   129
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
   130
  public int currentOffset ()
02bb8761fcce Initial load
duke
parents:
diff changeset
   131
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   132
    return offset;
02bb8761fcce Initial load
duke
parents:
diff changeset
   133
  } // currentOffset
02bb8761fcce Initial load
duke
parents:
diff changeset
   134
02bb8761fcce Initial load
duke
parents:
diff changeset
   135
  /**
02bb8761fcce Initial load
duke
parents:
diff changeset
   136
   *
02bb8761fcce Initial load
duke
parents:
diff changeset
   137
   **/
02bb8761fcce Initial load
duke
parents:
diff changeset
   138
  public void bumpCurrentOffset (int value)
02bb8761fcce Initial load
duke
parents:
diff changeset
   139
  {
02bb8761fcce Initial load
duke
parents:
diff changeset
   140
    offset += value;
02bb8761fcce Initial load
duke
parents:
diff changeset
   141
  } // bumpCurrentOffset
02bb8761fcce Initial load
duke
parents:
diff changeset
   142
02bb8761fcce Initial load
duke
parents:
diff changeset
   143
  private Hashtable tcs    = new Hashtable ();
02bb8761fcce Initial load
duke
parents:
diff changeset
   144
  private int       offset = 0;
02bb8761fcce Initial load
duke
parents:
diff changeset
   145
} // class TCOffsets