< prev index next >

src/share/vm/runtime/fieldDescriptor.hpp

Print this page




  23  */
  24 
  25 #ifndef SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP
  26 #define SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP
  27 
  28 #include "oops/constantPool.hpp"
  29 #include "oops/symbol.hpp"
  30 #include "runtime/fieldType.hpp"
  31 #include "utilities/accessFlags.hpp"
  32 #include "utilities/constantTag.hpp"
  33 
  34 // A fieldDescriptor describes the attributes of a single field (instance or class variable).
  35 // It needs the class constant pool to work (because it only holds indices into the pool
  36 // rather than the actual info).
  37 
  38 class fieldDescriptor VALUE_OBJ_CLASS_SPEC {
  39  private:
  40   AccessFlags         _access_flags;
  41   int                 _index; // the field index
  42   constantPoolHandle  _cp;







  43 
  44   // update the access_flags for the field in the klass
  45   void update_klass_field_access_flag() {
  46     InstanceKlass* ik = field_holder();
  47     ik->field(index())->set_access_flags(_access_flags.as_short());
  48   }
  49 
  50   FieldInfo* field() const {



  51     InstanceKlass* ik = field_holder();
  52     return ik->field(_index);
  53   }

  54 
  55  public:
  56   fieldDescriptor() {
  57     DEBUG_ONLY(_index = badInt);



  58   }
  59   fieldDescriptor(InstanceKlass* ik, int index) {
  60     DEBUG_ONLY(_index = badInt);
  61     reinitialize(ik, index);
  62   }





























  63   Symbol* name() const {
  64     return field()->name(_cp);
  65   }
  66   Symbol* signature() const {
  67     return field()->signature(_cp);
  68   }
  69   InstanceKlass* field_holder()   const    { return _cp->pool_holder(); }
  70   ConstantPool* constants()       const    { return _cp(); }
  71   AccessFlags access_flags()      const    { return _access_flags; }
  72   oop loader()                    const;
  73   // Offset (in words) of field from start of instanceOop / Klass*
  74   int offset()                    const    { return field()->offset(); }
  75   Symbol* generic_signature()     const;
  76   int index()                     const    { return _index; }
  77   AnnotationArray* annotations()  const;
  78   AnnotationArray* type_annotations()  const;
  79 
  80   // Initial field value
  81   bool has_initial_value()        const    { return field()->initval_index() != 0; }
  82   int initial_value_index()       const    { return field()->initval_index(); }
  83   constantTag initial_value_tag() const;  // The tag will return true on one of is_int(), is_long(), is_single(), is_double()
  84   jint int_initial_value()        const;
  85   jlong long_initial_value()      const;
  86   jfloat float_initial_value()    const;
  87   jdouble double_initial_value()  const;


 103 
 104   bool is_synthetic()             const    { return access_flags().is_synthetic(); }
 105 
 106   bool is_field_access_watched()  const    { return access_flags().is_field_access_watched(); }
 107   bool is_field_modification_watched() const
 108                                            { return access_flags().is_field_modification_watched(); }
 109   bool has_generic_signature()    const    { return access_flags().field_has_generic_signature(); }
 110 
 111   void set_is_field_access_watched(const bool value) {
 112     _access_flags.set_is_field_access_watched(value);
 113     update_klass_field_access_flag();
 114   }
 115 
 116   void set_is_field_modification_watched(const bool value) {
 117     _access_flags.set_is_field_modification_watched(value);
 118     update_klass_field_access_flag();
 119   }
 120 
 121   // Initialization
 122   void reinitialize(InstanceKlass* ik, int index);

 123 
 124   // Print
 125   void print() { print_on(tty); }
 126   void print_on(outputStream* st) const         PRODUCT_RETURN;
 127   void print_on_for(outputStream* st, oop obj)  PRODUCT_RETURN;
 128   void verify() const                           PRODUCT_RETURN;
 129 };
 130 
 131 #endif // SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP


  23  */
  24 
  25 #ifndef SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP
  26 #define SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP
  27 
  28 #include "oops/constantPool.hpp"
  29 #include "oops/symbol.hpp"
  30 #include "runtime/fieldType.hpp"
  31 #include "utilities/accessFlags.hpp"
  32 #include "utilities/constantTag.hpp"
  33 
  34 // A fieldDescriptor describes the attributes of a single field (instance or class variable).
  35 // It needs the class constant pool to work (because it only holds indices into the pool
  36 // rather than the actual info).
  37 
  38 class fieldDescriptor VALUE_OBJ_CLASS_SPEC {
  39  private:
  40   AccessFlags         _access_flags;
  41   int                 _index; // the field index
  42   constantPoolHandle  _cp;
  43   u2                   _putAccessor;
  44   u2                   _getAccessor;
  45   bool                _is_accessor;
  46   u2                  _field_name_from_accessor;
  47   FieldInfo*          _accessor_info;
  48   Symbol*             _sig_for_accessor;
  49   
  50   
  51   // update the access_flags for the field in the klass
  52   void update_klass_field_access_flag() {
  53     InstanceKlass* ik = field_holder();
  54     ik->field(index())->set_access_flags(_access_flags.as_short());
  55   }
  56 
  57   FieldInfo* field() const {
  58     if (_is_accessor) {
  59       return _accessor_info;
  60     }else {
  61       InstanceKlass* ik = field_holder();
  62       return ik->field(_index);
  63     }
  64   }
  65 
  66  public:
  67   fieldDescriptor() {
  68     DEBUG_ONLY(_index = badInt);
  69     _is_accessor = false;
  70     _index = -1;
  71     _accessor_info = NULL;
  72   }
  73   fieldDescriptor(InstanceKlass* ik, int index) {
  74     DEBUG_ONLY(_index = badInt);
  75     reinitialize(ik, index);
  76   }
  77   
  78   void set_sig_for_accessor(Symbol* sig) {
  79       this->_sig_for_accessor = sig;
  80   }
  81   
  82   void set_field_name_from_accessor(u2 field_name_from_accessor) {
  83     this->_field_name_from_accessor = field_name_from_accessor;
  84   }
  85   
  86   bool is_accessor() {
  87     return _is_accessor;
  88   }
  89   
  90   u2 get_get_accessor() {
  91     return _getAccessor;
  92   }
  93   
  94   u2 get_put_accessor() {
  95     return _putAccessor;
  96   }
  97   
  98   void set_get_accessor(u2 index) {
  99     _getAccessor = index;
 100   }
 101   
 102   void set_put_accessor(u2 index) {
 103     _putAccessor = index;
 104   }
 105   
 106   Symbol* name() const {
 107     return _is_accessor ? constants()->symbol_at(_field_name_from_accessor) :  field()->name(_cp);
 108   }
 109   Symbol* signature() const {
 110     return _is_accessor ? _sig_for_accessor : field()->signature(_cp);
 111   }
 112   InstanceKlass* field_holder()   const    { return _cp->pool_holder(); }
 113   ConstantPool* constants()       const    { return _cp(); }
 114   AccessFlags access_flags()      const    { return _access_flags; }
 115   oop loader()                    const;
 116   // Offset (in words) of field from start of instanceOop / Klass*
 117   int offset()                    const    { return field()->offset(); }
 118   Symbol* generic_signature()     const;
 119   int index()                     const    { return _index; }
 120   AnnotationArray* annotations()  const;
 121   AnnotationArray* type_annotations()  const;
 122 
 123   // Initial field value
 124   bool has_initial_value()        const    { return field()->initval_index() != 0; }
 125   int initial_value_index()       const    { return field()->initval_index(); }
 126   constantTag initial_value_tag() const;  // The tag will return true on one of is_int(), is_long(), is_single(), is_double()
 127   jint int_initial_value()        const;
 128   jlong long_initial_value()      const;
 129   jfloat float_initial_value()    const;
 130   jdouble double_initial_value()  const;


 146 
 147   bool is_synthetic()             const    { return access_flags().is_synthetic(); }
 148 
 149   bool is_field_access_watched()  const    { return access_flags().is_field_access_watched(); }
 150   bool is_field_modification_watched() const
 151                                            { return access_flags().is_field_modification_watched(); }
 152   bool has_generic_signature()    const    { return access_flags().field_has_generic_signature(); }
 153 
 154   void set_is_field_access_watched(const bool value) {
 155     _access_flags.set_is_field_access_watched(value);
 156     update_klass_field_access_flag();
 157   }
 158 
 159   void set_is_field_modification_watched(const bool value) {
 160     _access_flags.set_is_field_modification_watched(value);
 161     update_klass_field_access_flag();
 162   }
 163 
 164   // Initialization
 165   void reinitialize(InstanceKlass* ik, int index);
 166   void reinitialize_accessor(InstanceKlass* ik);
 167 
 168   // Print
 169   void print() { print_on(tty); }
 170   void print_on(outputStream* st) const         PRODUCT_RETURN;
 171   void print_on_for(outputStream* st, oop obj)  PRODUCT_RETURN;
 172   void verify() const                           PRODUCT_RETURN;
 173 };
 174 
 175 #endif // SHARE_VM_RUNTIME_FIELDDESCRIPTOR_HPP
< prev index next >