#ifndef StringObject_h
#define StringObject_h
#include "JSWrapperObject.h"
#include "JSString.h"
namespace JSC {
class StringObject : public JSWrapperObject {
public:
StringObject(ExecState*, PassRefPtr<Structure>);
StringObject(ExecState*, PassRefPtr<Structure>, const UString&);
static StringObject* create(ExecState*, JSString*);
virtual bool getOwnPropertySlot(ExecState*, const Identifier& propertyName, PropertySlot&);
virtual bool getOwnPropertySlot(ExecState*, unsigned propertyName, PropertySlot&);
virtual void put(ExecState* exec, const Identifier& propertyName, JSValuePtr, PutPropertySlot&);
virtual bool deleteProperty(ExecState*, const Identifier& propertyName);
virtual void getPropertyNames(ExecState*, PropertyNameArray&);
virtual const ClassInfo* classInfo() const { return &info; }
static const ClassInfo info;
JSString* internalValue() const { return asString(JSWrapperObject::internalValue());}
static PassRefPtr<Structure> createStructure(JSValuePtr prototype)
{
return Structure::create(prototype, TypeInfo(ObjectType));
}
protected:
StringObject(PassRefPtr<Structure>, JSString*);
private:
virtual UString toString(ExecState*) const;
virtual UString toThisString(ExecState*) const;
virtual JSString* toThisJSString(ExecState*);
};
StringObject* asStringObject(JSValuePtr);
inline StringObject* asStringObject(JSValuePtr value)
{
ASSERT(asObject(value)->inherits(&StringObject::info));
return static_cast<StringObject*>(asObject(value));
}
}
#endif // StringObject_h