aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llappviewermacosx.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2009-04-30 13:04:20 -0500
committerJacek Antonelli2009-04-30 13:07:16 -0500
commitca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e (patch)
tree8348301d0ac44a524f1819b777686bf086907d76 /linden/indra/newview/llappviewermacosx.cpp
parentSecond Life viewer sources 1.22.11 (diff)
downloadmeta-impy-ca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e.zip
meta-impy-ca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e.tar.gz
meta-impy-ca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e.tar.bz2
meta-impy-ca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e.tar.xz
Second Life viewer sources 1.23.0-RC
Diffstat (limited to 'linden/indra/newview/llappviewermacosx.cpp')
-rw-r--r--linden/indra/newview/llappviewermacosx.cpp21
1 files changed, 18 insertions, 3 deletions
diff --git a/linden/indra/newview/llappviewermacosx.cpp b/linden/indra/newview/llappviewermacosx.cpp
index 0e5062d..3cdcb35 100644
--- a/linden/indra/newview/llappviewermacosx.cpp
+++ b/linden/indra/newview/llappviewermacosx.cpp
@@ -17,7 +17,8 @@
17 * There are special exceptions to the terms and conditions of the GPL as 17 * There are special exceptions to the terms and conditions of the GPL as
18 * it is applied to this Source Code. View the full text of the exception 18 * it is applied to this Source Code. View the full text of the exception
19 * in the file doc/FLOSS-exception.txt in this software distribution, or 19 * in the file doc/FLOSS-exception.txt in this software distribution, or
20 * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception 20 * online at
21 * http://secondlifegrid.net/programs/open_source/licensing/flossexception
21 * 22 *
22 * By copying, modifying or distributing this software, you acknowledge 23 * By copying, modifying or distributing this software, you acknowledge
23 * that you have read and understood your obligations described above, 24 * that you have read and understood your obligations described above,
@@ -49,6 +50,7 @@
49#include <Carbon/Carbon.h> 50#include <Carbon/Carbon.h>
50#include "lldir.h" 51#include "lldir.h"
51#include <signal.h> 52#include <signal.h>
53class LLWebBrowserCtrl; // for LLURLDispatcher
52 54
53namespace 55namespace
54{ 56{
@@ -440,8 +442,21 @@ OSErr AEGURLHandler(const AppleEvent *messagein, AppleEvent *reply, long refIn)
440 if(result == noErr) 442 if(result == noErr)
441 { 443 {
442 std::string url = buffer; 444 std::string url = buffer;
443 const bool from_external_browser = true; 445
444 LLURLDispatcher::dispatch(url, from_external_browser); 446 // Safari 3.2 silently mangles secondlife:///app/ URLs into
447 // secondlife:/app/ (only one leading slash).
448 // Fix them up to meet the URL specification. JC
449 const std::string prefix = "secondlife:/app/";
450 std::string test_prefix = url.substr(0, prefix.length());
451 LLStringUtil::toLower(test_prefix);
452 if (test_prefix == prefix)
453 {
454 url.replace(0, prefix.length(), "secondlife:///app/");
455 }
456
457 LLWebBrowserCtrl* web = NULL;
458 const bool trusted_browser = false;
459 LLURLDispatcher::dispatch(url, web, trusted_browser);
445 } 460 }
446 461
447 return(result); 462 return(result);