268 }
269
270 inline bool java_lang_invoke_ResolvedMethodName::is_instance(oop obj) {
271 return obj != nullptr && obj->klass() == vmClasses::ResolvedMethodName_klass();
272 }
273
274 inline bool java_lang_invoke_MethodType::is_instance(oop obj) {
275 return obj != nullptr && obj->klass() == vmClasses::MethodType_klass();
276 }
277
278 inline bool java_lang_invoke_MethodHandle::is_instance(oop obj) {
279 return obj != nullptr && is_subclass(obj->klass());
280 }
281
282 inline bool java_lang_Class::is_instance(oop obj) {
283 return obj != nullptr && obj->klass() == vmClasses::Class_klass();
284 }
285
286 inline Klass* java_lang_Class::as_Klass(oop java_class) {
287 //%note memory_2
288 assert(java_lang_Class::is_instance(java_class), "must be a Class object");
289 Klass* k = ((Klass*)java_class->metadata_field(_klass_offset));
290 assert(k == nullptr || k->is_klass(), "type check");
291 return k;
292 }
293
294 inline InstanceKlass* java_lang_Class::as_InstanceKlass(oop java_class) {
295 Klass* k = as_Klass(java_class);
296 assert(k == nullptr || k->is_instance_klass(), "type check");
297 return static_cast<InstanceKlass*>(k);
298 }
299
300 inline bool java_lang_Class::is_primitive(oop java_class) {
301 // should assert:
302 // assert(java_lang_Class::is_instance(java_class), "must be a Class object");
303 bool is_primitive = (java_class->metadata_field(_klass_offset) == nullptr);
304
305 #ifdef ASSERT
306 // The heapwalker walks through Classes that have had their Klass pointers removed, so can't assert this.
307 // assert(is_primitive == java_class->bool_field(_is_primitive_offset), "must match what we told Java");
308 if (java_class->bool_field(_is_primitive_offset)) {
|
268 }
269
270 inline bool java_lang_invoke_ResolvedMethodName::is_instance(oop obj) {
271 return obj != nullptr && obj->klass() == vmClasses::ResolvedMethodName_klass();
272 }
273
274 inline bool java_lang_invoke_MethodType::is_instance(oop obj) {
275 return obj != nullptr && obj->klass() == vmClasses::MethodType_klass();
276 }
277
278 inline bool java_lang_invoke_MethodHandle::is_instance(oop obj) {
279 return obj != nullptr && is_subclass(obj->klass());
280 }
281
282 inline bool java_lang_Class::is_instance(oop obj) {
283 return obj != nullptr && obj->klass() == vmClasses::Class_klass();
284 }
285
286 inline Klass* java_lang_Class::as_Klass(oop java_class) {
287 //%note memory_2
288 //assert(java_lang_Class::is_instance(java_class), "must be a Class object");
289 Klass* k = ((Klass*)java_class->metadata_field(_klass_offset));
290 assert(k == nullptr || k->is_klass(), "type check");
291 return k;
292 }
293
294 inline InstanceKlass* java_lang_Class::as_InstanceKlass(oop java_class) {
295 Klass* k = as_Klass(java_class);
296 assert(k == nullptr || k->is_instance_klass(), "type check");
297 return static_cast<InstanceKlass*>(k);
298 }
299
300 inline bool java_lang_Class::is_primitive(oop java_class) {
301 // should assert:
302 // assert(java_lang_Class::is_instance(java_class), "must be a Class object");
303 bool is_primitive = (java_class->metadata_field(_klass_offset) == nullptr);
304
305 #ifdef ASSERT
306 // The heapwalker walks through Classes that have had their Klass pointers removed, so can't assert this.
307 // assert(is_primitive == java_class->bool_field(_is_primitive_offset), "must match what we told Java");
308 if (java_class->bool_field(_is_primitive_offset)) {
|