Changeset 2859 in josm
- Timestamp:
- 2010-01-14T20:28:40+01:00 (15 years ago)
- Location:
- trunk/src/org/openstreetmap/josm
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/org/openstreetmap/josm/plugins/PluginHandler.java
r2858 r2859 706 706 } 707 707 708 private static boolean confirmD isablingPluginAfterException(PluginProxy plugin) {708 private static boolean confirmDeactivatingPluginAfterException(PluginProxy plugin) { 709 709 ButtonSpec [] options = new ButtonSpec[] { 710 710 new ButtonSpec( … … 748 748 } 749 749 750 /** 751 * Replies the plugin which most likely threw the exception <code>ex</code>. 752 * 753 * @param ex the exception 754 * @return the plugin; null, if the exception proably wasn't thrown from a plugin 755 */ 750 756 private static PluginProxy getPluginCausingException(Throwable ex) { 751 757 for (PluginProxy p : pluginList) { … … 762 768 } 763 769 764 public static boolean checkException(Throwable e) { 770 /** 771 * Checks whether the exception <code>e</code> was thrown by a plugin. If so, 772 * conditionally deactivates the plugin, but asks the user first. 773 * 774 * @param e the exception 775 */ 776 public static void disablePluginAfterException(Throwable e) { 765 777 PluginProxy plugin = null; 766 767 778 // Check for an explicit problem when calling a plugin function 768 779 if (e instanceof PluginException) { 769 780 plugin = ((PluginException) e).plugin; 770 781 } 771 772 782 if (plugin == null) { 773 783 plugin = getPluginCausingException(e); 774 784 } 775 776 if (plugin != null && confirmDisablingPluginAfterException(plugin)) { 777 List<String> plugins = new ArrayList<String>(Main.pref.getCollection("plugins", Collections 778 .<String> emptyList())); 779 if (plugins.contains(plugin.getPluginInformation().name)) { 780 while (plugins.remove(plugin.getPluginInformation().name)) { 781 } 782 Main.pref.putCollection("plugins", plugins); 783 JOptionPane 784 .showMessageDialog( 785 Main.parent, 786 tr("The plugin has been removed from the configuration. Please restart JOSM to unload the plugin."), 787 tr("Information"), JOptionPane.INFORMATION_MESSAGE); 788 } else { 789 JOptionPane.showMessageDialog(Main.parent, 790 tr("The plugin could not be removed. Probably it was already disabled"), tr("Error"), 791 JOptionPane.ERROR_MESSAGE); 792 } 793 return true; 794 } 795 return false; 785 if (plugin == null) 786 // don't know what plugin threw the exception 787 return; 788 789 Set<String> plugins = new HashSet<String>( 790 Main.pref.getCollection("plugins",Collections.<String> emptySet()) 791 ); 792 if (! plugins.contains(plugin.getPluginInformation().name)) 793 // plugin not activated ? strange in this context but anyway, don't bother 794 // the user with dialogs, skip condiational deactivation 795 return; 796 797 if (!confirmDeactivatingPluginAfterException(plugin)) 798 // user doesn't want to deactivate the plugin 799 return; 800 801 // deactivate the plugin 802 plugins.remove(plugin.getPluginInformation().name); 803 Main.pref.putCollection("plugins", plugins); 804 JOptionPane.showMessageDialog( 805 Main.parent, 806 tr("The plugin has been removed from the configuration. Please restart JOSM to unload the plugin."), 807 tr("Information"), 808 JOptionPane.INFORMATION_MESSAGE 809 ); 810 return; 796 811 } 797 812 -
trunk/src/org/openstreetmap/josm/tools/BugReportExceptionHandler.java
r2853 r2859 51 51 } 52 52 53 if(PluginHandler.checkException(e)) 54 return; 53 // Give the user a chance to deactivate the plugin which threw the exception (if it 54 // was thrown from a plugin) 55 // 56 PluginHandler.disablePluginAfterException(e); 55 57 58 // Then ask for submitting a bug report, for exceptions thrown from a plugin too 59 // 56 60 Object[] options = new String[]{tr("Do nothing"), tr("Report Bug")}; 57 int answer = JOptionPane.showOptionDialog(Main.parent, tr("An unexpected exception occurred.\n\n" + 58 "This is always a coding error. If you are running the latest\n" + 59 "version of JOSM, please consider being kind and file a bug report."), 60 tr("Unexpected Exception"), JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE,null, 61 options, options[0]); 62 if (answer == 1) { 61 int answer = JOptionPane.showOptionDialog( 62 Main.parent, 63 "<html>" 64 + tr("An unexpected exception occurred.<br>" + 65 "This is always a coding error. If you are running the latest<br>" + 66 "version of JOSM, please consider being kind and file a bug report." 67 ) 68 + "</html>", 69 tr("Unexpected Exception"), 70 JOptionPane.YES_NO_OPTION, 71 JOptionPane.ERROR_MESSAGE, 72 null, 73 options, options[0] 74 ); 75 if (answer != 1) return; 76 77 try { 78 final int maxlen = 7000; 79 StringWriter stack = new StringWriter(); 80 e.printStackTrace(new PrintWriter(stack)); 81 82 String text = ShowStatusReportAction.getReportHeader() 83 + stack.getBuffer().toString(); 84 String urltext = text.replaceAll("\r",""); /* strip useless return chars */ 85 if(urltext.length() > maxlen) 86 { 87 urltext = urltext.substring(0,maxlen); 88 int idx = urltext.lastIndexOf("\n"); 89 /* cut whole line when not loosing too much */ 90 if(maxlen-idx < 200) { 91 urltext = urltext.substring(0,idx+1); 92 } 93 urltext += "...<snip>...\n"; 94 } 95 96 URL url = new URL("http://josm.openstreetmap.de/josmticket?" + 97 "data="+ 98 Base64.encode( 99 // To note that it came from this code 100 "keywords=template_report&" + 101 "description=" + java.net.URLEncoder.encode( 102 // Note: This doesn't use tr() intentionally, we want bug reports in English 103 "What steps will reproduce the problem?\n" 104 + " 1. \n" 105 + " 2. \n" 106 + " 3. \n" 107 + "\n" 108 + "What is the expected result?\n\n" 109 + "What happens instead?\n\n" 110 + "Please provide any additional information below. Attach a screenshot if\n" 111 + "possible.\n\n" 112 + "{{{\n" + urltext + "\n}}}\n", 113 "UTF-8"))); 114 115 JPanel p = new JPanel(new GridBagLayout()); 116 p.add(new JMultilineLabel( 117 tr("You have encountered an error in JOSM. Before you file a bug report" + 118 "make sure you have updated to the latest version of JOSM here:")), GBC.eol()); 119 p.add(new UrlLabel("http://josm.openstreetmap.de/#Download"), GBC.eop().insets(8,0,0,0)); 120 p.add(new JMultilineLabel( 121 tr("You should also update your plugins. If neither of those help please" + 122 "file a bug report in our bugtracker using this link:")), GBC.eol()); 123 p.add(new UrlLabel(url.toString(), "http://josm.openstreetmap.de/josmticket?..."), GBC.eop().insets(8,0,0,0)); 124 p.add(new JMultilineLabel( 125 tr("There the error information provided below should already be" + 126 "filled in for you. Please include information on how to reproduce" + 127 "the error and try to supply as much detail as possible.")), GBC.eop()); 128 p.add(new JMultilineLabel( 129 tr("Alternatively, if that does not work you can manually fill in the information" + 130 "below at this URL:")), GBC.eol()); 131 p.add(new UrlLabel("http://josm.openstreetmap.de/newticket"), GBC.eop().insets(8,0,0,0)); 63 132 try { 64 final int maxlen = 7000; 65 StringWriter stack = new StringWriter(); 66 e.printStackTrace(new PrintWriter(stack)); 133 Toolkit.getDefaultToolkit().getSystemClipboard().setContents(new StringSelection(text), new ClipboardOwner(){ 134 public void lostOwnership(Clipboard clipboard, Transferable contents) {} 135 }); 136 p.add(new JLabel(tr("(The text has already been copied to your clipboard.)")), GBC.eop()); 137 } 138 catch (RuntimeException x) {} 67 139 68 String text = ShowStatusReportAction.getReportHeader() 69 + stack.getBuffer().toString(); 70 String urltext = text.replaceAll("\r",""); /* strip useless return chars */ 71 if(urltext.length() > maxlen) 72 { 73 urltext = urltext.substring(0,maxlen); 74 int idx = urltext.lastIndexOf("\n"); 75 /* cut whole line when not loosing too much */ 76 if(maxlen-idx < 200) { 77 urltext = urltext.substring(0,idx+1); 78 } 79 urltext += "...<snip>...\n"; 140 JTextArea info = new JTextArea(text, 20, 60); 141 info.setCaretPosition(0); 142 info.setEditable(false); 143 p.add(new JScrollPane(info), GBC.eop()); 144 145 for (Component c: p.getComponents()) { 146 if (c instanceof JMultilineLabel) { 147 ((JMultilineLabel)c).setMaxWidth(400); 80 148 } 149 } 81 150 82 URL url = new URL("http://josm.openstreetmap.de/josmticket?" + 83 "data="+ 84 Base64.encode( 85 // To note that it came from this code 86 "keywords=template_report&" + 87 "description=" + java.net.URLEncoder.encode( 88 // Note: This doesn't use tr() intentionally, we want bug reports in English 89 "What steps will reproduce the problem?\n" 90 + " 1. \n" 91 + " 2. \n" 92 + " 3. \n" 93 + "\n" 94 + "What is the expected result?\n\n" 95 + "What happens instead?\n\n" 96 + "Please provide any additional information below. Attach a screenshot if\n" 97 + "possible.\n\n" 98 + "{{{\n" + urltext + "\n}}}\n", 99 "UTF-8"))); 100 101 JPanel p = new JPanel(new GridBagLayout()); 102 p.add(new JMultilineLabel( 103 tr("You have encountered an error in JOSM. Before you file a bug report" + 104 "make sure you have updated to the latest version of JOSM here:")), GBC.eol()); 105 p.add(new UrlLabel("http://josm.openstreetmap.de/#Download"), GBC.eop().insets(8,0,0,0)); 106 p.add(new JMultilineLabel( 107 tr("You should also update your plugins. If neither of those help please" + 108 "file a bug report in our bugtracker using this link:")), GBC.eol()); 109 p.add(new UrlLabel(url.toString(), "http://josm.openstreetmap.de/josmticket?..."), GBC.eop().insets(8,0,0,0)); 110 p.add(new JMultilineLabel( 111 tr("There the error information provided below should already be" + 112 "filled in for you. Please include information on how to reproduce" + 113 "the error and try to supply as much detail as possible.")), GBC.eop()); 114 p.add(new JMultilineLabel( 115 tr("Alternatively, if that does not work you can manually fill in the information" + 116 "below at this URL:")), GBC.eol()); 117 p.add(new UrlLabel("http://josm.openstreetmap.de/newticket"), GBC.eop().insets(8,0,0,0)); 118 try { 119 Toolkit.getDefaultToolkit().getSystemClipboard().setContents(new StringSelection(text), new ClipboardOwner(){ 120 public void lostOwnership(Clipboard clipboard, Transferable contents) {} 121 }); 122 p.add(new JLabel(tr("(The text has already been copied to your clipboard.)")), GBC.eop()); 123 } 124 catch (RuntimeException x) {} 125 126 JTextArea info = new JTextArea(text, 20, 60); 127 info.setCaretPosition(0); 128 info.setEditable(false); 129 p.add(new JScrollPane(info), GBC.eop()); 130 131 for (Component c: p.getComponents()) { 132 if (c instanceof JMultilineLabel) { 133 ((JMultilineLabel)c).setMaxWidth(400); 134 } 135 } 136 137 JOptionPane.showMessageDialog(Main.parent, p, tr("You have encountered a bug in JOSM"), JOptionPane.ERROR_MESSAGE); 138 } catch (Exception e1) { 139 e1.printStackTrace(); 140 } 151 JOptionPane.showMessageDialog(Main.parent, p, tr("You have encountered a bug in JOSM"), JOptionPane.ERROR_MESSAGE); 152 } catch (Exception e1) { 153 e1.printStackTrace(); 141 154 } 142 155 }
Note:
See TracChangeset
for help on using the changeset viewer.