| Index: src/extensions/gc-extension.cc
|
| diff --git a/src/extensions/gc-extension.cc b/src/extensions/gc-extension.cc
|
| index 205587f41cbf10e0f76efd01483b96042782cf8c..1d4873de73ed01d99a81d8a9bf6af3b90764a446 100644
|
| --- a/src/extensions/gc-extension.cc
|
| +++ b/src/extensions/gc-extension.cc
|
| @@ -40,28 +40,9 @@ v8::Handle<v8::FunctionTemplate> GCExtension::GetNativeFunctionTemplate(
|
|
|
|
|
| void GCExtension::GC(const v8::FunctionCallbackInfo<v8::Value>& args) {
|
| - i::Isolate* isolate = reinterpret_cast<i::Isolate*>(args.GetIsolate());
|
| - if (args[0]->BooleanValue()) {
|
| - isolate->heap()->CollectGarbage(
|
| - NEW_SPACE, "gc extension", v8::kGCCallbackFlagForced);
|
| - } else {
|
| - isolate->heap()->CollectAllGarbage(
|
| - Heap::kNoGCFlags, "gc extension", v8::kGCCallbackFlagForced);
|
| - }
|
| -}
|
| -
|
| -
|
| -void GCExtension::Register() {
|
| - static char buffer[50];
|
| - Vector<char> temp_vector(buffer, sizeof(buffer));
|
| - if (FLAG_expose_gc_as != NULL && strlen(FLAG_expose_gc_as) != 0) {
|
| - OS::SNPrintF(temp_vector, "native function %s();", FLAG_expose_gc_as);
|
| - } else {
|
| - OS::SNPrintF(temp_vector, "native function gc();");
|
| - }
|
| -
|
| - static GCExtension gc_extension(buffer);
|
| - static v8::DeclareExtension declaration(&gc_extension);
|
| + args.GetIsolate()->RequestGarbageCollectionForTesting(
|
| + args[0]->BooleanValue() ? v8::Isolate::kMinorGarbageCollection
|
| + : v8::Isolate::kFullGarbageCollection);
|
| }
|
|
|
| } } // namespace v8::internal
|
|
|