annotate src/share/vm/oops/arrayKlassKlass.hpp @ 196:d1605aabd0a1

6719955: Update copyright year Summary: Update copyright year for files that have been modified in 2008 Reviewed-by: ohair, tbell
author xdono
date Wed, 02 Jul 2008 12:55:16 -0700
parents
children 4e6abf09f540
rev   line source
duke@0 1 /*
duke@0 2 * Copyright 1997-2006 Sun Microsystems, Inc. All Rights Reserved.
duke@0 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@0 4 *
duke@0 5 * This code is free software; you can redistribute it and/or modify it
duke@0 6 * under the terms of the GNU General Public License version 2 only, as
duke@0 7 * published by the Free Software Foundation.
duke@0 8 *
duke@0 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@0 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@0 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@0 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@0 13 * accompanied this code).
duke@0 14 *
duke@0 15 * You should have received a copy of the GNU General Public License version
duke@0 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@0 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@0 18 *
duke@0 19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
duke@0 20 * CA 95054 USA or visit www.sun.com if you need additional information or
duke@0 21 * have any questions.
duke@0 22 *
duke@0 23 */
duke@0 24
duke@0 25 // arrayKlassKlass is the abstract baseclass for all array class classes
duke@0 26
duke@0 27 class arrayKlassKlass : public klassKlass {
duke@0 28 public:
duke@0 29 // Testing
duke@0 30 bool oop_is_arrayKlass() const { return true; }
duke@0 31
duke@0 32 // Allocation
duke@0 33 DEFINE_ALLOCATE_PERMANENT(arrayKlassKlass);
duke@0 34 static klassOop create_klass(TRAPS);
duke@0 35
duke@0 36 // Casting from klassOop
duke@0 37 static arrayKlassKlass* cast(klassOop k) {
duke@0 38 assert(k->klass_part()->oop_is_klass(), "cast to arrayKlassKlass");
duke@0 39 return (arrayKlassKlass*) k->klass_part();
duke@0 40 }
duke@0 41
duke@0 42 // Sizing
duke@0 43 static int header_size() { return oopDesc::header_size() + sizeof(arrayKlassKlass)/HeapWordSize; }
duke@0 44 int object_size() const { return align_object_size(header_size()); }
duke@0 45
duke@0 46 // Garbage collection
duke@0 47 void oop_follow_contents(oop obj);
duke@0 48 int oop_adjust_pointers(oop obj);
duke@0 49 bool oop_is_parsable(oop obj) const;
duke@0 50
duke@0 51 // Parallel Scavenge and Parallel Old
duke@0 52 PARALLEL_GC_DECLS
duke@0 53
duke@0 54 // Iterators
duke@0 55 int oop_oop_iterate(oop obj, OopClosure* blk);
duke@0 56 int oop_oop_iterate_m(oop obj, OopClosure* blk, MemRegion mr);
duke@0 57
duke@0 58 #ifndef PRODUCT
duke@0 59 public:
duke@0 60 // Printing
duke@0 61 void oop_print_on(oop obj, outputStream* st);
duke@0 62 void oop_print_value_on(oop obj, outputStream* st);
duke@0 63 #endif
duke@0 64
duke@0 65 public:
duke@0 66 // Verification
duke@0 67 const char* internal_name() const;
duke@0 68 void oop_verify_on(oop obj, outputStream* st);
duke@0 69 };