com.google.gwt.user.client.CommandExecutor Maven / Gradle / Ivy
/*
* Copyright 2007 Google Inc.
*
* Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* 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.gwt.user.client;
import com.google.gwt.core.client.Duration;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
* Class which executes {@link Command}s and {@link IncrementalCommand}s after
* all currently pending event handlers have completed. This class attempts to
* protect against slow script warnings by running commands in small time
* increments.
*
*
* It is still possible that a poorly written command could cause a slow script
* warning which a user may choose to cancel. In that event, a
* {@link CommandCanceledException} or an
* {@link IncrementalCommandCanceledException} is reported through
* {@link GWT#reportUncaughtException} depending on the type of command which
* caused the warning. All other commands will continue to be executed.
*
*
* TODO(mmendez): Can an SSW be detected without using a timer? Currently, if a
* {@link Command} or an {@link IncrementalCommand} calls either
* {@link Window#alert(String)} or the JavaScript alert(String)
* methods directly or indirectly then the cancellation timer can fire,
* resulting in a false SSW cancellation detection.
*/
class CommandExecutor {
/**
* A circular iterator used by this class. This iterator will wrap back to
* zero when it hits the end of the commands.
*/
private class CircularIterator implements Iterator