* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111, USA.
*****************************************************************************/
+#import "update.h"
+
#ifdef UPDATE_CHECK
+#include <assert.h>
+
/*****************************************************************************
* Preamble
*****************************************************************************/
-#import "update.h"
static NSString * kPrefUpdateOnStartup = @"UpdateOnStartup";
static NSString * kPrefUpdateLastTimeChecked = @"UpdateLastTimeChecked";
[self dealloc];
} else {
_o_sharedInstance = [super init];
- b_checked = VLC_FALSE;
+ b_checked = false;
/* clean the interface */
[o_fld_releaseNote setString: @""];
{
[o_bar_checking startAnimation: self];
[self checkForUpdate];
- b_checked = VLC_TRUE;
+ b_checked = true;
[o_bar_checking stopAnimation: self];
}
}
[saveFilePanel setRequiredFileType: @"dmg"];
[saveFilePanel setCanSelectHiddenExtension: YES];
[saveFilePanel setCanCreateDirectories: YES];
+ update_release_t *p_release = update_GetRelease( p_u );
+ assert( p_release );
[saveFilePanel beginSheetForDirectory:nil file:
- [[[NSString stringWithUTF8String: p_u->release.psz_url] componentsSeparatedByString:@"/"] lastObject]
+ [[[NSString stringWithUTF8String: p_release->psz_url] componentsSeparatedByString:@"/"] lastObject]
modalForWindow: o_update_window
modalDelegate:self
didEndSelector:sel
- (void)setUpToDate:(BOOL)uptodate
{
- NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
-
if( uptodate )
{
[o_fld_releaseNote setString: @""];
}
else
{
- [o_fld_releaseNote setString: [NSString stringWithUTF8String: (p_u->release.psz_desc ? p_u->release.psz_desc : "" )]];
+ update_release_t *p_release = update_GetRelease( p_u );
+ [o_fld_releaseNote setString: [NSString stringWithUTF8String: (p_release->psz_desc ? p_release->psz_desc : "" )]];
[o_fld_status setStringValue: _NS("This version of VLC is outdated.")];
[o_fld_currentVersion setStringValue: [NSString stringWithFormat:
- _NS("The current release is %d.%d.%d%c."), p_u->release.i_major,
- p_u->release.i_minor, p_u->release.i_revision, p_u->release.extra]];
+ _NS("The current release is %d.%d.%d%c."), p_release->i_major,
+ p_release->i_minor, p_release->i_revision, p_release->extra]];
[o_btn_DownloadNow setEnabled: YES];
/* Make sure the update window is showed in case we have something */
[o_update_window center];
[o_update_window displayIfNeeded];
[o_update_window makeKeyAndOrderFront: self];
}
-
- [pool release];
}
-static void updateCallback( void * p_data, vlc_bool_t b_success )
+static void updateCallback( void * p_data, bool b_success )
{
- [(id)p_data setUpToDate: !b_success || update_CompareReleaseToCurrent( ((VLCUpdate*)p_data)->p_u ) == UpdateReleaseStatusNewer ];
+ VLCUpdate * update = p_data;
+ NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
+ NSNumber * state = [NSNumber numberWithBool:!b_success || !update_NeedUpgrade( update->p_u )];
+ [update performSelectorOnMainThread:@selector(setUpToDate:) withObject:state waitUntilDone:YES];
+ [pool release];
}
- (void)checkForUpdate
return;
update_Check( p_u, updateCallback, self );
+ NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
[[NSUserDefaults standardUserDefaults] setObject: [NSDate date] forKey: kPrefUpdateLastTimeChecked];
+ [pool release];
}
- (void)performDownload:(NSString *)path