2013-05-11 136 views
3

我有一个编辑器TopComponent实现。出于某种原因,当我保存文档时,会引发错误。下面列出的是错误。我不确定从这个例外开始。你能分享你所知道的吗?感谢Netbeans保存挂起

java.lang.IllegalArgumentException: Self-causation not permitted 
    at java.lang.Throwable.initCause(Throwable.java:458) 
    at org.netbeans.modules.masterfs.filebasedfs.fileobjects.MutualExclusionSupport.addStack(MutualExclusionSupport.java:122) 
    at org.netbeans.modules.masterfs.filebasedfs.fileobjects.MutualExclusionSupport.addStack(MutualExclusionSupport.java:109) 
    at org.netbeans.modules.masterfs.filebasedfs.fileobjects.MutualExclusionSupport.addResource(MutualExclusionSupport.java:98) 
    at org.netbeans.modules.masterfs.filebasedfs.fileobjects.FileObj.getOutputStream(FileObj.java:127) 
    at org.netbeans.modules.masterfs.filebasedfs.fileobjects.FileObj.getOutputStream(FileObj.java:102) 
    at org.openide.text.DataEditorSupport$Env.outputStream(DataEditorSupport.java:891) 
    at org.openide.text.CloneableEditorSupport.saveDocument(CloneableEditorSupport.java:1172) 
    at org.openide.text.DataEditorSupport.superSaveDoc(DataEditorSupport.java:602) 
    at org.openide.text.DataEditorSupport$SaveImpl.run(DataEditorSupport.java:1315) 
    at org.openide.filesystems.EventControl.runAtomicAction(EventControl.java:127) 
    at org.openide.filesystems.FileSystem.runAtomicAction(FileSystem.java:609) 
    at org.openide.filesystems.FileUtil.runAtomicAction(FileUtil.java:415) 
    at org.openide.text.DataEditorSupport.saveDocument(DataEditorSupport.java:598) 
    at org.netbeans.modules.openide.loaders.SimpleES$SaveCookieImpl.save(SimpleES.java:226) 
    at org.openide.actions.SaveAction.performAction(SaveAction.java:132) 
    at org.openide.actions.SaveAction.performAction(SaveAction.java:102) 
    at org.openide.actions.SaveAction$Delegate.actionPerformed(SaveAction.java:249) 
    at org.openide.awt.ContextAction$Performer.actionPerformed(ContextAction.java:231) 
    at org.openide.awt.ContextManager.actionPerformed(ContextManager.java:257) 
    at org.openide.awt.ContextAction.actionPerformed(ContextAction.java:109) 
    at org.openide.util.actions.ActionInvoker$1.run(ActionInvoker.java:93) 
    at org.openide.util.actions.ActionInvoker$ActionRunnable.actionPerformed(ActionInvoker.java:162) 
    at org.netbeans.core.ModuleActions.invokeAction(ModuleActions.java:109) 
    at org.netbeans.modules.openide.actions.ActionsBridgeImpl.invokeAction(ActionsBridgeImpl.java:60) 
    at org.openide.util.actions.ActionInvoker$ActionRunnable.doRun(ActionInvoker.java:153) 
    at org.openide.util.actions.ActionInvoker$2.run(ActionInvoker.java:110) 
    at org.openide.util.RequestProcessor$Task.run(RequestProcessor.java:1432) 
    at org.openide.util.RequestProcessor$Processor.run(RequestProcessor.java:2044) 
