diff options
author | Jacek Antonelli | 2009-04-30 13:04:20 -0500 |
---|---|---|
committer | Jacek Antonelli | 2009-04-30 13:07:16 -0500 |
commit | ca8149ca6d157eb4b5fc8ba0e5ba3a6e56f72e7e (patch) | |
tree | 8348301d0ac44a524f1819b777686bf086907d76 /linden/indra/newview/llappviewermacosx.cpp | |
parent | Second Life viewer sources 1.22.11 (diff) | |
download | meta-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.cpp | 21 |
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> |
53 | class LLWebBrowserCtrl; // for LLURLDispatcher | ||
52 | 54 | ||
53 | namespace | 55 | namespace |
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); |