blob: ad3cd4b7f02622c37090b00a665d09c65cdf1394 [file] [log] [blame]
/*
* Copyright 2000-2009 JetBrains s.r.o.
*
* 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.intellij.openapi.progress.util;
import com.intellij.ide.IdeEventQueue;
import com.intellij.openapi.diagnostic.Logger;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.util.SystemInfo;
import com.intellij.openapi.application.impl.LaterInvocator;
public class DispatchThreadProgressWindow extends ProgressWindow{
private static final Logger LOG = Logger.getInstance("#com.intellij.openapi.progress.util.DispatchThreadProgressWindow");
private long myLastPumpEventsTime = 0;
private static final int PUMP_INTERVAL = SystemInfo.isWindows ? 100 : 500;
private Runnable myRunnable;
public DispatchThreadProgressWindow(boolean shouldShowCancel, Project project) {
super(shouldShowCancel, project);
}
public void setText(String text) {
super.setText(text);
pumpEvents();
}
public void setFraction(double fraction) {
super.setFraction(fraction);
pumpEvents();
}
public void setText2(String text) {
super.setText2(text);
pumpEvents();
}
private void pumpEvents() {
long time = System.currentTimeMillis();
if (time - myLastPumpEventsTime < PUMP_INTERVAL) return;
myLastPumpEventsTime = time;
IdeEventQueue.getInstance().flushQueue();
}
@Override
protected void prepareShowDialog() {
if (myRunnable != null) {
LaterInvocator.invokeLater(myRunnable, getModalityState());
}
showDialog();
}
public void setRunnable(final Runnable runnable) {
myRunnable = runnable;
}
}