Eclipse UI blockiert - laengere Ablaeufe auf dem main-Thread..?

sirbender

Top Contributor
Hi,

ich versuche gerade ein Eclipse plug-in zu verbessern, dass von anderen geschrieben wurde. Es wir bei diesem plug-in ein Eclipse Remote Projekt angelegt. Es ist so implementiert, dass Eclipse nicht merkt, dass es sich um ein Remote-Filesystem handelt. Die Kommunikation/Filesynchronisierung geschieht ueber SFTP.

Das Problem ist, dass einige dieser recht langen File-Operationen von dem Programmierer scheinbar im main-Thread ausgefuehrt werden und wie ich annehme die UI deswegen nicht neu gezeichnet wird.

Generell meine Frage: ist es legal Operationen in Eclipse auf dem main-Thread auszufuehren? Wird dazu geraten eher Worker zu starten? Was sind da so die Regeln/Empfehlungen?

Danke!
 

Wildcard

Top Contributor
*verschoben*
Eclipse hat bereits API um Remote Dateisysteme einzubinden. Die entsprechende Abstraktionsschicht heißt EFS (Eclipse File System).
Long Running Operations werden üblicherweise in einem Eclipse Job ausgeführt. Bei Dingen wie aufklappen der Verzeichnisstruktur (was bei Remote Dateisystemen länger dauern kann) gibt es ebenfalls unterstützung für asynchrone Ausführung. Hier kommen dann LazyContentProvider zum Einsatz.
 

sirbender

Top Contributor
Ich weiss ueber das EFS Bescheid. Es wird auch in dem Plug-in genutzt. Das Problem ist folgendes:

Soll ein File remotely ausgeschrieben werden, ruft FileSystemResourceManager in seiner write-Methode folgenden code auf:
OutputStream out = store.openOutputStream(options, Policy.subMonitorFor(monitor, 0));

Dieser Ausruf geschieht im main Thread und will einen OutputStream in den es schreiben kann. Diesen OutputStream muss ich selbst erstellen und zurueckliefern. Wie also soll ich dem Aufrufer sagen, dass er doch bitte nicht im main-Thread in the OutputStream schreibt den ich ihm gebe sondern z.B. in einem extra Worker-Thread bzw. via LazyContentProvider?




org.eclipse.core.internal.localstore.FileSystemResourceManager.write(FileSystemResourceManager.java:962)
org.eclipse.core.internal.localstore.FileSystemResourceManager.internalWrite(FileSystemResourceManager.java:539)
org.eclipse.core.internal.resources.Project.writeDescription(Project.java:1196)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1085)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1109)
org.eclipse.cdt.make.internal.core.BuildInfoFactory$BuildInfoProject.putString(BuildInfoFactory.java:490)
org.eclipse.cdt.make.internal.core.BuildInfoFactory$AbstractBuildInfo.setBuildAttribute(BuildInfoFactory.java:99)
 

Wildcard

Top Contributor
Seltsam das der cdt Builder im Main Thread abläuft. Wie wurde die aktion getriggert? Durch eine UI Aktion? Wenn ja, würde ich einen Bug auf CDT öffnen.
 

sirbender

Top Contributor
Hier ist der gesamte Stack falls das hilft. Es ist eine Erweiterung zu CDT. Man legt ein neues Remote Project an und klickt auf Ok. Der Stack wird danach, also waehrend das neue Project angelegt wird geworfen.

Ist das eine Regel oder Konvention dass Builder nicht auf dem main thread laufen duerfen?


