byteArrayKlass.hpp

Go to the documentation of this file.
00001 /* Copyright 1994, 1995 LongView Technologies L.L.C. $Revision: 1.24 $ */
00002 /* Copyright (c) 2006, Sun Microsystems, Inc.
00003 All rights reserved.
00004 
00005 Redistribution and use in source and binary forms, with or without modification, are permitted provided that the 
00006 following conditions are met:
00007 
00008     * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following 
00010           disclaimer in the documentation and/or other materials provided with the distribution.
00011     * Neither the name of Sun Microsystems nor the names of its contributors may be used to endorse or promote products derived 
00012           from this software without specific prior written permission.
00013 
00014 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT 
00015 NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL 
00016 THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 
00017 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
00018 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
00019 OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
00020 
00021 
00022 */
00023 
00024 class byteArrayKlass: public memOopKlass {
00025  public:
00026   // allocation properties
00027   bool can_inline_allocation() const { return false; }
00028 
00029   // Return the oop size for a byteArrayOop
00030   int object_size(int number_of_bytes) const {
00031     return   non_indexable_size() + 1
00032            + roundTo(number_of_bytes, oopSize) / oopSize;
00033   }
00034 
00035   // Layout
00036   int length_offset() const             { return non_indexable_size(); }
00037   int array_offset() const              { return non_indexable_size() + 1; }
00038 
00039   // creation operations
00040   oop allocateObject();
00041   oop allocateObjectSize(int bytes);
00042 
00043   // creates invocation
00044   klassOop create_subclass(mixinOop mixin, Format format);
00045 
00046   static klassOop create_class(klassOop super_class, mixinOop mixin);
00047 
00048   // Format
00049   Format format() { return byteArray_klass; }
00050 
00051   // Initialize the object
00052   void initialize_object(byteArrayOop obj, char* value, int len);
00053 
00054   friend void set_byteArrayKlass_vtbl(Klass* k);
00055 
00056   char* name() const { return "byteArray"; }
00057 
00058  // ALL FUNCTIONS BELOW THIS POINT ARE DISPATCHED FROM AN OOP 
00059  public:
00060   // accessors
00061   int  oop_size(oop obj) const { return object_size(byteArrayOop(obj)->length()); }
00062 
00063   int  oop_scavenge_contents(oop obj);
00064   int  oop_scavenge_tenured_contents(oop obj);
00065 
00066   bool oop_verify(oop obj);
00067   void oop_print_value_on(oop obj, outputStream* st);
00068 
00069   // iterators
00070   void oop_oop_iterate(oop obj, OopClosure* blk);
00071   void oop_layout_iterate(oop obj, ObjectLayoutClosure* blk);
00072 
00073   // Sizing
00074   int oop_header_size() const { return byteArrayOopDesc::header_size(); }
00075 
00076   // testers
00077   bool oop_is_byteArray() const { return true; }
00078   bool oop_is_indexable() const { return true; }
00079 
00080 };

Generated on Mon Oct 9 13:37:04 2006 for Strongtalk VM by  doxygen 1.4.7