Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Unified Diff: plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableImpl.java

Issue 11659028: Rename JsVariableImpl -> JsVariableBase (Closed) Base URL: https://chromedevtools.googlecode.com/svn/trunk
Patch Set: clean Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableBase.java ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableImpl.java
diff --git a/plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableImpl.java b/plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableImpl.java
deleted file mode 100644
index 3b0af565114c88ed3ae984cc9467c11814bc3745..0000000000000000000000000000000000000000
--- a/plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableImpl.java
+++ /dev/null
@@ -1,153 +0,0 @@
-// Copyright (c) 2009 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-package org.chromium.sdk.internal.v8native.value;
-
-
-import org.chromium.sdk.JsEvaluateContext.EvaluateCallback;
-import org.chromium.sdk.JsFunction;
-import org.chromium.sdk.JsValue;
-import org.chromium.sdk.JsValue.Type;
-import org.chromium.sdk.JsObjectProperty;
-import org.chromium.sdk.JsVariable;
-import org.chromium.sdk.RelayOk;
-import org.chromium.sdk.SyncCallback;
-
-/**
- * A generic implementation of the JsVariable interface.
- * TODO(TBR-robot): rename into JsVariableBase
- */
-public abstract class JsVariableImpl implements JsVariable {
-
- /** The lazily constructed value of this variable. */
- private final JsValueBase value;
-
- /** Variable name. */
- private final Object rawName;
-
- /**
- * Constructs a variable contained in the given context with the given
- * value mirror.
- *
- * @param valueLoader that owns this variable
- * @param valueData for this variable
- */
- public JsVariableImpl(ValueLoader valueLoader, ValueMirror valueData, Object rawName) {
- this.rawName = rawName;
- this.value = createValue(valueLoader, valueData);
- }
-
- public static JsValueBase createValue(ValueLoader valueLoader, ValueMirror valueData) {
- Type type = valueData.getType();
- switch (type) {
- case TYPE_FUNCTION:
- return new JsFunctionImpl(valueLoader, valueData);
- case TYPE_ERROR:
- case TYPE_OBJECT:
- case TYPE_DATE:
- case TYPE_REGEXP:
- return new JsObjectBase.Impl(valueLoader, valueData);
- case TYPE_ARRAY:
- return new JsArrayImpl(valueLoader, valueData);
- default:
- return new JsValueBase.Impl(valueData);
- }
- }
-
-
- /**
- * @return a [probably compound] JsValue corresponding to this variable.
- * {@code null} if there was an error lazy-loading the value data.
- */
- @Override
- public JsValueBase getValue() {
- return value;
- }
-
- @Override
- public String getName() {
- return rawName.toString();
- }
-
- Object getRawNameAsObject() {
- return this.rawName;
- }
-
- @Override
- public boolean isMutable() {
- return false; // TODO(apavlov): fix once V8 supports it
- }
-
- @Override
- public boolean isReadable() {
- // TODO(apavlov): implement once the readability metadata are available
- return true;
- }
-
- @Override
- public synchronized void setValue(String newValue, SetValueCallback callback) {
- // TODO(apavlov): currently V8 does not support it
- if (!isMutable()) {
- throw new UnsupportedOperationException();
- }
- }
-
- @Override
- public String toString() {
- return new StringBuilder()
- .append("[JsVariable: name=")
- .append(getName())
- .append(",value=")
- .append(getValue())
- .append(']')
- .toString();
- }
-
- /**
- * A non-abstract class that implements JsVariable.
- */
- public static class Impl extends JsVariableImpl {
- public Impl(ValueLoader valueLoader, ValueMirror valueData, Object rawName) {
- super(valueLoader, valueData, rawName);
- }
-
- @Override public JsObjectProperty asObjectProperty() {
- return null;
- }
- }
-
- /**
- * An extension to {@JsVariableImpl} that additional provides {@link JsObjectProperty} interface.
- * TODO: properly support getters, setters etc. once supported by protocol.
- */
- static class Property extends JsVariableImpl implements JsObjectProperty {
- public Property(ValueLoader valueLoader, ValueMirror valueData, Object rawName) {
- super(valueLoader, valueData, rawName);
- }
- @Override public JsObjectProperty asObjectProperty() {
- return this;
- }
- @Override public boolean isWritable() {
- return true;
- }
- @Override public JsValue getGetter() {
- return null;
- }
- @Override public JsFunction getGetterAsFunction() {
- return null;
- }
- @Override public JsValue getSetter() {
- return null;
- }
- @Override public boolean isConfigurable() {
- return true;
- }
- @Override public boolean isEnumerable() {
- return true;
- }
- @Override public RelayOk evaluateGet(EvaluateCallback callback, SyncCallback syncCallback) {
- throw new RuntimeException();
- }
- }
-}
« no previous file with comments | « plugins/org.chromium.sdk/src/org/chromium/sdk/internal/v8native/value/JsVariableBase.java ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698