mirror of
https://github.com/libretro/scummvm.git
synced 2025-04-03 07:11:49 +00:00
CLOUD: Move openUrl to OSystem
This commit is contained in:
parent
dff88b1058
commit
1f2a50bcd3
@ -150,33 +150,6 @@ MODULE_OBJS += \
|
||||
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
|
||||
ifeq ($(BACKEND),android)
|
||||
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 == kFeatureCursorPalette ||
|
||||
f == kFeatureVirtualKeyboard ||
|
||||
f == kFeatureOverlaySupportsAlpha);
|
||||
f == kFeatureOverlaySupportsAlpha ||
|
||||
f == kFeatureOpenUrl);
|
||||
}
|
||||
|
||||
void OSystem_Android::setFeatureState(Feature f, bool enable) {
|
||||
@ -586,6 +587,10 @@ Common::String OSystem_Android::getSystemLanguage() const {
|
||||
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 {
|
||||
char value[PROP_VALUE_MAX];
|
||||
|
||||
|
@ -286,6 +286,7 @@ public:
|
||||
virtual void logMessage(LogMessageType::Type type, const char *message);
|
||||
virtual void addSysArchivesToSearchSet(Common::SearchSet &s,
|
||||
int priority = 0);
|
||||
virtual bool openUrl(const Common::String &url);
|
||||
virtual Common::String getSystemLanguage() const;
|
||||
};
|
||||
|
||||
|
@ -107,7 +107,7 @@ void OSystem_MacOSX::addSysArchivesToSearchSet(Common::SearchSet &s, int priorit
|
||||
}
|
||||
|
||||
bool OSystem_MacOSX::hasFeature(Feature f) {
|
||||
if (f == kFeatureDisplayLogFile || f == kFeatureClipboardSupport)
|
||||
if (f == kFeatureDisplayLogFile || f == kFeatureClipboardSupport || f == kFeatureOpenUrl)
|
||||
return true;
|
||||
return OSystem_POSIX::hasFeature(f);
|
||||
}
|
||||
@ -133,6 +133,13 @@ Common::String OSystem_MacOSX::getTextFromClipboard() {
|
||||
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 {
|
||||
#if defined(USE_DETECTLANG) && defined(USE_TRANSLATION)
|
||||
CFArrayRef availableLocalizations = CFBundleCopyBundleLocalizations(CFBundleGetMainBundle());
|
||||
|
@ -35,6 +35,8 @@ public:
|
||||
|
||||
virtual bool hasTextInClipboard();
|
||||
virtual Common::String getTextFromClipboard();
|
||||
|
||||
virtual bool openUrl(const Common::String &url);
|
||||
|
||||
virtual Common::String getSystemLanguage() const;
|
||||
|
||||
|
@ -25,6 +25,7 @@
|
||||
#define FORBIDDEN_SYMBOL_EXCEPTION_exit
|
||||
#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_system
|
||||
|
||||
#include "common/scummsys.h"
|
||||
|
||||
@ -40,6 +41,9 @@
|
||||
#include "backends/audiocd/linux/linux-audiocd.h"
|
||||
#endif
|
||||
|
||||
#include "common/textconsole.h"
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include <sys/stat.h>
|
||||
#include <sys/wait.h>
|
||||
@ -78,7 +82,7 @@ void OSystem_POSIX::initBackend() {
|
||||
}
|
||||
|
||||
bool OSystem_POSIX::hasFeature(Feature f) {
|
||||
if (f == kFeatureDisplayLogFile)
|
||||
if (f == kFeatureDisplayLogFile || f == kFeatureOpenUrl)
|
||||
return true;
|
||||
return OSystem_SDL::hasFeature(f);
|
||||
}
|
||||
@ -261,6 +265,51 @@ bool OSystem_POSIX::displayLogFile() {
|
||||
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() {
|
||||
#ifdef USE_LINUXCD
|
||||
|
@ -35,6 +35,8 @@ public:
|
||||
|
||||
virtual bool displayLogFile();
|
||||
|
||||
virtual bool openUrl(const Common::String &url);
|
||||
|
||||
virtual void init();
|
||||
virtual void initBackend();
|
||||
|
||||
@ -63,6 +65,8 @@ protected:
|
||||
virtual Common::WriteStream *createLogFile();
|
||||
|
||||
virtual AudioCDManager *createAudioCDManager();
|
||||
|
||||
bool launchBrowser(const Common::String& client, const Common::String &url);
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@ -94,7 +94,7 @@ void OSystem_Win32::initBackend() {
|
||||
|
||||
|
||||
bool OSystem_Win32::hasFeature(Feature f) {
|
||||
if (f == kFeatureDisplayLogFile)
|
||||
if (f == kFeatureDisplayLogFile || f == kFeatureOpenUrl)
|
||||
return true;
|
||||
|
||||
return OSystem_SDL::hasFeature(f);
|
||||
@ -135,6 +135,16 @@ bool OSystem_Win32::displayLogFile() {
|
||||
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() {
|
||||
char configFile[MAXPATHLEN];
|
||||
|
||||
|
@ -36,6 +36,8 @@ public:
|
||||
|
||||
virtual bool displayLogFile();
|
||||
|
||||
virtual bool openUrl(const Common::String &url);
|
||||
|
||||
protected:
|
||||
/**
|
||||
* The path of the currently open log file, if any.
|
||||
|
@ -322,7 +322,15 @@ public:
|
||||
*
|
||||
* 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 ""; }
|
||||
|
||||
/**
|
||||
* 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.
|
||||
*
|
||||
|
@ -113,11 +113,6 @@ bool shouldSkipFileForTarget(const std::string &fileID, const std::string &targe
|
||||
splitFilename(fileName, name, ext);
|
||||
|
||||
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
|
||||
if (name.length() > 4 && name.substr(name.length() - 4) == "_osx") {
|
||||
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) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// networking backend for macOS is openurl-osx
|
||||
if (name == "openurl-default" || name == "openurl-posix") {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
@ -22,7 +22,6 @@
|
||||
|
||||
#include "testbed/misc.h"
|
||||
#include "common/timer.h"
|
||||
#include "backends/networking/browser/openurl.h"
|
||||
|
||||
namespace Testbed {
|
||||
|
||||
@ -170,7 +169,7 @@ TestExitStatus MiscTests::testOpenUrl() {
|
||||
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");
|
||||
return kTestFailed;
|
||||
}
|
||||
|
@ -23,7 +23,6 @@
|
||||
#include "testbed/webserver.h"
|
||||
#include "backends/networking/sdl_net/localwebserver.h"
|
||||
#include "common/config-manager.h"
|
||||
#include "backends/networking/browser/openurl.h"
|
||||
|
||||
namespace Testbed {
|
||||
|
||||
@ -92,7 +91,7 @@ TestExitStatus WebserverTests::testIndexPage() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress());
|
||||
g_system->openUrl(LocalServer.getAddress());
|
||||
if (Testsuite::handleInteractiveInput(
|
||||
Common::String::format("The %s page opens well?", LocalServer.getAddress().c_str()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
@ -118,7 +117,7 @@ TestExitStatus WebserverTests::testFilesPageInvalidParameterValue() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress()+"files?path=error");
|
||||
g_system->openUrl(LocalServer.getAddress()+"files?path=error");
|
||||
if (Testsuite::handleInteractiveInput(
|
||||
Common::String::format("The %sfiles?path=error page displays error message?", LocalServer.getAddress().c_str()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
@ -144,7 +143,7 @@ TestExitStatus WebserverTests::testFilesPageCreateDirectory() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
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()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
@ -170,7 +169,7 @@ TestExitStatus WebserverTests::testFilesPageUploadFile() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
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()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
@ -196,7 +195,7 @@ TestExitStatus WebserverTests::testFilesPageUploadDirectory() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
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()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
@ -222,7 +221,7 @@ TestExitStatus WebserverTests::testFilesPageDownloadFile() {
|
||||
return kTestSkipped;
|
||||
}
|
||||
|
||||
Networking::Browser::openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
g_system->openUrl(LocalServer.getAddress() + "files?path=/root/");
|
||||
if (Testsuite::handleInteractiveInput(
|
||||
Common::String::format("You're able to download a file through %sfiles page?", LocalServer.getAddress().c_str()),
|
||||
"Yes", "No", kOptionRight)) {
|
||||
|
@ -30,7 +30,6 @@
|
||||
#ifdef USE_SDL_NET
|
||||
#include "backends/networking/sdl_net/localwebserver.h"
|
||||
#endif
|
||||
#include "backends/networking/browser/openurl.h"
|
||||
#include "common/translation.h"
|
||||
|
||||
namespace GUI {
|
||||
@ -206,7 +205,7 @@ void StorageWizardDialog::handleCommand(CommandSender *sender, uint32 cmd, uint3
|
||||
break;
|
||||
}
|
||||
case kOpenUrlCmd: {
|
||||
if (!Networking::Browser::openUrl(getUrl())) {
|
||||
if (!g_system->openUrl(getUrl())) {
|
||||
MessageDialog alert(_("Failed to open URL!\nPlease navigate to this page manually."));
|
||||
alert.runModal();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user