2017-12-18 13 views
1

Googleのgithubを使用してテストアプリケーションを作成しましたが、いくつかの変更が加えられました(ファイアストアで使用されるキーとフィルターの数が少ない)。firestoreで新しいキーを追加するとアプリケーションがクラッシュする

firestoreに新しいキーを追加したときにアプリがクラッシュする問題がありましたが、アプリは以前に追加された2つのキーで動作します。

クラッシュと表示エラーfatalError("error")にあります。なぜ2つのキーでアプリケーションが動作するのか理解できませんが、3番目のキー(ホール)を使用するとアプリケーションがクラッシュします。

何が問題なのですか?

それは私のコードです:

class ViewControllerTwo: UIViewController, UITableViewDelegate, UITableViewDataSource { 

    @IBOutlet var tableView: UITableView! 

    private var sweets: [Sweet] = [] 
    private var document: [DocumentSnapshot] = [] 

    fileprivate var query: Query? { 
     didSet { 
      if let listener = listener { 
       listener.remove() 
      } 
     } 
    } 

    private var listener: FIRListenerRegistration? 

    fileprivate func observeQuery() { 

     guard let query = query else { return } 

     stopObserving() 

     listener = query.addSnapshotListener { [unowned self] (snapshot, error) in 

      guard let snapshot = snapshot else { 

       print("Error fetching snapshot results: \(error!)") 

       return 

      } 

      let models = snapshot.documents.map { (document) -> Sweet in 

       if let model = Sweet(dictionary: document.data()) { 

        return model 

       } else { 

        fatalError("error") 

       } 

      } 

      self.sweets = models 

      self.document = snapshot.documents 

      self.tableView.reloadData() 

     } 

    } 

    @IBAction func filterButton(_ sender: Any) { 
     present(filters.navigationController, animated: true, completion: nil)  
    } 

    lazy private var filters: (navigationController: UINavigationController, filtersController: FilterViewController) = { 
     return FilterViewController.fromStoryboard(delegate: self) 
    }() 

    fileprivate func stopObserving() { 
     listener?.remove() 
    } 

    fileprivate func baseQuery() -> Query { 
     return Firestore.firestore().collection("sweets").limit(to: 50)  
    } 

    override func viewDidLoad() { 
     super.viewDidLoad() 

     query = baseQuery()  
    } 

    override func viewWillAppear(_ animated: Bool) { 
     super.viewWillAppear(true) 

     observeQuery() 
    } 

    override func viewWillDisappear(_ animated: Bool) { 
     super.viewWillDisappear(true) 

     stopObserving()  
    } 

    deinit { 
     listener?.remove()  
    } 

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 

     return sweets.count 
    } 

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
     let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! ViewControllerCell 

     let sweet = sweets[indexPath.row] 

     cell.studioNameLabel.text = sweet.name 
     cell.studioAddressLabel.text = sweet.content 
     cell.hallNameLabel.text = sweet.hall 

     return cell 

    } 

} 

extension ViewControllerTwo: FiltersViewControllerDelegate { 

    func query(withCategory title: String?) -> Query { 

     var filtered = baseQuery() 

     if let title = title, !title.isEmpty { 
      filtered = filtered.whereField("title", isEqualTo: title) 
     } 

     return filtered 
    } 

    func controller(_ controller: FilterViewController, didSelectCategory title: String?) { 

     let filtered = query(withCategory: title) 

     self.query = filtered 
     observeQuery() 

    } 
} 

class ViewControllerCell: UITableViewCell { 

    @IBOutlet weak var studioNameLabel: UILabel! 
    @IBOutlet weak var studioAddressLabel: UILabel! 
    @IBOutlet weak var hallNameLabel: UILabel! 

} 

そして、私の構造体:

protocol DocumentSerializable { 
    init?(dictionary:[String:Any]) 
} 
struct Sweet { 
    var name:String 
    var content:String 
    var hall:String 
    var dictionary:[String:Any] { 
     return [ 
      "name": name, 
      "content" : content, 
      "hall" : hall 
     ] 
    } 
} 
extension Sweet : DocumentSerializable { 

    static let title = [ 
     "one", 
     "two", 
     "three", 
     "four" 
    ] 
    init?(dictionary: [String : Any]) { 
     guard let name = dictionary["name"] as? String, 
      let content = dictionary["content"] as? String, 
      let hall = dictionary["hall"] as? String else { return nil } 

     self.init(name: name, content: content, hall: hall) 
    } 
} 

のGoogleドライブでの私のプロジェクトは

google drive

google service info.plist

+0

'Sweet(dictionary:document.data())'を試して、 'nil'かどうかを確認してください。 –

+0

@DharmeshKheniは' fatalError() 'にありますか? – Dima

+0

上記の 'if let model = Sweet(dictionary:document.data())' –

答えて

0

既存の構造に新しい鍵を追加するだけで、アプリケーションを再インストールする必要があります。

構造体実装の前に、必要なキーを決める必要があります。または、将来新しいキーを追加すると、アプリケーションを再インストールできます。