hotspot/src/share/vm/runtime/reflectionUtils.cpp
author phh
Wed, 28 Oct 2009 16:25:51 -0400
changeset 4434 4b41e5b42f81
parent 1 489c9b5090e2
child 4571 80b553bddc26
permissions -rw-r--r--
6887571: Increase default heap config sizes Summary: Apply modification of existing server heap size ergo to all collectors except CMS. Reviewed-by: jmasa, ysr, xlu
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
     2
 * Copyright 1999-2006 Sun Microsystems, Inc.  All Rights Reserved.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
 * CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
 * have any questions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
#include "incls/_precompiled.incl"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
#include "incls/_reflectionUtils.cpp.incl"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
KlassStream::KlassStream(instanceKlassHandle klass, bool local_only, bool classes_only) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
  _klass = klass;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
  if (classes_only) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
    _interfaces = Universe::the_empty_system_obj_array();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
    _interfaces = klass->transitive_interfaces();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
  _interface_index = _interfaces->length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
  _local_only = local_only;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
  _classes_only = classes_only;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
bool KlassStream::eos() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
  if (index() >= 0) return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
  if (_local_only) return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
  if (!_klass->is_interface() && _klass->super() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
    // go up superclass chain (not for interfaces)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
    _klass = _klass->super();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
    if (_interface_index > 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
      _klass = klassOop(_interfaces->obj_at(--_interface_index));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
      return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
  _index = length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
  next();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
  return eos();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
GrowableArray<FilteredField*> *FilteredFieldsMap::_filtered_fields =
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
  new (ResourceObj::C_HEAP) GrowableArray<FilteredField*>(3,true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
void FilteredFieldsMap::initialize() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
  int offset;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
  offset = java_lang_Throwable::get_backtrace_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
  _filtered_fields->append(new FilteredField(SystemDictionary::throwable_klass(), offset));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
  // The latest version of vm may be used with old jdk.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
  if (JDK_Version::is_gte_jdk16x_version()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
    // The following class fields do not exist in
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
    // previous version of jdk.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
    offset = sun_reflect_ConstantPool::cp_oop_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
    _filtered_fields->append(new FilteredField(SystemDictionary::reflect_constant_pool_klass(), offset));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
    offset = sun_reflect_UnsafeStaticFieldAccessorImpl::base_offset();
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
    _filtered_fields->append(new FilteredField(SystemDictionary::reflect_unsafe_static_field_accessor_impl_klass(), offset));
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
int FilteredFieldStream::field_count() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
  int numflds = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
  for (;!eos(); next()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
    numflds++;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
  return numflds;
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
}