/*
* Copyright (c) 2012, the Dart project authors.
*
* Licensed under the Eclipse Public License v1.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.eclipse.org/legal/epl-v10.html
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package com.google.dart.tools.debug.core.expr;
import com.google.dart.tools.core.utilities.general.AdapterUtilities;
import org.eclipse.debug.core.model.IDebugElement;
import org.eclipse.debug.core.model.IWatchExpressionDelegate;
import org.eclipse.debug.core.model.IWatchExpressionListener;
/**
* An implementation of a watch expression delegate. Used to asynchronously evaluate expressions in
* certain contexts (like debugger call frames).
*
* @see IWatchExpressionDelegate
*/
public class WatchExpressionDelegate implements IWatchExpressionDelegate {
/**
* Evaluates the given expression in the given context asynchronously and notifies the given
* listener when the evaluation finishes.
*
* @param expression the expression to evaluate
* @param context the context for the evaluation
* @param listener the listener to notify when the evaluation completes
*/
@Override
public void evaluateExpression(String expression, IDebugElement context,
IWatchExpressionListener listener) {
IExpressionEvaluator expressionEvaluator = AdapterUtilities.getAdapter(
context,
IExpressionEvaluator.class);
if (expressionEvaluator != null) {
expressionEvaluator.evaluateExpression(expression, listener);
} else {
listener.watchEvaluationFinished(WatchExpressionResult.noOp(expression));
}
}
}