0

私はEclipseプラグインを書いています。私は 5 ページの MultiPageEditor を持っています。最初のページには GraphicalEditor(geEx) を拡張するエディターがあり、2 番目のページには 2 つ (logicInputEditor、logicOutputEditor) GroovyEditor の org.codehaus.groovy.eclipse.editor.GroovyEditor があります。geEx は 1 つのファイル (例: first.qwe) を処理し、logicEditors は他の 2 つのファイル (in.groovy、out.groovy) を処理します。geEx には次のコードがあります。




     @Override
                public void commandStackChanged(EventObject event) {
                        firePropertyChange(IEditorPart.PROP_DIRTY);
                        super.commandStackChanged(event);
                }

ファイルを最初に編集すると、MultiPageEditor は何かが変更されたことを認識し、それをマークしてファイルを保存できるようにします。すべて問題ありません。

GrooveEditors にリスナーを追加します。




     logicInputEditor.addPropertyListener(new IPropertyListener() {
                                @Override
                                 public void propertyChanged(Object source, int propId) {
                                         if (propId == IEditorPart.PROP_DIRTY){
                                                 firePropertyChange(IEditorPart.PROP_DIRTY);
                                         }
                                 }
                         });

GrooveEditor は CommandStackListener を実装していないため、commandStackChanged 関数をオーバーライドできません。

GroovyEditor の 1 つで何かを編集するたびに、MultiPageEditor の状態がダーティに変わります。これは私が望んでいたことですが、コンソールにも例外が出力されます。だから-それは私が望むように機能していますが、ユーザーがエディターで何かを入力するたびに例外をスローしてキャッチするのは遅く、一般的に悪いです。

メッセージは次のとおりです。

Problem trying to determine classpath of project Test:
 Java Model Exception: Java Model Status [Test does not exist]
 at org.eclipse.jdt.internal.core.JavaElement.newNotPresentException(JavaElement.java:495)
 at org.eclipse.jdt.internal.core.JavaModelManager.getPerProjectInfoCheckExistence(JavaModelManager.java:2287)
 at org.eclipse.jdt.internal.core.JavaProject.getPerProjectInfo(JavaProject.java:1914)
 at org.eclipse.jdt.internal.core.JavaProject.getOutputLocation(JavaProject.java:1741)
 at org.eclipse.jdt.core.util.CompilerUtils.calculateClasspath(CompilerUtils.java:209)
 at org.eclipse.jdt.core.util.CompilerUtils.setGroovyClasspath(CompilerUtils.java:152)
 at org.eclipse.jdt.core.util.CompilerUtils.setGroovyClasspath(CompilerUtils.java:117)
 at org.codehaus.jdt.groovy.model.GroovyCompilationUnit.buildStructure(GroovyCompilationUnit.java:260)
 at org.eclipse.jdt.internal.core.Openable.generateInfos(Openable.java:258)
 at org.eclipse.jdt.internal.core.JavaElement.openWhenClosed(JavaElement.java:526)
 at org.eclipse.jdt.internal.core.CompilationUnit.makeConsistent(CompilationUnit.java:1100)
 at org.codehaus.jdt.groovy.model.GroovyReconcileWorkingCopyOperation.makeConsistent(GroovyReconcileWorkingCopyOperation.java:60)
 at org.eclipse.jdt.internal.core.ReconcileWorkingCopyOperation.executeOperation(ReconcileWorkingCopyOperation.java:89)
 at org.eclipse.jdt.internal.core.JavaModelOperation.run(JavaModelOperation.java:728)
 at org.eclipse.jdt.internal.core.JavaModelOperation.runOperation(JavaModelOperation.java:788)
 at org.codehaus.jdt.groovy.model.GroovyCompilationUnit.reconcile(GroovyCompilationUnit.java:423)
 at org.eclipse.jdt.internal.core.CompilationUnit.reconcile(CompilationUnit.java:1231)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:133)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.access$0(JavaReconcilingStrategy.java:108)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy$1.run(JavaReconcilingStrategy.java:89)
 at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:87)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:151)
 at org.eclipse.jdt.internal.ui.text.CompositeReconcilingStrategy.reconcile(CompositeReconcilingStrategy.java:86)
 at org.eclipse.jdt.internal.ui.text.JavaCompositeReconcilingStrategy.reconcile(JavaCompositeReconcilingStrategy.java:104)
 at org.eclipse.jface.text.reconciler.MonoReconciler.process(MonoReconciler.java:77)
 at org.eclipse.jface.text.reconciler.AbstractReconciler$BackgroundThread.run(AbstractReconciler.java:206)

