突然上周,一个JS文件在比较编辑器中无法打开。
- 我正在运行最新版本的Mars Eclipse
- 我正在运行最新版本的Subclipse
- 我与代码库同步,并看到了更改的文件
- 当我双击或选择比较时,要么看到一个带有“初始化...”的空白白页,要么看到一个空白的灰色页面
- 这仅限于一个特定的文本JS文件...项目中的所有其他文件和其他项目都可以正常差异化。
- 该文件大小为37,880字节
- 我已删除了Subversion设置文件,并重新创建了它们
- 我已检查过偏好设置并忽略空格
只有这个文件出现问题... 它是一个node.js项目的主文件。它曾经可以正常地进行差异化,但突然上周这个文件不再进行差异化,并抛出了这个异常。
当我查看日志时,我看到了以下异常:
!ENTRY org.eclipse.ui 4 0 2016-04-14 12:38:08.535 !MESSAGE 未处理的事件循环异常 !STACK 0 org.eclipse.swt.SWTException: 执行可运行程序失败 (java.lang.IllegalArgumentException) 在 org.eclipse.swt.SWT.error(SWT.java:4491) 在 org.eclipse.swt.SWT.error(SWT.java:4406) 在 org.eclipse.swt.widgets.Synchronizer.runAsyncMessages(Synchronizer.java:138) 在 org.eclipse.swt.widgets.Display.runAsyncMessages(Display.java:4155) 在 org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3772) 在 org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine$4.run(PartRenderingEngine.java:1127) 在 org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:337) 在 org.eclipse.e4.ui.internal.workbench.swt.PartRenderingEngine.run(PartRenderingEngine.java:1018) 在 org.eclipse.e4.ui.internal.workbench.E4Workbench.createAndRunUI(E4Workbench.java:156) 在 org.eclipse.ui.internal.Workbench$5.run(Workbench.java:694) 在 org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:337) 在 org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:606) 在 org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:150) 在 org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:139) 在 org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:196) 在 org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.java:134) 在 org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:104) 在 org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:380) 在 org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:235) 在 sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 在 sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 在 sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 在 java.lang.reflect.Method.invoke(Unknown Source) 在 org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:669) 在 org.eclipse.equinox.launcher.Main.basicRun(Main.java:608) 在 org.eclipse.equinox.launcher.Main.run(Main.java:1515)Caused by: java.lang.IllegalArgumentException 在 org.eclipse.wst.jsdt.core.dom.ASTNode.setSourceRange(ASTNode.java:2490) 在 org.eclipse.wst.jsdt.core.dom.ASTConverter.convertToVariableDeclarationStatement(ASTConverter.java:2696) 在 org.eclipse.wst.jsdt.core.dom.ASTConverter.checkAndAddMultipleLocalDeclaration(ASTConverter.java:319) 在 org.eclipse.wst.jsdt.core.dom.ASTConverter.convert(ASTConverter.java:436) 在 org.eclipse.wst.jsdt.core.dom.ASTConverter.convert(ASTConverter.java:1175) 在 org.eclipse.wst.jsdt.core.dom.JavaScriptUnitResolver.convert(JavaScriptUnitResolver.java:262) 在 org.eclipse.wst.jsdt.core.dom.ASTParser.internalCreateAST(ASTParser.java:887) 在 org.eclipse.wst.jsdt.core.dom.ASTParser.createAST(ASTParser.java:647) 在 org.eclipse.wst.jsdt.internal.ui.compare.JavaStructureCreator.createStructureComparator(JavaStructureCreator.java:284) 在 org.eclipse.wst.jsdt.internal.ui.compare.JavaStructureCreator.createStructureComparator(JavaStructureCreator.java:243) 在 org.eclipse.compare.structuremergeviewer.StructureCreator.internalCreateStructure(StructureCreator.java:121) 在 org.eclipse.compare.structuremergeviewer.StructureCreator.access$0(StructureCreator.java:109) 在 org.eclipse.compare.structuremergeviewer.StructureCreator$1.run(StructureCreator.java:96) 在 org.eclipse.swt.custom.BusyIndicator.showWhile(BusyIndicator.java:70) 在 org.eclipse.compare.internal.Utilities.runInUIThread(Utilities.java:859) 在 org.eclipse.compare.structuremergeviewer.StructureCreator.createStructure(StructureCreator.java:102) 在 org.eclipse.compare.structuremergeviewer.StructureDiffViewer$StructureInfo.createStructure(StructureDiffViewer.java:155) 在 org.eclipse.compare.structuremergeviewer.StructureDiffViewer$StructureInfo.refresh(StructureDiffViewer.java:133) 在 org.eclipse.compare.structuremergeviewer.StructureDiffViewer$StructureInfo.setInput(StructureDiffViewer.java:104) 在 org.eclipse.compare.structuremergeviewer.StructureDiffViewer.compareInputChanged(StructureDiffViewer.java:342) 在