2017-07-19 2 views
0

Salut tous J'ai récemment migré mon application iOS vers Swift 3.1 (Xcode 8.3.3). J'ai compris la plupart des problèmes par moi-même, mais un dernier bug me hante toujours. Eh bien, pour couper l'histoire courte, je bibliothèque Alamofire pour faire appel à webservices et utilisé Dispatch Sync dans quelques méthodes comme suit:Swift 3.1 Migration Dispatch.main.async référence ambiguë au membre 'async (execute :)'

class func createVideoActivity(_ type: Int, permission: Int, message: String, video: URL, progressview:UIProgressView , completion: @escaping (_ type: ResponseType , _ response : Int, _ message: String) -> Void) { 

     let user_id = CFunctions.getSession("id") 

     var serviceURL = baseURL + "&task=createActivity&user_id=\(user_id)&type=\(type)&permission=\(permission)" 

     serviceURL = serviceURL.addingPercentEncoding(withAllowedCharacters: CharacterSet.urlQueryAllowed)! 
     let url = URL(string: serviceURL) 
     let authHeader = ["":""] 

     let mimetype = "video/mov" 

     var movieData: Data? 
     do { 
      movieData = try Data(contentsOf: URL(fileURLWithPath: (video.relativePath)), options: NSData.ReadingOptions.alwaysMapped) 
     } catch _ { 
      movieData = nil 
      return 
     } 
     let filename = "upload.mov" 

     upload(
      multipartFormData:{ multipartFormData in 
       multipartFormData.append(movieData!, withName: "filedata",fileName: filename,mimeType: mimetype) 
       multipartFormData.append(message.data(using: String.Encoding.utf8)!, withName: "message") 
      }, 
      to: url!, 
      headers: authHeader, 
      encodingCompletion: 
      { 
       encodingResult in 
       switch encodingResult { 
       case .success(let uploads, _, _): 

        .uploadProgress { bytesWritten, totalBytesWritten, totalBytesExpectedToWrite in 

         DispatchQueue.main.async { 
          let percent = (Float(totalBytesWritten)/Float(totalBytesExpectedToWrite)) 
          print(percent) 
          progressview.setProgress(percent, animated: true) 
         } 

        } 
        uploads.validate() 
        uploads.responseJSON { serverResponse in 

         switch serverResponse.result { 

         case .success(let JSON): 

          debugPrint(JSON) 

          if (JSON as AnyObject).value(forKey: "status") as! Int == 1 { 
           completion(ResponseType.kresponseTypeSuccess,(JSON as AnyObject).value(forKey: "status") as! Int, (JSON as AnyObject).value(forKey: "response") as? String ?? "") 
          } else { 
           completion(ResponseType.kresponseTypeSuccess,(JSON as AnyObject).value(forKey: "status") as! Int, (JSON as AnyObject).value(forKey: "response") as? String ?? "") 


          } 

         case .failure(let error): 

          let dataString = String(data: serverResponse.data!, encoding: String.Encoding.utf8) 
          print("createVideoActivity Request failed with error: \(String(describing: dataString))") 
          completion(ResponseType.kResponseTypeFail, error as! Int, "Service failed") 

         } 

        } 
       case .failure(let encodingError): 
        print(encodingError) 
       } 
      } 
     ) // upload - end 
    } 

Je reçois « Ambigu référence à un membre 'async (exécuter :) » erreur sur la ligne Dispatch.main.sync. Pouvez-vous savoir ce qui se passe?

+0

Avez-vous essayé ceci: DispatchQueue.main.async (exécution: {() - > Annuler dans // votre code ici}) – u84six

+0

oui u84six déjà fait cela, n'a pas fonctionné. Bien que le problème soit résolu et je publie une réponse ci-dessous dans un instant. – Ali

Répondre

1

La question n'a pas été avec DispatchQueue.main.async mais avec la syntaxe Uploadprogress de Alamofire, il remplacé par le bloc suivant et problème résolu obtenu:

uploads.uploadProgress { (progress: Progress) in 
     DispatchQueue.main.async { 
       progressview.setProgress(progress.fractionCompleted, animated: true) 
     } 
}