また:

!ENTRY org.eclipse.jdt.core 4 4 2012-08-13 20:33:29.402
 !MESSAGE Problem with build structure for in.groovy
 !STACK 1
 Java Model Exception: Java Model Status [Test does not exist]
 at org.eclipse.jdt.internal.core.JavaElement.newJavaModelException(JavaElement.java:505)
 at org.eclipse.jdt.internal.core.Openable.generateInfos(Openable.java:246)
 at org.eclipse.jdt.internal.core.JavaElement.openWhenClosed(JavaElement.java:526)
 at org.eclipse.jdt.internal.core.JavaElement.getElementInfo(JavaElement.java:255)
 at org.eclipse.jdt.internal.core.JavaElement.getElementInfo(JavaElement.java:241)
 at org.eclipse.jdt.internal.core.JavaProject.getJavaProjectElementInfo(JavaProject.java:1646)
 at org.eclipse.jdt.internal.core.JavaProject.newNameLookup(JavaProject.java:2334)
 at org.eclipse.jdt.internal.core.SearchableEnvironment.<init>(SearchableEnvironment.java:59)
 at org.eclipse.jdt.internal.core.SearchableEnvironment.<init>(SearchableEnvironment.java:66)
 at org.eclipse.jdt.internal.core.CancelableNameEnvironment.<init>(CancelableNameEnvironment.java:26)
 at org.eclipse.jdt.internal.core.CompilationUnitProblemFinder.process(CompilationUnitProblemFinder.java:178)
 at org.codehaus.jdt.groovy.model.GroovyCompilationUnit.buildStructure(GroovyCompilationUnit.java:338)
 at org.eclipse.jdt.internal.core.Openable.generateInfos(Openable.java:258)
 at org.eclipse.jdt.internal.core.JavaElement.openWhenClosed(JavaElement.java:526)
 at org.eclipse.jdt.internal.core.CompilationUnit.makeConsistent(CompilationUnit.java:1100)
 at org.codehaus.jdt.groovy.model.GroovyReconcileWorkingCopyOperation.makeConsistent(GroovyReconcileWorkingCopyOperation.java:60)
 at org.eclipse.jdt.internal.core.ReconcileWorkingCopyOperation.executeOperation(ReconcileWorkingCopyOperation.java:89)
 at org.eclipse.jdt.internal.core.JavaModelOperation.run(JavaModelOperation.java:728)
 at org.eclipse.jdt.internal.core.JavaModelOperation.runOperation(JavaModelOperation.java:788)
 at org.codehaus.jdt.groovy.model.GroovyCompilationUnit.reconcile(GroovyCompilationUnit.java:423)
 at org.eclipse.jdt.internal.core.CompilationUnit.reconcile(CompilationUnit.java:1231)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:133)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.access$0(JavaReconcilingStrategy.java:108)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy$1.run(JavaReconcilingStrategy.java:89)
 at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:42)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:87)
 at org.eclipse.jdt.internal.ui.text.java.JavaReconcilingStrategy.reconcile(JavaReconcilingStrategy.java:151)
 at org.eclipse.jdt.internal.ui.text.CompositeReconcilingStrategy.reconcile(CompositeReconcilingStrategy.java:86)
 at org.eclipse.jdt.internal.ui.text.JavaCompositeReconcilingStrategy.reconcile(JavaCompositeReconcilingStrategy.java:104)
 at org.eclipse.jface.text.reconciler.MonoReconciler.process(MonoReconciler.java:77)
 at org.eclipse.jface.text.reconciler.AbstractReconciler$BackgroundThread.run(AbstractReconciler.java:206)
 !SUBENTRY 1 org.eclipse.jdt.core 4 969 2012-08-13 20:33:29.402
 !MESSAGE Test does not exist

問題は - どうすればこれを修正できますか? GroovyEditor の 1 つが「ダーティ」であるという「メッセージ」を MultiPageEditor に送信するにはどうすればよいですか?

4

1 に答える 1

2

最終的に解決されました-問題は私のコードにはありませんでしたが、GroovyEditorにありました-プロジェクトの性質がJavaプロジェクトの性質である場合(おそらくGroovyプロジェクトの性質も機能します)、それ以外の場合はGroovyEditorが例外をスローします。Groove Editorの問題追跡システムにバグを報告しましたが、解決されたため、次のバージョンではすべて問題がないはずです。現在、唯一の解決策は、プロジェクトの性質にJavaプロジェクトの性質を追加することです。

于 2012-08-24T20:36:25.780 に答える