| Index: src/execution.cc
|
| diff --git a/src/execution.cc b/src/execution.cc
|
| index 006d358eaaa5c84d7323a15bb85cf88ec03ec4bc..a6b15ccb450010074abcf392fe33e414b5969503 100644
|
| --- a/src/execution.cc
|
| +++ b/src/execution.cc
|
| @@ -679,7 +679,7 @@ Object* Execution::HandleStackGuardInterrupt() {
|
|
|
| // --- G C E x t e n s i o n ---
|
|
|
| -const char* GCExtension::kSource = "native function gc();";
|
| +const char* const GCExtension::kSource = "native function gc();";
|
|
|
|
|
| v8::Handle<v8::FunctionTemplate> GCExtension::GetNativeFunction(
|
| @@ -695,7 +695,115 @@ v8::Handle<v8::Value> GCExtension::GC(const v8::Arguments& args) {
|
| }
|
|
|
|
|
| -static GCExtension kGCExtension;
|
| -v8::DeclareExtension kGCExtensionDeclaration(&kGCExtension);
|
| +static GCExtension gc_extension;
|
| +static v8::DeclareExtension gc_extension_declaration(&gc_extension);
|
| +
|
| +
|
| +// --- E x t e r n a l i z e S t r i n g E x t e n s i o n ---
|
| +
|
| +
|
| +template <typename Char, typename Base>
|
| +class SimpleStringResource : public Base {
|
| + public:
|
| + // Takes ownership of |data|.
|
| + SimpleStringResource(Char* data, size_t length)
|
| + : data_(data),
|
| + length_(length) {}
|
| +
|
| + virtual ~SimpleStringResource() { delete data_; }
|
| +
|
| + virtual const Char* data() const { return data_; }
|
| +
|
| + virtual size_t length() const { return length_; }
|
| +
|
| + private:
|
| + Char* const data_;
|
| + const size_t length_;
|
| +};
|
| +
|
| +
|
| +typedef SimpleStringResource<char, v8::String::ExternalAsciiStringResource>
|
| + SimpleAsciiStringResource;
|
| +typedef SimpleStringResource<uc16, v8::String::ExternalStringResource>
|
| + SimpleTwoByteStringResource;
|
| +
|
| +
|
| +const char* const ExternalizeStringExtension::kSource =
|
| + "native function externalizeString();"
|
| + "native function isAsciiString();";
|
| +
|
| +
|
| +v8::Handle<v8::FunctionTemplate> ExternalizeStringExtension::GetNativeFunction(
|
| + v8::Handle<v8::String> str) {
|
| + if (strcmp(*v8::String::AsciiValue(str), "externalizeString") == 0) {
|
| + return v8::FunctionTemplate::New(ExternalizeStringExtension::Externalize);
|
| + } else {
|
| + ASSERT(strcmp(*v8::String::AsciiValue(str), "isAsciiString") == 0);
|
| + return v8::FunctionTemplate::New(ExternalizeStringExtension::IsAscii);
|
| + }
|
| +}
|
| +
|
| +
|
| +v8::Handle<v8::Value> ExternalizeStringExtension::Externalize(
|
| + const v8::Arguments& args) {
|
| + if (args.Length() < 1 || !args[0]->IsString()) {
|
| + return v8::ThrowException(v8::String::New(
|
| + "First parameter to externalizeString() must be a string."));
|
| + }
|
| + bool force_two_byte = false;
|
| + if (args.Length() >= 2) {
|
| + if (args[1]->IsBoolean()) {
|
| + force_two_byte = args[1]->BooleanValue();
|
| + } else {
|
| + return v8::ThrowException(v8::String::New(
|
| + "Second parameter to externalizeString() must be a boolean."));
|
| + }
|
| + }
|
| + bool result = false;
|
| + Handle<String> string = Utils::OpenHandle(*args[0].As<v8::String>());
|
| + if (string->IsExternalString()) {
|
| + return v8::ThrowException(v8::String::New(
|
| + "externalizeString() can't externalize twice."));
|
| + }
|
| + if (string->IsAsciiRepresentation() && !force_two_byte) {
|
| + char* data = new char[string->length()];
|
| + String::WriteToFlat(*string, data, 0, string->length());
|
| + SimpleAsciiStringResource* resource = new SimpleAsciiStringResource(
|
| + data, string->length());
|
| + result = string->MakeExternal(resource);
|
| + if (result && !string->IsSymbol()) {
|
| + i::ExternalStringTable::AddString(*string);
|
| + }
|
| + } else {
|
| + uc16* data = new uc16[string->length()];
|
| + String::WriteToFlat(*string, data, 0, string->length());
|
| + SimpleTwoByteStringResource* resource = new SimpleTwoByteStringResource(
|
| + data, string->length());
|
| + result = string->MakeExternal(resource);
|
| + if (result && !string->IsSymbol()) {
|
| + i::ExternalStringTable::AddString(*string);
|
| + }
|
| + }
|
| + if (!result) {
|
| + return v8::ThrowException(v8::String::New("externalizeString() failed."));
|
| + }
|
| + return v8::Undefined();
|
| +}
|
| +
|
| +
|
| +v8::Handle<v8::Value> ExternalizeStringExtension::IsAscii(
|
| + const v8::Arguments& args) {
|
| + if (args.Length() != 1 || !args[0]->IsString()) {
|
| + return v8::ThrowException(v8::String::New(
|
| + "isAsciiString() requires a single string argument."));
|
| + }
|
| + return Utils::OpenHandle(*args[0].As<v8::String>())->IsAsciiRepresentation() ?
|
| + v8::True() : v8::False();
|
| +}
|
| +
|
| +
|
| +static ExternalizeStringExtension externalize_extension;
|
| +static v8::DeclareExtension externalize_extension_declaration(
|
| + &externalize_extension);
|
|
|
| } } // namespace v8::internal
|
|
|