2 * Copyright (C) 2009 Apple Inc. All Rights Reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 #include <wtf/ByteArray.h>
35 class JSByteArray
: public JSObject
{
36 friend class JSGlobalData
;
38 bool canAccessIndex(unsigned i
) { return i
< m_storage
->length(); }
39 JSValue
getIndex(ExecState
* exec
, unsigned i
)
41 ASSERT(canAccessIndex(i
));
42 return jsNumber(exec
, m_storage
->data()[i
]);
45 void setIndex(unsigned i
, int value
)
47 ASSERT(canAccessIndex(i
));
54 m_storage
->data()[i
] = static_cast<unsigned char>(value
);
57 void setIndex(unsigned i
, double value
)
59 ASSERT(canAccessIndex(i
));
60 if (!(value
> 0)) // Clamp NaN to 0
64 m_storage
->data()[i
] = static_cast<unsigned char>(value
+ 0.5);
67 void setIndex(ExecState
* exec
, unsigned i
, JSValue value
)
69 double byteValue
= value
.toNumber(exec
);
70 if (exec
->hadException())
72 if (canAccessIndex(i
))
73 setIndex(i
, byteValue
);
76 JSByteArray(ExecState
* exec
, NonNullPassRefPtr
<Structure
>, WTF::ByteArray
* storage
, const JSC::ClassInfo
* = &s_defaultInfo
);
77 static PassRefPtr
<Structure
> createStructure(JSValue prototype
);
79 virtual bool getOwnPropertySlot(JSC::ExecState
*, const JSC::Identifier
& propertyName
, JSC::PropertySlot
&);
80 virtual bool getOwnPropertySlot(JSC::ExecState
*, unsigned propertyName
, JSC::PropertySlot
&);
81 virtual bool getOwnPropertyDescriptor(ExecState
*, const Identifier
&, PropertyDescriptor
&);
82 virtual void put(JSC::ExecState
*, const JSC::Identifier
& propertyName
, JSC::JSValue
, JSC::PutPropertySlot
&);
83 virtual void put(JSC::ExecState
*, unsigned propertyName
, JSC::JSValue
);
85 virtual void getOwnPropertyNames(JSC::ExecState
*, JSC::PropertyNameArray
&, EnumerationMode mode
= ExcludeDontEnumProperties
);
87 virtual const ClassInfo
* classInfo() const { return m_classInfo
; }
88 static const ClassInfo s_defaultInfo
;
90 size_t length() const { return m_storage
->length(); }
92 WTF::ByteArray
* storage() const { return m_storage
.get(); }
95 virtual ~JSByteArray();
99 static const unsigned StructureFlags
= OverridesGetOwnPropertySlot
| OverridesGetPropertyNames
| JSObject::StructureFlags
;
102 enum VPtrStealingHackType
{ VPtrStealingHack
};
103 JSByteArray(VPtrStealingHackType
)
104 : JSObject(createStructure(jsNull()))
109 RefPtr
<WTF::ByteArray
> m_storage
;
110 const ClassInfo
* m_classInfo
;
113 JSByteArray
* asByteArray(JSValue value
);
114 inline JSByteArray
* asByteArray(JSValue value
)
116 return static_cast<JSByteArray
*>(asCell(value
));
119 inline bool isJSByteArray(JSGlobalData
* globalData
, JSValue v
) { return v
.isCell() && v
.asCell()->vptr() == globalData
->jsByteArrayVPtr
; }
123 #endif // JSByteArray_h