Commit 00e7882f authored by Felix Paul Kühne's avatar Felix Paul Kühne

* retrieve the release notes and display them

    - they are temporarily stored in ~/Library/Caches/vlc_releasenote_temp.txt
    - Please shout if this location isn't okay for this purpose.
    - the file is automatically removed after displaying its content.
* show the binary's size in MB instead of bytes
parent bddb56ff
...@@ -34,11 +34,11 @@ ...@@ -34,11 +34,11 @@
IBOutlet id o_fld_status; IBOutlet id o_fld_status;
IBOutlet id o_update_window; IBOutlet id o_update_window;
IBOutlet id o_bar_checking; IBOutlet id o_bar_checking;
IBOutlet id o_lbl_checkForUpdate;
NSString * o_hashOfOurBinary; NSString * o_hashOfOurBinary;
NSString * o_urlOfBinary; NSString * o_urlOfBinary;
update_t * p_u; update_t * p_u;
intf_thread_t * p_intf;
} }
- (IBAction)download:(id)sender; - (IBAction)download:(id)sender;
......
...@@ -61,6 +61,9 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -61,6 +61,9 @@ static VLCUpdate *_o_sharedInstance = nil;
- (void)awakeFromNib - (void)awakeFromNib
{ {
/* get up */
p_intf = VLCIntf;
/* clean the interface */ /* clean the interface */
[o_fld_releaseNote setString: @""]; [o_fld_releaseNote setString: @""];
...@@ -73,13 +76,14 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -73,13 +76,14 @@ static VLCUpdate *_o_sharedInstance = nil;
[o_hashOfOurBinary release]; [o_hashOfOurBinary release];
if( o_urlOfBinary ) if( o_urlOfBinary )
[o_urlOfBinary release]; [o_urlOfBinary release];
[super dealloc]; [super dealloc];
} }
- (void)initStrings - (void)initStrings
{ {
/* translate strings to the user's language */ /* translate strings to the user's language */
[o_update_window setTitle: _NS("Check for update")]; [o_update_window setTitle: _NS("Check for Update")];
[o_btn_DownloadNow setTitle: _NS("Download now")]; [o_btn_DownloadNow setTitle: _NS("Download now")];
[o_btn_okay setTitle: _NS("OK")]; [o_btn_okay setTitle: _NS("OK")];
} }
...@@ -98,7 +102,6 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -98,7 +102,6 @@ static VLCUpdate *_o_sharedInstance = nil;
[o_bar_checking startAnimation: self]; [o_bar_checking startAnimation: self];
[self checkForUpdate]; [self checkForUpdate];
[o_bar_checking stopAnimation: self]; [o_bar_checking stopAnimation: self];
[o_lbl_checkForUpdate setHidden: YES];
} }
- (IBAction)download:(id)sender - (IBAction)download:(id)sender
...@@ -137,11 +140,15 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -137,11 +140,15 @@ static VLCUpdate *_o_sharedInstance = nil;
- (void)checkForUpdate - (void)checkForUpdate
{ {
p_u = update_New( VLCIntf ); p_u = update_New( p_intf );
update_Check( p_u, VLC_FALSE ); update_Check( p_u, VLC_FALSE );
update_iterator_t *p_uit = update_iterator_New( p_u ); update_iterator_t *p_uit = update_iterator_New( p_u );
BOOL releaseChecked = NO; BOOL releaseChecked = NO;
int x = 0; int x = 0;
NSString * pathToReleaseNote;
pathToReleaseNote = [[NSString stringWithString: \
@"~/Library/Caches/vlc_releasenote_temp.txt"] \
stringByExpandingTildeInPath];
if( p_uit ) if( p_uit )
{ {
...@@ -161,16 +168,21 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -161,16 +168,21 @@ static VLCUpdate *_o_sharedInstance = nil;
[o_fld_releaseNote setString: \ [o_fld_releaseNote setString: \
[NSString stringWithUTF8String: \ [NSString stringWithUTF8String: \
(p_uit->file.psz_description)]]; (p_uit->file.psz_description)]];
/* download our release note
* We will read the temp file after this loop */
update_download( p_uit, (char *)[pathToReleaseNote UTF8String] );
} }
else if( p_uit->file.i_type == UPDATE_FILE_TYPE_BINARY ) else if( p_uit->file.i_type == UPDATE_FILE_TYPE_BINARY )
{ {
msg_Dbg( VLCIntf, "binary found, version = %s" \ msg_Dbg( p_intf, "binary found, version = %s" \
", hash=%s", p_uit->release.psz_version, \ ", hash=%s, size=%i", p_uit->release.psz_version, \
p_uit->file.psz_md5 ); p_uit->file.psz_md5, (int)((p_uit->file.l_size \
/ 1024) / 1024) );
[o_fld_currentVersionAndSize setStringValue: \ [o_fld_currentVersionAndSize setStringValue: \
[NSString stringWithFormat: \ [NSString stringWithFormat: \
@"The current release is %s (%i MB to download).", \ @"The current release is %s (%i MB to download).", \
p_uit->release.psz_version, p_uit->file.l_size]]; p_uit->release.psz_version, ((p_uit->file.l_size \
/ 1024) / 1024)]];
if( o_urlOfBinary ) if( o_urlOfBinary )
[o_urlOfBinary release]; [o_urlOfBinary release];
...@@ -194,9 +206,9 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -194,9 +206,9 @@ static VLCUpdate *_o_sharedInstance = nil;
[o_fld_status setStringValue: _NS("Your version of VLC " \ [o_fld_status setStringValue: _NS("Your version of VLC " \
"is outdated.")]; "is outdated.")];
[o_btn_DownloadNow setEnabled: YES]; [o_btn_DownloadNow setEnabled: YES];
msg_Dbg( VLCIntf, "this version of VLC is outdated" ); msg_Dbg( p_intf, "this version of VLC is outdated" );
/* put the mirror information */ /* put the mirror information */
msg_Dbg( VLCIntf, "used mirror: %s, %s [%s]", \ msg_Dbg( p_intf, "used mirror: %s, %s [%s]", \
p_uit->mirror.psz_name, p_uit->mirror.psz_location,\ p_uit->mirror.psz_name, p_uit->mirror.psz_location,\
p_uit->mirror.psz_type ); p_uit->mirror.psz_type );
/* make sure that we perform this check only once */ /* make sure that we perform this check only once */
...@@ -207,13 +219,45 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -207,13 +219,45 @@ static VLCUpdate *_o_sharedInstance = nil;
[o_fld_status setStringValue: _NS("Your version of VLC " \ [o_fld_status setStringValue: _NS("Your version of VLC " \
"is up-to-date.")]; "is up-to-date.")];
[o_btn_DownloadNow setEnabled: NO]; [o_btn_DownloadNow setEnabled: NO];
msg_Dbg( VLCIntf, "current version is up-to-date" ); msg_Dbg( p_intf, "current version is up-to-date" );
releaseChecked = YES; releaseChecked = YES;
} }
} }
x += 1; x += 1;
} }
update_iterator_Delete( p_uit ); update_iterator_Delete( p_uit );
/* wait for our download, since it is done by another thread
* this does usually take 300000 to 500000 ms */
int i = 0;
while( [[NSFileManager defaultManager] fileExistsAtPath: pathToReleaseNote] == NO )
{
msleep( 100000 );
i += 1;
if( i == 600 )
{
/* if this takes more than 1 min, exit */
msg_Warn( p_intf, "download took more than a minute, exiting" );
return;
}
}
msg_Dbg( p_intf, "waited %i ms for the release notes", (i * 100000) );
msleep( 500000 );
/* let's open our cached release note and display it
* we can't use NSString stringWithContentsOfFile:encoding:error:
* since it is Tiger only */
NSString * releaseNote = [[NSString alloc] initWithData: \
[NSData dataWithContentsOfFile: pathToReleaseNote] \
encoding: NSISOLatin1StringEncoding];
if( releaseNote )
[o_fld_releaseNote setString: releaseNote];
/* delete the file since it isn't needed anymore */
BOOL myBOOL = NO;
myBOOL = [[NSFileManager defaultManager] removeFileAtPath: \
pathToReleaseNote handler: nil];
} }
} }
...@@ -240,7 +284,7 @@ static VLCUpdate *_o_sharedInstance = nil; ...@@ -240,7 +284,7 @@ static VLCUpdate *_o_sharedInstance = nil;
}*/ }*/
/* delete the following afterwards */ /* delete the following afterwards */
msg_Dbg( VLCIntf, "url is %s, using default browser for download", \ msg_Dbg( p_intf, "url is %s, using default browser for download", \
[o_urlOfBinary UTF8String] ); [o_urlOfBinary UTF8String] );
NSURL * o_url = [NSURL URLWithString: o_urlOfBinary]; NSURL * o_url = [NSURL URLWithString: o_urlOfBinary];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment