X-Git-Url: https://git.argeo.org/?a=blobdiff_plain;f=server%2Fplugins%2Forg.argeo.jcr.ui.explorer%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fjcr%2Fui%2Fexplorer%2Feditors%2FGenericNodeEditorInput.java;h=5ddfc301d9eecb610c178f3bc3c4dca6d30d1ea8;hb=2f0d8516846690fcb9a13ebe7a8c15ca50930a2b;hp=37cabe703d46b75014db197dc400da07d3bcdb11;hpb=e20bb1ef1c9c03d5e704d1634f3c83a971d15df8;p=lgpl%2Fargeo-commons.git diff --git a/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/editors/GenericNodeEditorInput.java b/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/editors/GenericNodeEditorInput.java index 37cabe703..5ddfc301d 100644 --- a/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/editors/GenericNodeEditorInput.java +++ b/server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/editors/GenericNodeEditorInput.java @@ -15,8 +15,23 @@ import org.eclipse.ui.IPersistableElement; public class GenericNodeEditorInput implements IEditorInput { private final Node currentNode; + // cache key properties at creation time to avoid Exception at recoring time + // when the session has been closed + private String path; + private String uid; + private String name; + public GenericNodeEditorInput(Node currentNode) { this.currentNode = currentNode; + try { + name = currentNode.getName(); + uid = currentNode.getIdentifier(); + path = currentNode.getPath(); + } catch (RepositoryException re) { + throw new ArgeoException( + "unexpected error while getting node key values at creation time", + re); + } } public Node getCurrentNode() { @@ -36,39 +51,19 @@ public class GenericNodeEditorInput implements IEditorInput { } public String getName() { - try { - return currentNode.getName(); - } catch (RepositoryException re) { - throw new ArgeoException( - "unexpected error while getting node name", re); - } + return name; } public String getUid() { - try { - return currentNode.getIdentifier(); - } catch (RepositoryException re) { - throw new ArgeoException("unexpected error while getting node uid", - re); - } + return uid; } public String getToolTipText() { - try { - return currentNode.getPath(); - } catch (RepositoryException re) { - throw new ArgeoException( - "unexpected error while getting node path", re); - } + return path; } public String getPath() { - try { - return currentNode.getPath(); - } catch (RepositoryException re) { - throw new ArgeoException( - "unexpected error while getting node path", re); - } + return path; } public IPersistableElement getPersistable() {