MACOSX: Turned update support off by default, simplified and cleaned the pull request

This commit is contained in:
Oystein Eftevaag 2011-08-02 21:00:57 -04:00
parent 9044e17499
commit 7e7e606919
7 changed files with 24 additions and 118 deletions

View file

@ -15,8 +15,7 @@ MODULE_OBJS := \
midi/timidity.o \ midi/timidity.o \
saves/savefile.o \ saves/savefile.o \
saves/default/default-saves.o \ saves/default/default-saves.o \
timer/default/default-timer.o \ timer/default/default-timer.o
updates/sparkle-updates.o
ifdef USE_ELF_LOADER ifdef USE_ELF_LOADER

View file

@ -64,7 +64,7 @@ void OSystem_MacOSX::initBackend() {
// Replace the SDL generated menu items with our own translated ones on Mac OS X // Replace the SDL generated menu items with our own translated ones on Mac OS X
replaceApplicationMenuItems(); replaceApplicationMenuItems();
#if defined(USE_SPARKLE) #ifdef USE_SPARKLE
// Initialize updates manager // Initialize updates manager
_updateManager = new MacOSXUpdateManager(); _updateManager = new MacOSXUpdateManager();
#endif #endif

View file

@ -23,11 +23,13 @@
#ifndef BACKENDS_UPDATES_MACOSX_H #ifndef BACKENDS_UPDATES_MACOSX_H
#define BACKENDS_UPDATES_MACOSX_H #define BACKENDS_UPDATES_MACOSX_H
#include "backends/updates/sparkle-updates.h" #include "common/scummsys.h"
#if defined(MACOSX) && defined(USE_SPARKLE) #if defined(MACOSX) && defined(USE_SPARKLE)
class MacOSXUpdateManager : public SparkleUpdateManager { #include "common/updates.h"
class MacOSXUpdateManager : public Common::UpdateManager {
public: public:
MacOSXUpdateManager(); MacOSXUpdateManager();
virtual ~MacOSXUpdateManager(); virtual ~MacOSXUpdateManager();

View file

@ -23,11 +23,9 @@
// Disable symbol overrides so that we can use system headers. // Disable symbol overrides so that we can use system headers.
#define FORBIDDEN_SYMBOL_ALLOW_ALL #define FORBIDDEN_SYMBOL_ALLOW_ALL
#include "backends/updates/sparkle-updates.h"
#if defined(MACOSX) && defined(USE_SPARKLE)
#include "backends/updates/macosx/macosx-updates.h" #include "backends/updates/macosx/macosx-updates.h"
#ifdef USE_SPARKLE
#include "common/translation.h" #include "common/translation.h"
#include <Cocoa/Cocoa.h> #include <Cocoa/Cocoa.h>
@ -53,8 +51,12 @@ MacOSXUpdateManager::MacOSXUpdateManager() {
// Init Sparkle // Init Sparkle
sparkleUpdater = [SUUpdater sharedUpdater]; sparkleUpdater = [SUUpdater sharedUpdater];
NSBundle* mainBundle = [NSBundle mainBundle];
NSString* feedbackURL = [mainBundle objectForInfoDictionaryKey:@"SUFeedURL"];
// Set appcast URL // Set appcast URL
[sparkleUpdater setFeedURL:[NSURL URLWithString:[NSString stringWithCString:getAppcastUrl().c_str()]]]; [sparkleUpdater setFeedURL:[NSURL URLWithString:feedbackURL]];
// Get current encoding // Get current encoding
NSStringEncoding stringEncoding = CFStringConvertEncodingToNSStringEncoding(CFStringConvertIANACharSetNameToEncoding((CFStringRef)[NSString stringWithCString:(TransMan.getCurrentCharset()).c_str() encoding:NSASCIIStringEncoding])); NSStringEncoding stringEncoding = CFStringConvertEncodingToNSStringEncoding(CFStringConvertIANACharSetNameToEncoding((CFStringRef)[NSString stringWithCString:(TransMan.getCurrentCharset()).c_str() encoding:NSASCIIStringEncoding]));
@ -108,22 +110,18 @@ Common::UpdateManager::UpdateInterval MacOSXUpdateManager::getUpdateCheckInterva
// This is kind of a hack but necessary, as the value stored by Sparkle // This is kind of a hack but necessary, as the value stored by Sparkle
// might have been changed outside of ScummVM (in which case we return the // might have been changed outside of ScummVM (in which case we return the
// default interval of one day) // default interval of one day)
switch ((UpdateInterval)[sparkleUpdater updateCheckInterval]) {
default:
break;
case kUpdateIntervalOneDay: UpdateInterval updateInterval = (UpdateInterval)[sparkleUpdater updateCheckInterval];
return kUpdateIntervalOneDay; switch (updateInterval) {
case kUpdateIntervalOneDay:
case kUpdateIntervalOneWeek:
case kUpdateIntervalOneMonth:
return updateInterval;
case kUpdateIntervalOneWeek: default:
return kUpdateIntervalOneWeek; // Return the default value (one day)
return kUpdateIntervalOneDay;
case kUpdateIntervalOneMonth:
return kUpdateIntervalOneMonth;
} }
// Return the default value (one day)
return kUpdateIntervalOneDay;
} }
#endif #endif

View file

@ -1,45 +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/updates/sparkle-updates.h"
#if defined(USE_SPARKLE)
// TODO replace by proper URL
#if defined(MACOSX)
#define APPCAST_BASE_URL "http://www.scummvm.org/appcasts/macosx/"
#elif defined(WIN32)
#define APPCAST_BASE_URL "http://www.scummvm.org/appcasts/win32/"
#else
#error "Please define APPCAST_BASE_URL for your platform!"
#endif
Common::String SparkleUpdateManager::getAppcastUrl() {
#ifdef RELEASE_BUILD
return APPCAST_BASE_URL "release.xml";
#else
return APPCAST_BASE_URL "beta.xml";
#endif
}
#endif

View file

@ -1,48 +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 BACKENDS_UPDATES_SPARKLE_UPDATE_H
#define BACKENDS_UPDATES_SPARKLE_UPDATE_H
#include "common/scummsys.h"
#include "common/str.h"
#include "common/updates.h"
#if defined(USE_SPARKLE)
class SparkleUpdateManager : public Common::UpdateManager {
public:
/**
* Gets the appcast url.
*
* Beta/RC versions and releases might have a different appcast url.
* This function takes care of checking which version of ScummVM is running
* and return the url to the proper appcast.
*
* @return the appcast url.
*/
Common::String getAppcastUrl();
};
#endif
#endif // BACKENDS_UPDATES_SPARKLE_UPDATE_H

4
configure vendored
View file

@ -144,7 +144,7 @@ _opengl=auto
_opengles=auto _opengles=auto
_readline=auto _readline=auto
_taskbar=yes _taskbar=yes
_updates=yes _updates=no
_libunity=auto _libunity=auto
# Default option behaviour yes/no # Default option behaviour yes/no
_debug_build=auto _debug_build=auto
@ -775,7 +775,7 @@ Optional Features:
--disable-hq-scalers exclude HQ2x and HQ3x scalers --disable-hq-scalers exclude HQ2x and HQ3x scalers
--disable-translation don't build support for translated messages --disable-translation don't build support for translated messages
--disable-taskbar don't build support for taskbar and launcher integration --disable-taskbar don't build support for taskbar and launcher integration
--disable-updates don't build support for updates --enable-updates build support for updates
--enable-text-console use text console instead of graphical console --enable-text-console use text console instead of graphical console
--enable-verbose-build enable regular echoing of commands during build --enable-verbose-build enable regular echoing of commands during build
process process