Bug 1364977 - Do not remove obs_documentCreated observer in its notification processing to avoid a crash. r=IanN

Also change attachment handling to avoid hitting bug 468740 when the observer is only removed during close.
This commit is contained in:
Frank-Rainer Grahl 2017-06-05 11:03:16 +02:00
Родитель 6fe0dc2a87
Коммит 3b9c200b9a
1 изменённых файлов: 80 добавлений и 25 удалений

Просмотреть файл

@ -1266,8 +1266,6 @@ var gMsgEditorCreationObserver =
updateComposeItems();
else
gLastWindowToHaveFocus = null;
commandManager.removeCommandObserver(this, "obs_documentCreated");
}
}
}
@ -1340,6 +1338,8 @@ function ComposeUnload()
document.getElementById("msgcomposeWindow").dispatchEvent(
new Event("compose-window-unload", { bubbles: false, cancelable: false }));
GetCurrentCommandManager().removeCommandObserver(gMsgEditorCreationObserver,
"obs_documentCreated");
UnloadCommandUpdateHandlers();
// Stop InlineSpellCheckerUI so personal dictionary is saved
@ -2476,36 +2476,91 @@ function AttachmentElementHasItems()
function OpenSelectedAttachment()
{
var bucket = GetMsgAttachmentElement();
if (bucket.selectedItems.length == 1)
{
var attachmentUrl = bucket.getSelectedItem(0).attachment.url;
let bucket = document.getElementById("attachmentBucket");
if (bucket.selectedItems.length == 1) {
let attachmentUrl = bucket.getSelectedItem(0).attachment.url;
var messagePrefix = /^mailbox-message:|^imap-message:|^news-message:/i;
if (messagePrefix.test(attachmentUrl))
{
// we must be dealing with a forwarded attachment, treat this specially
var msgHdr = gMessenger.msgHdrFromURI(attachmentUrl);
if (msgHdr)
{
var folderUri = msgHdr.folder.folderURL;
window.openDialog("chrome://messenger/content/messageWindow.xul", "_blank", "all,chrome,dialog=no,status,toolbar",
attachmentUrl, folderUri, null);
let messagePrefix = /^mailbox-message:|^imap-message:|^news-message:/i;
if (messagePrefix.test(attachmentUrl)) {
// We must be dealing with a forwarded attachment, treat this special.
let msgHdr = gMessenger.msgHdrFromURI(attachmentUrl);
if (msgHdr) {
MailUtils.openMessageInNewWindow(msgHdr);
}
} else {
// Turn the URL into a nsIURI object then open it.
let uri = Services.io.newURI(attachmentUrl);
if (uri) {
let channel = Services.io.newChannelFromURI2(uri,
null,
Services.scriptSecurityManager.getSystemPrincipal(),
null,
Components.interfaces.nsILoadInfo.SEC_ALLOW_CROSS_ORIGIN_DATA_IS_NULL,
Components.interfaces.nsIContentPolicy.TYPE_OTHER);
if (channel) {
let uriLoader = Components.classes["@mozilla.org/uriloader;1"].getService(Components.interfaces.nsIURILoader);
uriLoader.openURI(channel, true, new nsAttachmentOpener());
}
else
{
var editorElement = GetCurrentEditorElement();
if (editorElement) {
const loadFlags = Components.interfaces.nsIWebNavigation.LOAD_FLAGS_IS_LINK;
try {
editorElement.webNavigation.loadURI(attachmentUrl, loadFlags, null, null, null);
} catch (e) {}
}
}
} // if one attachment selected
}
function nsAttachmentOpener()
{
}
nsAttachmentOpener.prototype =
{
QueryInterface: function(iid)
{
if (iid.equals(Components.interfaces.nsIURIContentListener) ||
iid.equals(Components.interfaces.nsIInterfaceRequestor) ||
iid.equals(Components.interfaces.nsISupports)) {
return this;
}
throw Components.results.NS_NOINTERFACE;
},
onStartURIOpen: function(uri)
{
return false;
},
doContent: function(contentType, isContentPreferred, request, contentHandler)
{
return false;
},
isPreferred: function(contentType, desiredContentType)
{
return false;
},
canHandleContent: function(contentType, isContentPreferred, desiredContentType)
{
return false;
},
getInterface: function(iid)
{
if (iid.equals(Components.interfaces.nsIDOMWindow)) {
return window;
}
if (iid.equals(Components.interfaces.nsIDocShell)) {
return window.QueryInterface(Components.interfaces.nsIInterfaceRequestor)
.getInterface(Components.interfaces.nsIWebNavigation)
.QueryInterface(Components.interfaces.nsIDocShell);
}
return this.QueryInterface(iid);
},
loadCookie: null,
parentContentListener: null
}
function DetermineHTMLAction(convertible)
{
try {