com.remoteproj.rm.remotetools.internal.ssh.FileTools.getOutputStream(FileTools.java:331)
com.remoteproj.rm.remote.remotetools.core.RemoteToolsFileStore.openOutputStream(RemoteToolsFileStore.java:365)
org.eclipse.core.internal.localstore.FileSystemResourceManager.write(FileSystemResourceManager.java:962)
org.eclipse.core.internal.localstore.FileSystemResourceManager.internalWrite(FileSystemResourceManager.java:539)
org.eclipse.core.internal.resources.Project.writeDescription(Project.java:1196)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1085)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1109)
org.eclipse.cdt.make.internal.core.BuildInfoFactory$BuildInfoProject.putString(BuildInfoFactory.java:490)
org.eclipse.cdt.make.internal.core.BuildInfoFactory$AbstractBuildInfo.setBuildAttribute(BuildInfoFactory.java:99)
com.remoteproj.rm.rdt.core.resources.RemoteMakeNature.configure(RemoteMakeNature.java:183)
org.eclipse.core.internal.resources.NatureManager$1.run(NatureManager.java:143)
org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
org.eclipse.core.internal.resources.NatureManager.configureNature(NatureManager.java:158)
org.eclipse.core.internal.resources.NatureManager.configureNatures(NatureManager.java:203)
org.eclipse.core.internal.resources.Project.basicSetDescription(Project.java:86)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1081)
org.eclipse.core.internal.resources.Project.setDescription(Project.java:1109)
com.remoteproj.rm.rdt.core.resources.RemoteMakeNature.addNature(RemoteMakeNature.java:59)
com.remoteproj.rm.rdt.ui.wizards.RemoteMakefileWizardHandler.createProject(RemoteMakefileWizardHandler.java:108)
org.eclipse.cdt.ui.wizards.CDTCommonProjectWizard$1$1$1.run(CDTCommonProjectWizard.java:257)
org.eclipse.ui.actions.WorkspaceModifyDelegatingOperation.execute(WorkspaceModifyDelegatingOperation.java:69)
org.eclipse.ui.actions.WorkspaceModifyOperation$1.run(WorkspaceModifyOperation.java:106)
org.eclipse.core.internal.resources.Workspace.run(Workspace.java:1857)
org.eclipse.ui.actions.WorkspaceModifyOperation.run(WorkspaceModifyOperation.java:118)
org.eclipse.jface.operation.ModalContext.runInCurrentThread(ModalContext.java:464)
org.eclipse.jface.operation.ModalContext.run(ModalContext.java:372)
org.eclipse.jface.wizard.WizardDialog.run(WizardDialog.java:946)
org.eclipse.cdt.ui.wizards.CDTCommonProjectWizard$1$1.run(CDTCommonProjectWizard.java:266)
org.eclipse.ui.internal.UILockListener.doPendingWork(UILockListener.java:155)
org.eclipse.ui.internal.UISynchronizer$3.run(UISynchronizer.java:158)
org.eclipse.swt.widgets.RunnableLock.run(RunnableLock.java:35)
org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:134)
org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:3487)
org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3134)
org.eclipse.jface.operation.ModalContext$ModalContextThread.block(ModalContext.java:173)
org.eclipse.jface.operation.ModalContext.run(ModalContext.java:388)
org.eclipse.jface.wizard.WizardDialog.run(WizardDialog.java:946)
org.eclipse.cdt.ui.wizards.CDTCommonProjectWizard.invokeRunnable(CDTCommonProjectWizard.java:179)
org.eclipse.cdt.ui.wizards.CDTCommonProjectWizard.getProject(CDTCommonProjectWizard.java:157)
org.eclipse.cdt.ui.wizards.CDTCommonProjectWizard.performFinish(CDTCommonProjectWizard.java:195)
 

Wildcard

Top Contributor
Ist das eine Regel oder Konvention dass Builder nicht auf dem main thread laufen duerfen?
Builder können long running sein. Long Running Operations werden allerdings grundsätzlich nicht im Dispatcher Thread ausgeführt, da solange die Oberfläche blockiert (wie du ja siehst). Also finde heraus was die Aktion genau triggert und sorg dafür das sie stattdessen in einem Job ausgeführt wird.
 

sirbender

Top Contributor
Danke. Ich kann ja davon ausgehen, dass der Builder auch im main thread ablaeuft, wenn der Code danach im main thread ist, da alle Elemente in einem Stacktrace auch im selben thread ablaufen, oder?