Caused: org.openide.util.RequestProcessor$SlowItem: task failed due to 
    at org.openide.util.RequestProcessor.post(RequestProcessor.java:424) 
    at org.openide.util.actions.ActionInvoker.doPerformAction(ActionInvoker.java:114) 
    at org.openide.util.actions.ActionInvoker.invokeAction(ActionInvoker.java:99) 
    at org.openide.awt.GeneralAction$BaseDelAction.actionPerformed(GeneralAction.java:234) 
    at org.openide.windows.TopComponent.processKeyBinding(TopComponent.java:1176) 
    at javax.swing.JComponent.processKeyBindings(JComponent.java:2940) 
    at javax.swing.JComponent.processKeyEvent(JComponent.java:2842) 
    at java.awt.Component.processEvent(Component.java:6282) 
    at java.awt.Container.processEvent(Container.java:2229) 
    at java.awt.Component.dispatchEventImpl(Component.java:4861) 
    at java.awt.Container.dispatchEventImpl(Container.java:2287) 
    at java.awt.Component.dispatchEvent(Component.java:4687) 
    at java.awt.KeyboardFocusManager.redispatchEvent(KeyboardFocusManager.java:1895) 
    at java.awt.DefaultKeyboardFocusManager.dispatchKeyEvent(DefaultKeyboardFocusManager.java:762) 
    at java.awt.DefaultKeyboardFocusManager.preDispatchKeyEvent(DefaultKeyboardFocusManager.java:1027) 
    at java.awt.DefaultKeyboardFocusManager.typeAheadAssertions(DefaultKeyboardFocusManager.java:899) 
    at java.awt.DefaultKeyboardFocusManager.dispatchEvent(DefaultKeyboardFocusManager.java:727) 
    at java.awt.Component.dispatchEventImpl(Component.java:4731) 
    at java.awt.Container.dispatchEventImpl(Container.java:2287) 
    at java.awt.Window.dispatchEventImpl(Window.java:2719) 
    at java.awt.Component.dispatchEvent(Component.java:4687) 
    at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:723) 
    at java.awt.EventQueue.access$200(EventQueue.java:103) 
    at java.awt.EventQueue$3.run(EventQueue.java:682) 
    at java.awt.EventQueue$3.run(EventQueue.java:680) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:87) 
    at java.awt.EventQueue$4.run(EventQueue.java:696) 
    at java.awt.EventQueue$4.run(EventQueue.java:694) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:76) 
    at java.awt.EventQueue.dispatchEvent(EventQueue.java:693) 
    at org.netbeans.core.TimableEventQueue.dispatchEvent(TimableEventQueue.java:159) 
    at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:242) 
    at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:161) 
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:146) 
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:138) 
[catch] at java.awt.EventDispatchThread.run(EventDispatchThread.java:91) 

EDIT 1

我有DataObject中且具有构造成一个新的MIME类型text/x-puml一个VisualElement子类。一旦我将这些改回text/plain,事情就开始奏效。我搜索了text/plain,看看我是否错过了更改text/x-puml的任何内容,但找不到任何内容。有没有其他的事情我应该改变MIME类型为text/x-puml

EDIT 2

似乎现在零星发生,但往往不是发生。如果我有自定义MIME类型,是否需要实现自己的SaveCookie或Savable?

+0

stacktrace中的哪一行包含您编写或编辑的类? – 2013-05-11 21:55:47

+0

这是有趣的部分,没有一行提到我的代码。但是我刚才确实发现了什么导致了这个问题。我有一个新的MIME类型的注册'text/x-puml',一旦我将它改为'text/plain',问题就消失了。你会碰巧知道我是否缺少任何配置。 – ShaggyInjun 2013-05-11 22:04:36

+0

我还没有在NetBeans中使用自定义MIME类型,所以我无法在那里帮你。 – 2013-05-13 00:06:39

回答

1

它看起来像一个信号灯问题。

系统无法保存文件,因为该文件上存在排他锁。另一个独占锁(根据保存需要)是不可能的。

试着看文件处理。某处必须是锁。

0

我有一个类似的错误,由于重命名,这是因为该文件的锁。所以我用了file's锁定与primaryFile.lock()在:

WindowManager.getDefault().invokeWhenUIReady(new Runnable() 
{ 
    @Override 
    public void run() 
    { 
     if (obj.getDomainModel() != null) 
     { 
      String newName = obj.getDomainModel().getName(); 
      FileObject primaryFile = obj.getPrimaryFile(); 
      try 
      { 
       primaryFile.rename(primaryFile.lock(), newName, primaryFile.getExt()); 
       callback.updateTitle(newName); 
      } 
      catch (IOException ex) 
      { 
       String message = String.format("The model couldn´t be renamed to \"%s\"", newName); 

       LOG.warning(message); 
      } 
     } 
    } 
}); 

用它来保存文件或相似任何情况下。

+1

我的例子我有同样的问题,但重命名,而不是保存。但同样的问题:先前打开的文件的锁定。 – EliuX 2015-08-27 22:40:19

+0

对不起 - 我误解了你的回答。删除downvote,谢谢澄清 – user2290362 2015-08-29 17:30:30

+0

感谢您纠正。 – EliuX 2015-08-31 17:15:15