aboutsummaryrefslogtreecommitdiffstats
path: root/embed/mozilla/ContentHandler.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'embed/mozilla/ContentHandler.cpp')
-rw-r--r--embed/mozilla/ContentHandler.cpp24
1 files changed, 16 insertions, 8 deletions
diff --git a/embed/mozilla/ContentHandler.cpp b/embed/mozilla/ContentHandler.cpp
index b7ba3b43f..3535d362c 100644
--- a/embed/mozilla/ContentHandler.cpp
+++ b/embed/mozilla/ContentHandler.cpp
@@ -416,14 +416,7 @@ NS_METHOD GContentHandler::MIMEDoAction (void)
mLauncher->GetMIMEInfo(getter_AddRefs(mimeInfo));
NS_ENSURE_TRUE (mimeInfo, NS_ERROR_FAILURE);
-#ifdef HAVE_GECKO_1_9
- nsHandlerInfoAction action;
- if (mAction == CONTENT_ACTION_DOWNLOAD) {
- action = EPHY_ACTION_BROWSE_TO_FILE;
- } else {
- action = nsIMIMEInfo::useSystemDefault;
- }
-#else
+#ifndef HAVE_GECKO_1_9
char *info = NULL;
if (mAction == CONTENT_ACTION_OPEN)
@@ -478,5 +471,20 @@ NS_METHOD GContentHandler::MIMEDoAction (void)
mLauncher->SaveToDisk (nsnull, PR_FALSE);
}
+#ifdef HAVE_GECKO_1_9
+ /* We have to do this work down here because the external helper app modifies the
+ * value after calling SaveToDisk.
+ */
+ nsHandlerInfoAction action;
+ if (mAction == CONTENT_ACTION_DOWNLOAD) {
+ action = EPHY_ACTION_BROWSE_TO_FILE;
+
+ /* This won't be able to transport the activation time so we cannot
+ * do startup notification, but it's the best that was available
+ */
+ mimeInfo->SetPreferredAction (action);
+ }
+#endif
+
return NS_OK;
}