Oder koennte der builder auch in einem anderen als dem main thread ablaufen und der Stack zeigt ihn trotzdem an?
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E OSGi Eclipse Plug-in programmierung: java.lang.NullPointerException: Cannot enter synchronized block because "profile" is null Plattformprogrammierung 4
R Eclipse Bundles Plattformprogrammierung 2
Robertop RCP Command in bereits bestehendes Eclipse-Menü einbauen Plattformprogrammierung 4
T Java Projekt läuft nur in Eclipse Plattformprogrammierung 6
M Eclipse Plugin PreferencePage BooleanFieldEditor Plattformprogrammierung 1
F OSGi Plugin unter Eclipse arbeitet anders als wenn veröffentlicht Plattformprogrammierung 2
D RCP P2-Repository für Eclipse-Plugins Plattformprogrammierung 0
M Debuging in Eclipse Annotations Processor Plattformprogrammierung 0
D Nach Sprachpaket Installation kann eclipse nicht mehr gestartet werden Plattformprogrammierung 4
L0MiN Wie kann ich ein Klassendiagramm aus Eclipse heraus erstellen? Plattformprogrammierung 5
M Eclipse Probleme beim Ausführen eines Programms Plattformprogrammierung 3
feinperligekohlensaeure Eclipse Workspace gemeinsam Nutzen -> keine .project Datei Plattformprogrammierung 1
F Eclipse Build Path auf benötigte Projekte Plattformprogrammierung 4
B Daten von Eclipse extern sichern Plattformprogrammierung 2
B Eclipse zeigt Fehler nach Java-Update auf 1.8.0_40 Plattformprogrammierung 3
VfL_Freak [Eclipse] Fehleranzeige im Reiter "Problems" Plattformprogrammierung 1
S Errors in workspace bei eclipse Plattformprogrammierung 3
T eclipse bietet keine META-INF an Plattformprogrammierung 1
N Eclipse wo starten Plattformprogrammierung 6
A Eclipse schließt einfach ohne Fehlermeldung Plattformprogrammierung 4
W Eclipse vergißt beim Exportieren Resources-Ordner Plattformprogrammierung 11
A RCP Eclipse e4 und Injection-Contexts Plattformprogrammierung 0
K Eclipse fährt nicht mehr hoch. Metadatendatei schuld? Plattformprogrammierung 7
C [Eclipse RCP E4]InjectionException: no actual value was found for the argument "MDirtyable" Plattformprogrammierung 8
T Eclipse Eigenschaften hinzufügen Plattformprogrammierung 2
M RCP [Eclipse RCP 3.4] ViewTab Kontextmenu "Alle schließen" Plattformprogrammierung 0
D Problem mit eclipse Plattformprogrammierung 2
S Verschieben des Verzeichnis .eclipse aus Userprofile Plattformprogrammierung 3
A RCP Kann kein Eclipse 4 Projekt anlegen Plattformprogrammierung 0
S RCP Exportiertes RCP Produkt lädt Datei nicht, bei Start aus Eclipse wird Datei jedoch gefunden Plattformprogrammierung 6
G Eine Library in Eclipse zur Verfügung stellen Plattformprogrammierung 14
Gregorrr Eclipse RCP Product Build-Nummer + Jenkins Plattformprogrammierung 6
R Einfaches Eclipse-Plugin-Beispiel funktioniert nicht Plattformprogrammierung 5
H OSGi OSGi + Logback + slf4j - Eclipse Run Configuration Plattformprogrammierung 7
C plugin development environment eclipse Plattformprogrammierung 4
R RCP Commands nutzen / org.eclipse.ui.file.save Plattformprogrammierung 7
O Installiere externe Methode "containsNone" in Eclipse Plattformprogrammierung 2
M Keybinding in Eclipse Plugin Plattformprogrammierung 3
TheWhiteShadow RCP Konstrukt für Editor in Eclipse gesucht. Plattformprogrammierung 3
B Eclipse Probleme mit build Plattformprogrammierung 8
H Keine Hilfe/API mehr in Eclipse Juno? Plattformprogrammierung 4
B Neue SuppressWarning in Eclipse Juno Plattformprogrammierung 6
B Eclipse Property Page Plattformprogrammierung 6
B Eclipse PreferencePage Plattformprogrammierung 3
B Eclipse Plugin Einstellungsleiste Plattformprogrammierung 2
B Birt-Previewer über Eclipse Plattformprogrammierung 14
J Eclipse Plug-In für UML-Diagramme Problem Plattformprogrammierung 4
O Eclipse Plugin - Einfachstes Problem, das es gibt. Plattformprogrammierung 2
R Eclipse RCP Tabellen-View (Anfängerfrage) Plattformprogrammierung 3
C Eclipse: Notification beim umbennen von Methoden? Plattformprogrammierung 4
schalentier Eclipse Sourcecode Plattformprogrammierung 4
A Eclipse undo/redo button reagiert nicht auf Änderungen in der OperationHistory Plattformprogrammierung 5
P Eclipse M2_REPO (NON MODIFIABLE) Plattformprogrammierung 8
B Eclipse: Contextmenu id erhalten? Plattformprogrammierung 9
H Datei in eclipse wird nicht erkannt Plattformprogrammierung 3
O Neues Tastenkürzel für Eclipse Editorfenster registrieren Plattformprogrammierung 2
3 Eclipse Editor Plugin selektiert Projekt nicht Plattformprogrammierung 10
Madlip RCP eclipse.ui.bindings (Key-Problematik) Plattformprogrammierung 2
S Eclipse vs. JavaMail vs. Ubuntu vs. Windows Plattformprogrammierung 3
M eclipse führt applikationen nicht mehr aus Plattformprogrammierung 6
S Eclipse: Auf CTRL-C/CTRL-V im Package Explorer? Plattformprogrammierung 4
M Eclipse und Hilfen Plattformprogrammierung 5
G Eclipse buggt rum!!! Plattformprogrammierung 4
B Eclipse RCP und Java 7 Plattformprogrammierung 7
G RCP Eclipse Editor + Guice Plattformprogrammierung 8
T RCP Eclipse RCP: Wo/wann im Plugin ist workbench initialisiert? Plattformprogrammierung 14
G Eclipse Plug-in: wie refreshe ich eine combobox? Plattformprogrammierung 4
M Eclipse Plug-in: Wie eine Grafik einfügen? Plattformprogrammierung 20
M RCP [Eclipse RCP] Feature Export und "Fehler"... Plattformprogrammierung 3
P Eclipse speichert keine Änderungen Plattformprogrammierung 5
M Eclipse - Dokumentation nicht über das Internet benutzen Plattformprogrammierung 3
C Eclipse Plugin NoClassDefFoundError Plattformprogrammierung 4
E org.eclipse.ui.dialogs.ListSelectionDialog erzeugt ClassNotFoundException zur Laufzeit Plattformprogrammierung 4
M Eclipse Plugin Entwicklung - NoClassDefFoundError Plattformprogrammierung 10
C RCP Verständnisfrage Eclipse/Equinox Plattformprogrammierung 4
D eclipse-RCP von der Konsole baut nicht Plattformprogrammierung 3
L RCP Eclipse Popupmenu im PackageExplorer erweitern? Plattformprogrammierung 7
C Eclipse Plugin Entwicklung: Editor für Flussdiagramme Plattformprogrammierung 6
S (OSGI - EQUINOX) Welche Eclipse IDE? Plattformprogrammierung 3
C Pdf in jar datei einbinden mit eclipse Plattformprogrammierung 23
G neuer branch in SVN mit Eclipse Plattformprogrammierung 6
F RCP eclipse rcp ohne eclipse? Plattformprogrammierung 15
dzim RCP Eclipse Provisioning Plattformprogrammierung 3
G RCP Abhängigkeiten von Eclipse Plugins Plattformprogrammierung 9
K Eclipse RCP, EMF, Hibernate Problem Plattformprogrammierung 7
B RCP eigenes Eclipse Plugin wird nicht aufgelöst Plattformprogrammierung 7
T Eclipse Helios XMLUnit importieren Plattformprogrammierung 6
R Verwendung pdfbox in Maven-Projekt in Eclipse Plattformprogrammierung 3
lumo RCP wechseln der Font von Eclipse per code Plattformprogrammierung 10
lumo RCP Eclipse internationalisierung Plattformprogrammierung 5
jemandzehage Kurze Fehlernachricht beim starten in Eclipse Plattformprogrammierung 5
A RCP java.lang.ClassNotFoundException: org.eclipse.core.runtime.adaptor.EclipseStarter Plattformprogrammierung 7
P Wie bekomme ich ICompilationUnit aus dem event? bei Eclipse-Plugin Plattformprogrammierung 3
Rudolf External Libs dauerhaft in Eclipse einbinden Plattformprogrammierung 3
G RCP Eclipse UI Forms Plattformprogrammierung 10
musiKk RCP Eclipse: Speichern von Spaltenbreiten Plattformprogrammierung 9
X Datei in einem Eclipse Projekt über Plugin zugreifen Plattformprogrammierung 2
P Eclipse Help: Wie Links zu anderer Hilfeseite setzen ? Plattformprogrammierung 5
F Eclipse EMF Modelltransformation Plattformprogrammierung 3
tfa RCP Compilereinstellungen festlegen bei Eclipse-Batch-Build Plattformprogrammierung 9

Ähnliche Java Themen


Oben