| Index: src/runtime/runtime-symbol.cc
|
| diff --git a/src/runtime/runtime-symbol.cc b/src/runtime/runtime-symbol.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..4d333ac25741b973cb04986d5a94be7843afd588
|
| --- /dev/null
|
| +++ b/src/runtime/runtime-symbol.cc
|
| @@ -0,0 +1,101 @@
|
| +// Copyright 2014 the V8 project authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "src/v8.h"
|
| +
|
| +#include "src/arguments.h"
|
| +#include "src/runtime/runtime.h"
|
| +#include "src/runtime/runtime-utils.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +
|
| +RUNTIME_FUNCTION(Runtime_CreateSymbol) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_HANDLE_CHECKED(Object, name, 0);
|
| + RUNTIME_ASSERT(name->IsString() || name->IsUndefined());
|
| + Handle<Symbol> symbol = isolate->factory()->NewSymbol();
|
| + if (name->IsString()) symbol->set_name(*name);
|
| + return *symbol;
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_CreatePrivateSymbol) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_HANDLE_CHECKED(Object, name, 0);
|
| + RUNTIME_ASSERT(name->IsString() || name->IsUndefined());
|
| + Handle<Symbol> symbol = isolate->factory()->NewPrivateSymbol();
|
| + if (name->IsString()) symbol->set_name(*name);
|
| + return *symbol;
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_CreatePrivateOwnSymbol) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_HANDLE_CHECKED(Object, name, 0);
|
| + RUNTIME_ASSERT(name->IsString() || name->IsUndefined());
|
| + Handle<Symbol> symbol = isolate->factory()->NewPrivateOwnSymbol();
|
| + if (name->IsString()) symbol->set_name(*name);
|
| + return *symbol;
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_CreateGlobalPrivateOwnSymbol) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_HANDLE_CHECKED(String, name, 0);
|
| + Handle<JSObject> registry = isolate->GetSymbolRegistry();
|
| + Handle<String> part = isolate->factory()->private_intern_string();
|
| + Handle<Object> privates;
|
| + ASSIGN_RETURN_FAILURE_ON_EXCEPTION(
|
| + isolate, privates, Object::GetPropertyOrElement(registry, part));
|
| + Handle<Object> symbol;
|
| + ASSIGN_RETURN_FAILURE_ON_EXCEPTION(
|
| + isolate, symbol, Object::GetPropertyOrElement(privates, name));
|
| + if (!symbol->IsSymbol()) {
|
| + DCHECK(symbol->IsUndefined());
|
| + symbol = isolate->factory()->NewPrivateSymbol();
|
| + Handle<Symbol>::cast(symbol)->set_name(*name);
|
| + Handle<Symbol>::cast(symbol)->set_is_own(true);
|
| + JSObject::SetProperty(Handle<JSObject>::cast(privates), name, symbol,
|
| + STRICT).Assert();
|
| + }
|
| + return *symbol;
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_NewSymbolWrapper) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_HANDLE_CHECKED(Symbol, symbol, 0);
|
| + return *Object::ToObject(isolate, symbol).ToHandleChecked();
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_SymbolDescription) {
|
| + SealHandleScope shs(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_CHECKED(Symbol, symbol, 0);
|
| + return symbol->name();
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_SymbolRegistry) {
|
| + HandleScope scope(isolate);
|
| + DCHECK(args.length() == 0);
|
| + return *isolate->GetSymbolRegistry();
|
| +}
|
| +
|
| +
|
| +RUNTIME_FUNCTION(Runtime_SymbolIsPrivate) {
|
| + SealHandleScope shs(isolate);
|
| + DCHECK(args.length() == 1);
|
| + CONVERT_ARG_CHECKED(Symbol, symbol, 0);
|
| + return isolate->heap()->ToBoolean(symbol->is_private());
|
| +}
|
| +}
|
| +} // namespace v8::internal
|
|
|