Skip to main content

Check Application version | iOS | Swift

Show the alert within application for update the application.

func checkApplicationVersion(){
        let urlString = String(format: "",AppleAppID)
        let url = NSURL(string: urlString)
        let urlRequest = NSURLRequest(URL: url!)
        NSURLConnection.sendAsynchronousRequest(urlRequest, queue: NSOperationQueue.mainQueue()) { (response, data, error) -> Void in
            if (error == nil)
                do {
                    let appMetadataDictionary : NSDictionary = try NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.MutableContainers) as! NSDictionary
                    let resultsArray : NSArray = appMetadataDictionary.objectForKey("results") as! NSArray
                    let resultsDic : NSDictionary = resultsArray.firstObject as! NSDictionary

                    let iTunesVersion : String = resultsDic.objectForKey("version") as! String
                    let appVersionString : String = NSBundle.mainBundle().objectForInfoDictionaryKey("CFBundleShortVersionString") as! String
                    if( != NSComparisonResult.OrderedSame// new version exists
                        let message = String(format:"New version %@ available. Update required.",iTunesVersion)
                        let alert = UIAlertController(title: KEY_AppAlertTitle, message: message, preferredStyle: UIAlertControllerStyle.Alert)
                        alert.addAction(UIAlertAction(title: "Update", style: .Default, handler: { (action) -> Void in
                            let iTunesLink : String = String(format:"itms://",AppleAppID)
                            UIApplication.sharedApplication().openURL(NSURL(string: iTunesLink)!)
                        alert.addAction(UIAlertAction(title: "Cancel", style: .Cancel, handler: nil))
                        self.window?.rootViewController?.presentViewController(alert, animated: true, completion: nil)
                } catch let error as NSError {
                    print("error while lookup:- \(error)")
                    print("error occurred communicating with iTunes:- \(error)")



Popular posts from this blog

Play youtube video in iOS app

Youtube video can be played in iOS app using webview. MPMoviePlayerController is not able to open youtube video automatically. Integrate the below script to show thumbnail, clicking on it the video will play in full screen.

NSString *url = @""; NSString* embedHTML = @"\     <html><head>\     <style type=\"text/css\">\     body {\     background-color: transparent;\     color: white;\     }\     </style>\     </head><body style=\"margin:0\">\     <iframe id=\"yt\" src=\"%@\" type=\"application/x-shockwave-flash\" \     width=\"%0.0f\" height=\"%0.0f\" frameborder=\"0\" feature=player_detailpage allowfullscreen></iframe>\     </body></html>"; NSString* html = [NSStringstringWithFormat:embedHTML, url, self.view.frame.size.width, 200.0];
    [webviewloadHTMLString:html baseURL:nil];


Disabling print for Production In Swift Project

You'll need to set up a compiler flag to use the Swift preprocessor - go to the Swift Compiler - Custom Flags section of Build Settings to set up a -D DEBUG flag:

Then in your code you can define a DLog() function and only print your message if the DEBUG flag is set:
func DLog(message: String, function: String = __FUNCTION__) { #if DEBUG     println("\(function): \(message)") #endif }

Return multiple values from a function in objective C

We can return tuples in swift as follows:-

func getData()->(Int,Int,Int){//...code herereturn( hour, minute, second)}You can't do that in objective-c. Best option is using parameters by reference. Something like this.