mirror of
https://github.com/libretro/scummvm.git
synced 2025-04-05 16:21:40 +00:00
CLOUD: Move openUrl to OSystem
This commit is contained in:
parent
dff88b1058
commit
1f2a50bcd3
@ -150,33 +150,6 @@ MODULE_OBJS += \
|
|||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# openUrl
|
|
||||||
ifeq ($(BACKEND),android)
|
|
||||||
MODULE_OBJS += \
|
|
||||||
networking/browser/openurl-android.o
|
|
||||||
else
|
|
||||||
ifdef MACOSX
|
|
||||||
MODULE_OBJS += \
|
|
||||||
networking/browser/openurl-osx.o
|
|
||||||
else
|
|
||||||
ifdef WIN32
|
|
||||||
MODULE_OBJS += \
|
|
||||||
networking/browser/openurl-windows.o
|
|
||||||
else
|
|
||||||
ifdef POSIX
|
|
||||||
MODULE_OBJS += \
|
|
||||||
networking/browser/openurl-posix.o
|
|
||||||
else
|
|
||||||
# create_project doesn't know something about `else`
|
|
||||||
ifndef WIN32
|
|
||||||
MODULE_OBJS += \
|
|
||||||
networking/browser/openurl-default.o
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Connection::isLimited
|
# Connection::isLimited
|
||||||
ifeq ($(BACKEND),android)
|
ifeq ($(BACKEND),android)
|
||||||
MODULE_OBJS += \
|
MODULE_OBJS += \
|
||||||
|
@ -1,35 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include "backends/platform/android/jni.h"
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
bool openUrl(const Common::String &url) {
|
|
||||||
return JNI::openUrl(url.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
||||||
|
|
@ -1,36 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include "common/textconsole.h"
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
bool openUrl(const Common::String &url) {
|
|
||||||
warning("Networking::Browser::openUrl(): not implemented");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
||||||
|
|
@ -1,49 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define FORBIDDEN_SYMBOL_ALLOW_ALL
|
|
||||||
|
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include <CoreFoundation/CFBundle.h>
|
|
||||||
#include <ApplicationServices/ApplicationServices.h>
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
bool openUrl(const Common::String &url) {
|
|
||||||
CFURLRef urlRef = CFURLCreateWithBytes (
|
|
||||||
NULL,
|
|
||||||
(UInt8*)url.c_str(),
|
|
||||||
url.size(),
|
|
||||||
kCFStringEncodingASCII,
|
|
||||||
NULL
|
|
||||||
);
|
|
||||||
int result = LSOpenCFURLRef(urlRef, 0);
|
|
||||||
CFRelease(urlRef);
|
|
||||||
return result == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
||||||
|
|
@ -1,77 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define FORBIDDEN_SYMBOL_ALLOW_ALL
|
|
||||||
|
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include "common/textconsole.h"
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
bool launch(const Common::String client, const Common::String &url) {
|
|
||||||
// FIXME: system's input must be heavily escaped
|
|
||||||
// well, when url's specified by user
|
|
||||||
// it's OK now (urls are hardcoded somewhere in GUI)
|
|
||||||
Common::String cmd = client + " " + url;
|
|
||||||
return (system(cmd.c_str()) != -1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool openUrl(const Common::String &url) {
|
|
||||||
// inspired by Qt's "qdesktopservices_x11.cpp"
|
|
||||||
|
|
||||||
// try "standards"
|
|
||||||
if (launch("xdg-open", url))
|
|
||||||
return true;
|
|
||||||
if (launch(getenv("DEFAULT_BROWSER"), url))
|
|
||||||
return true;
|
|
||||||
if (launch(getenv("BROWSER"), url))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// try desktop environment specific tools
|
|
||||||
if (launch("gnome-open", url)) // gnome
|
|
||||||
return true;
|
|
||||||
if (launch("kfmclient openURL", url)) // kde
|
|
||||||
return true;
|
|
||||||
if (launch("exo-open", url)) // xfce
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// try browser names
|
|
||||||
if (launch("firefox", url))
|
|
||||||
return true;
|
|
||||||
if (launch("mozilla", url))
|
|
||||||
return true;
|
|
||||||
if (launch("netscape", url))
|
|
||||||
return true;
|
|
||||||
if (launch("opera", url))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
warning("Networking::Browser::openUrl() (POSIX) failed to open URL");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include "common/textconsole.h"
|
|
||||||
#include <windows.h>
|
|
||||||
#include <shellapi.h>
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
bool openUrl(const Common::String &url) {
|
|
||||||
const uint64 result = (uint64)ShellExecute(0, 0, /*(wchar_t*)nativeFilePath.utf16()*/url.c_str(), 0, 0, SW_SHOWNORMAL);
|
|
||||||
// ShellExecute returns a value greater than 32 if successful
|
|
||||||
if (result <= 32) {
|
|
||||||
warning("ShellExecute failed: error = %u", result);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
@ -1,41 +0,0 @@
|
|||||||
/* ScummVM - Graphic Adventure Engine
|
|
||||||
*
|
|
||||||
* ScummVM is the legal property of its developers, whose names
|
|
||||||
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
||||||
* file distributed with this source distribution.
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* as published by the Free Software Foundation; either version 2
|
|
||||||
* of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, write to the Free Software
|
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef NETWORKING_BROWSER_OPENURL_H
|
|
||||||
#define NETWORKING_BROWSER_OPENURL_H
|
|
||||||
|
|
||||||
#include "common/str.h"
|
|
||||||
|
|
||||||
namespace Networking {
|
|
||||||
namespace Browser {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Opens URL in default browser (if available on the target system).
|
|
||||||
*
|
|
||||||
* Returns true on success.
|
|
||||||
*/
|
|
||||||
bool openUrl(const Common::String &url);
|
|
||||||
|
|
||||||
} // End of namespace Browser
|
|
||||||
} // End of namespace Networking
|
|
||||||
|
|
||||||
#endif /*NETWORKING_BROWSER_OPENURL_H*/
|
|
@ -401,7 +401,8 @@ bool OSystem_Android::hasFeature(Feature f) {
|
|||||||
f == kFeatureAspectRatioCorrection ||
|
f == kFeatureAspectRatioCorrection ||
|
||||||
f == kFeatureCursorPalette ||
|
f == kFeatureCursorPalette ||
|
||||||
f == kFeatureVirtualKeyboard ||
|
f == kFeatureVirtualKeyboard ||
|
||||||
f == kFeatureOverlaySupportsAlpha);
|
f == kFeatureOverlaySupportsAlpha ||
|
||||||
|
f == kFeatureOpenUrl);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OSystem_Android::setFeatureState(Feature f, bool enable) {
|
void OSystem_Android::setFeatureState(Feature f, bool enable) {
|
||||||
@ -586,6 +587,10 @@ Common::String OSystem_Android::getSystemLanguage() const {
|
|||||||
getSystemProperty("persist.sys.country").c_str());
|
getSystemProperty("persist.sys.country").c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool OSystem_Android::openUrl(const Common::String &url) {
|
||||||
|
return JNI::openUrl(url.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
Common::String OSystem_Android::getSystemProperty(const char *name) const {
|
Common::String OSystem_Android::getSystemProperty(const char *name) const {
|
||||||
char value[PROP_VALUE_MAX];
|
char value[PROP_VALUE_MAX];
|
||||||
|
|
||||||
|
@ -286,6 +286,7 @@ public:
|
|||||||
virtual void logMessage(LogMessageType::Type type, const char *message);
|
virtual void logMessage(LogMessageType::Type type, const char *message);
|
||||||
virtual void addSysArchivesToSearchSet(Common::SearchSet &s,
|
virtual void addSysArchivesToSearchSet(Common::SearchSet &s,
|
||||||
int priority = 0);
|
int priority = 0);
|
||||||
|
virtual bool openUrl(const Common::String &url);
|
||||||
virtual Common::String getSystemLanguage() const;
|
virtual Common::String getSystemLanguage() const;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -107,7 +107,7 @@ void OSystem_MacOSX::addSysArchivesToSearchSet(Common::SearchSet &s, int priorit
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool OSystem_MacOSX::hasFeature(Feature f) {
|
bool OSystem_MacOSX::hasFeature(Feature f) {
|
||||||
if (f == kFeatureDisplayLogFile || f == kFeatureClipboardSupport)
|
if (f == kFeatureDisplayLogFile || f == kFeatureClipboardSupport || f == kFeatureOpenUrl)
|
||||||
return true;
|
return true;
|
||||||
return OSystem_POSIX::hasFeature(f);
|
return OSystem_POSIX::hasFeature(f);
|
||||||
}
|
}
|
||||||
@ -133,6 +133,13 @@ Common::String OSystem_MacOSX::getTextFromClipboard() {
|
|||||||
return getTextFromClipboardMacOSX();
|
return getTextFromClipboardMacOSX();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool OSystem_MacOSX::openUrl(const Common::String &url) {
|
||||||
|
CFURLRef urlRef = CFURLCreateWithBytes (NULL, (UInt8*)url.c_str(), url.size(), kCFStringEncodingASCII, NULL);
|
||||||
|
OSStatus err = LSOpenCFURLRef(urlRef, NULL);
|
||||||
|
CFRelease(urlRef);
|
||||||
|
return err != noErr;
|
||||||
|
}
|
||||||
|
|
||||||
Common::String OSystem_MacOSX::getSystemLanguage() const {
|
Common::String OSystem_MacOSX::getSystemLanguage() const {
|
||||||
#if defined(USE_DETECTLANG) && defined(USE_TRANSLATION)
|
#if defined(USE_DETECTLANG) && defined(USE_TRANSLATION)
|
||||||
CFArrayRef availableLocalizations = CFBundleCopyBundleLocalizations(CFBundleGetMainBundle());
|
CFArrayRef availableLocalizations = CFBundleCopyBundleLocalizations(CFBundleGetMainBundle());
|
||||||
|
@ -35,6 +35,8 @@ public:
|
|||||||
|
|
||||||
virtual bool hasTextInClipboard();
|
virtual bool hasTextInClipboard();
|
||||||
virtual Common::String getTextFromClipboard();
|
virtual Common::String getTextFromClipboard();
|
||||||
|
|
||||||
|
virtual bool openUrl(const Common::String &url);
|
||||||
|
|
||||||
virtual Common::String getSystemLanguage() const;
|
virtual Common::String getSystemLanguage() const;
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#define FORBIDDEN_SYMBOL_EXCEPTION_exit
|
#define FORBIDDEN_SYMBOL_EXCEPTION_exit
|
||||||
#define FORBIDDEN_SYMBOL_EXCEPTION_unistd_h
|
#define FORBIDDEN_SYMBOL_EXCEPTION_unistd_h
|
||||||
#define FORBIDDEN_SYMBOL_EXCEPTION_time_h //On IRIX, sys/stat.h includes sys/time.h
|
#define FORBIDDEN_SYMBOL_EXCEPTION_time_h //On IRIX, sys/stat.h includes sys/time.h
|
||||||
|
#define FORBIDDEN_SYMBOL_EXCEPTION_system
|
||||||
|
|
||||||
#include "common/scummsys.h"
|
#include "common/scummsys.h"
|
||||||
|
|
||||||
@ -40,6 +41,9 @@
|
|||||||
#include "backends/audiocd/linux/linux-audiocd.h"
|
#include "backends/audiocd/linux/linux-audiocd.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "common/textconsole.h"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
@ -78,7 +82,7 @@ void OSystem_POSIX::initBackend() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool OSystem_POSIX::hasFeature(Feature f) {
|
bool OSystem_POSIX::hasFeature(Feature f) {
|
||||||
if (f == kFeatureDisplayLogFile)
|
if (f == kFeatureDisplayLogFile || f == kFeatureOpenUrl)
|
||||||
return true;
|
return true;
|
||||||
return OSystem_SDL::hasFeature(f);
|
return OSystem_SDL::hasFeature(f);
|
||||||
}
|
}
|
||||||
@ -261,6 +265,51 @@ bool OSystem_POSIX::displayLogFile() {
|
|||||||
return WIFEXITED(status) && WEXITSTATUS(status) == 0;
|
return WIFEXITED(status) && WEXITSTATUS(status) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool OSystem_POSIX::openUrl(const Common::String &url) {
|
||||||
|
// inspired by Qt's "qdesktopservices_x11.cpp"
|
||||||
|
|
||||||
|
// try "standards"
|
||||||
|
if (launchBrowser("xdg-open", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser(getenv("DEFAULT_BROWSER"), url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser(getenv("BROWSER"), url))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// try desktop environment specific tools
|
||||||
|
if (launchBrowser("gnome-open", url)) // gnome
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("kfmclient openURL", url)) // kde
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("exo-open", url)) // xfce
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// try browser names
|
||||||
|
if (launchBrowser("firefox", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("mozilla", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("netscape", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("opera", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("chromium-browser", url))
|
||||||
|
return true;
|
||||||
|
if (launchBrowser("google-chrome", url))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
warning("openUrl() (POSIX) failed to open URL");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool OSystem_POSIX::launchBrowser(const Common::String& client, const Common::String &url) {
|
||||||
|
// FIXME: system's input must be heavily escaped
|
||||||
|
// well, when url's specified by user
|
||||||
|
// it's OK now (urls are hardcoded somewhere in GUI)
|
||||||
|
Common::String cmd = client + " " + url;
|
||||||
|
return (system(cmd.c_str()) != -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
AudioCDManager *OSystem_POSIX::createAudioCDManager() {
|
AudioCDManager *OSystem_POSIX::createAudioCDManager() {
|
||||||
#ifdef USE_LINUXCD
|
#ifdef USE_LINUXCD
|
||||||
|
@ -35,6 +35,8 @@ public:
|
|||||||
|
|
||||||
virtual bool displayLogFile();
|
virtual bool displayLogFile();
|
||||||
|
|
||||||
|
virtual bool openUrl(const Common::String &url);
|
||||||
|
|
||||||
virtual void init();
|
virtual void init();
|
||||||
virtual void initBackend();
|
virtual void initBackend();
|
||||||
|
|
||||||
@ -63,6 +65,8 @@ protected:
|
|||||||
virtual Common::WriteStream *createLogFile();
|
virtual Common::WriteStream *createLogFile();
|
||||||
|
|
||||||
virtual AudioCDManager *createAudioCDManager();
|
virtual AudioCDManager *createAudioCDManager();
|
||||||
|
|
||||||
|
bool launchBrowser(const Common::String& client, const Common::String &url);
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -94,7 +94,7 @@ void OSystem_Win32::initBackend() {
|
|||||||
|
|
||||||
|
|
||||||
bool OSystem_Win32::hasFeature(Feature f) {
|
bool OSystem_Win32::hasFeature(Feature f) {
|
||||||
if (f == kFeatureDisplayLogFile)
|
if (f == kFeatureDisplayLogFile || f == kFeatureOpenUrl)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
return OSystem_SDL::hasFeature(f);
|
return OSystem_SDL::hasFeature(f);
|
||||||
@ -135,6 +135,16 @@ bool OSystem_Win32::displayLogFile() {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool OSystem_Win32::openUrl(const Common::String &url) {
|
||||||
|
const uint64 result = (uint64)ShellExecute(0, 0, /*(wchar_t*)nativeFilePath.utf16()*/url.c_str(), 0, 0, SW_SHOWNORMAL);
|
||||||
|
// ShellExecute returns a value greater than 32 if successful
|
||||||
|
if (result <= 32) {
|
||||||
|
warning("ShellExecute failed: error = %u", result);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
Common::String OSystem_Win32::getDefaultConfigFileName() {
|
Common::String OSystem_Win32::getDefaultConfigFileName() {
|
||||||
char configFile[MAXPATHLEN];
|
char configFile[MAXPATHLEN];
|
||||||
|
|
||||||
|
@ -36,6 +36,8 @@ public:
|
|||||||
|
|
||||||
virtual bool displayLogFile();
|
virtual bool displayLogFile();
|
||||||
|
|
||||||
|
virtual bool openUrl(const Common::String &url);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
* The path of the currently open log file, if any.
|
* The path of the currently open log file, if any.
|
||||||
|
@ -322,7 +322,15 @@ public:
|
|||||||
*
|
*
|
||||||
* This feature has no associated state.
|
* This feature has no associated state.
|
||||||
*/
|
*/
|
||||||
kFeatureClipboardSupport
|
kFeatureClipboardSupport,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The presence of this feature indicates whether the openUrl()
|
||||||
|
* call is supported.
|
||||||
|
*
|
||||||
|
* This feature has no associated state.
|
||||||
|
*/
|
||||||
|
kFeatureOpenUrl
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1268,6 +1276,20 @@ public:
|
|||||||
*/
|
*/
|
||||||
virtual Common::String getTextFromClipboard() { return ""; }
|
virtual Common::String getTextFromClipboard() { return ""; }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Open the given Url in the default browser (if available on the target
|
||||||
|
* system).
|
||||||
|
*
|
||||||
|
* @return true on success, false otherwise.
|
||||||
|
*
|
||||||
|
* @note It is up to the backend to ensure that the system is in a state
|
||||||
|
* that allows the user to actually see the web page. This might for
|
||||||
|
* example require leaving fullscreen mode.
|
||||||
|
*
|
||||||
|
* @parem url the URL to open
|
||||||
|
*/
|
||||||
|
virtual bool openUrl(const Common::String &url) {return false; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the locale of the system.
|
* Returns the locale of the system.
|
||||||
*
|
*
|
||||||
|
@ -113,11 +113,6 @@ bool shouldSkipFileForTarget(const std::string &fileID, const std::string &targe
|
|||||||
splitFilename(fileName, name, ext);
|
splitFilename(fileName, name, ext);
|
||||||
|
|
||||||
if (targetIsIOS(targetName)) {
|
if (targetIsIOS(targetName)) {
|
||||||
// networking backend for iOS is openurl-default
|
|
||||||
if (name == "openurl-posix" || name == "openurl-osx") {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// iOS target: we skip all files with the "_osx" suffix
|
// iOS target: we skip all files with the "_osx" suffix
|
||||||
if (name.length() > 4 && name.substr(name.length() - 4) == "_osx") {
|
if (name.length() > 4 && name.substr(name.length() - 4) == "_osx") {
|
||||||
return true;
|
return true;
|
||||||
@ -156,11 +151,6 @@ bool shouldSkipFileForTarget(const std::string &fileID, const std::string &targe
|
|||||||
if (directory.length() > iphone_directory.length() && directory.substr(directory.length() - iphone_directory.length()) == iphone_directory) {
|
if (directory.length() > iphone_directory.length() && directory.substr(directory.length() - iphone_directory.length()) == iphone_directory) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// networking backend for macOS is openurl-osx
|
|
||||||
if (name == "openurl-default" || name == "openurl-posix") {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
|
|
||||||
#include "testbed/misc.h"
|
#include "testbed/misc.h"
|
||||||
#include "common/timer.h"
|
#include "common/timer.h"
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
|
|
||||||
namespace Testbed {
|
namespace Testbed {
|
||||||
|
|
||||||
@ -170,7 +169,7 @@ TestExitStatus MiscTests::testOpenUrl() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Networking::Browser::openUrl("http://scummvm.org/")) {
|
if (!g_system->openUrl("http://scummvm.org/")) {
|
||||||
Testsuite::logPrintf("Info! openUrl() says it couldn't open the url (probably not supported on this platform)\n");
|
Testsuite::logPrintf("Info! openUrl() says it couldn't open the url (probably not supported on this platform)\n");
|
||||||
return kTestFailed;
|
return kTestFailed;
|
||||||
}
|
}
|
||||||
|
@ -23,7 +23,6 @@
|
|||||||
#include "testbed/webserver.h"
|
#include "testbed/webserver.h"
|
||||||
#include "backends/networking/sdl_net/localwebserver.h"
|
#include "backends/networking/sdl_net/localwebserver.h"
|
||||||
#include "common/config-manager.h"
|
#include "common/config-manager.h"
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
|
|
||||||
namespace Testbed {
|
namespace Testbed {
|
||||||
|
|
||||||
@ -92,7 +91,7 @@ TestExitStatus WebserverTests::testIndexPage() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress());
|
g_system->openUrl(LocalServer.getAddress());
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("The %s page opens well?", LocalServer.getAddress().c_str()),
|
Common::String::format("The %s page opens well?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
@ -118,7 +117,7 @@ TestExitStatus WebserverTests::testFilesPageInvalidParameterValue() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress()+"files?path=error");
|
g_system->openUrl(LocalServer.getAddress()+"files?path=error");
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("The %sfiles?path=error page displays error message?", LocalServer.getAddress().c_str()),
|
Common::String::format("The %sfiles?path=error page displays error message?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
@ -144,7 +143,7 @@ TestExitStatus WebserverTests::testFilesPageCreateDirectory() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("You could go to %sfiles page, navigate to some directory with write access and create a directory there?", LocalServer.getAddress().c_str()),
|
Common::String::format("You could go to %sfiles page, navigate to some directory with write access and create a directory there?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
@ -170,7 +169,7 @@ TestExitStatus WebserverTests::testFilesPageUploadFile() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("You're able to upload a file in some directory with write access through %sfiles page?", LocalServer.getAddress().c_str()),
|
Common::String::format("You're able to upload a file in some directory with write access through %sfiles page?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
@ -196,7 +195,7 @@ TestExitStatus WebserverTests::testFilesPageUploadDirectory() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("You're able to upload a directory into some directory with write access through %sfiles page using Chrome?", LocalServer.getAddress().c_str()),
|
Common::String::format("You're able to upload a directory into some directory with write access through %sfiles page using Chrome?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
@ -222,7 +221,7 @@ TestExitStatus WebserverTests::testFilesPageDownloadFile() {
|
|||||||
return kTestSkipped;
|
return kTestSkipped;
|
||||||
}
|
}
|
||||||
|
|
||||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||||
if (Testsuite::handleInteractiveInput(
|
if (Testsuite::handleInteractiveInput(
|
||||||
Common::String::format("You're able to download a file through %sfiles page?", LocalServer.getAddress().c_str()),
|
Common::String::format("You're able to download a file through %sfiles page?", LocalServer.getAddress().c_str()),
|
||||||
"Yes", "No", kOptionRight)) {
|
"Yes", "No", kOptionRight)) {
|
||||||
|
@ -30,7 +30,6 @@
|
|||||||
#ifdef USE_SDL_NET
|
#ifdef USE_SDL_NET
|
||||||
#include "backends/networking/sdl_net/localwebserver.h"
|
#include "backends/networking/sdl_net/localwebserver.h"
|
||||||
#endif
|
#endif
|
||||||
#include "backends/networking/browser/openurl.h"
|
|
||||||
#include "common/translation.h"
|
#include "common/translation.h"
|
||||||
|
|
||||||
namespace GUI {
|
namespace GUI {
|
||||||
@ -206,7 +205,7 @@ void StorageWizardDialog::handleCommand(CommandSender *sender, uint32 cmd, uint3
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case kOpenUrlCmd: {
|
case kOpenUrlCmd: {
|
||||||
if (!Networking::Browser::openUrl(getUrl())) {
|
if (!g_system->openUrl(getUrl())) {
|
||||||
MessageDialog alert(_("Failed to open URL!\nPlease navigate to this page manually."));
|
MessageDialog alert(_("Failed to open URL!\nPlease navigate to this page manually."));
|
||||||
alert.runModal();
|
alert.runModal();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user