update author list in license for (JAL-826)
[jalview.git] / src / jalview / gui / AnnotationExporter.java
index 118aab8..75399b6 100755 (executable)
@@ -1,6 +1,6 @@
 /*\r
- * Jalview - A Sequence Alignment Editor and Viewer (Version 2.5)\r
- * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle\r
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7)\r
+ * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle\r
  * \r
  * This file is part of Jalview.\r
  * \r
@@ -61,7 +61,7 @@ public class AnnotationExporter extends JPanel
     frame = new JInternalFrame();\r
     frame.setContentPane(this);\r
     frame.setLayer(JLayeredPane.PALETTE_LAYER);\r
-    Desktop.addInternalFrame(frame, "", 260, 125);\r
+    Desktop.addInternalFrame(frame, "", frame.getPreferredSize().width, frame.getPreferredSize().height);\r
   }\r
 \r
   public void exportFeatures(AlignmentPanel ap)\r
@@ -88,8 +88,8 @@ public class AnnotationExporter extends JPanel
 \r
   public void toFile_actionPerformed(ActionEvent e)\r
   {\r
-    JalviewFileChooser chooser = new JalviewFileChooser(jalview.bin.Cache\r
-            .getProperty("LAST_DIRECTORY"));\r
+    JalviewFileChooser chooser = new JalviewFileChooser(\r
+            jalview.bin.Cache.getProperty("LAST_DIRECTORY"));\r
 \r
     chooser.setFileView(new JalviewFileView());\r
     chooser.setDialogTitle(features ? "Save Features to File"\r
@@ -177,10 +177,18 @@ public class AnnotationExporter extends JPanel
     }\r
 \r
     CutAndPasteTransfer cap = new CutAndPasteTransfer();\r
-    cap.setText(text);\r
-    Desktop.addInternalFrame(cap, (features ? "Features for - "\r
-            : "Annotations for - ")\r
-            + ap.alignFrame.getTitle(), 600, 500);\r
+    try\r
+    {\r
+      cap.setText(text);\r
+      Desktop.addInternalFrame(cap, (features ? "Features for - "\r
+              : "Annotations for - ") + ap.alignFrame.getTitle(), 600, 500);\r
+    } catch (OutOfMemoryError oom)\r
+    {\r
+      new OOMWarning("generating "\r
+              + (features ? "Features for - " : "Annotations for - ")\r
+              + ap.alignFrame.getTitle(), oom);\r
+      cap.dispose();\r
+    }\r
 \r
     close_actionPerformed(null);\r
   }\r
@@ -188,6 +196,10 @@ public class AnnotationExporter extends JPanel
   private Hashtable getDisplayedFeatureCols()\r
   {\r
     Hashtable fcols = new Hashtable();\r
+    if (ap.av.featuresDisplayed == null)\r
+    {\r
+      return fcols;\r
+    }\r
     Enumeration en = ap.av.featuresDisplayed.keys();\r
     FeatureRenderer fr = ap.seqPanel.seqCanvas.getFeatureRenderer(); // consider\r
                                                                      // higher\r
@@ -213,7 +225,8 @@ public class AnnotationExporter extends JPanel
 \r
   private void jbInit() throws Exception\r
   {\r
-    this.setLayout(flowLayout1);\r
+    this.setLayout(new BorderLayout());\r
+    \r
     toFile.setText("to File");\r
     toFile.addActionListener(new ActionListener()\r
     {\r
@@ -261,8 +274,8 @@ public class AnnotationExporter extends JPanel
     buttonGroup.add(jalviewFormat);\r
     buttonGroup.add(GFFFormat);\r
     buttonGroup.add(CSVFormat);\r
-    this.add(jPanel3, null);\r
-    this.add(jPanel1, null);\r
+    this.add(jPanel3, BorderLayout.CENTER);\r
+    this.add(jPanel1, BorderLayout.SOUTH);\r
   }\r
 \r
   JPanel jPanel1 = new JPanel();\r