OSDN Git Service

guard の書き方を統一した
[kcd/KCD.git] / KCD / Ship.swift
index 3fb0e90..8d30304 100644 (file)
@@ -65,11 +65,11 @@ final class Ship: KCManagedObject {
 }
 // swiftlint:eable variable_name
 
-fileprivate let shortSTypeNames: [String] = {
+private let shortSTypeNames: [String] = {
     
     guard let url = Bundle.main.url(forResource: "STypeShortName", withExtension: "plist"),
-        let array = NSArray(contentsOf: url) as? [String]
-        else {
+        let array = NSArray(contentsOf: url) as? [String] else {
+            
             print("Can not load STypeShortName.plist.")
             return []
     }
@@ -77,11 +77,11 @@ fileprivate let shortSTypeNames: [String] = {
     return array
 }()
 
-fileprivate let levelUpExps: [Int] = {
+private let levelUpExps: [Int] = {
     
     guard let url = Bundle.main.url(forResource: "LevelUpExp", withExtension: "plist"),
-        let array = NSArray(contentsOf: url) as? [Int]
-        else {
+        let array = NSArray(contentsOf: url) as? [Int] else {
+            
             print("Can not load LevelUpExp.plist.")
             return []
     }
@@ -95,18 +95,17 @@ extension Ship {
         
         return ["ship_id"]
     }
-    dynamic var name: String { return master_ship.name }
+    @objc dynamic var name: String { return master_ship.name }
     
     class func keyPathsForValuesAffectingShortTypeName() -> Set<String> {
         
         return ["ship_id"]
     }
-    dynamic var shortTypeName: String? {
+    @objc dynamic var shortTypeName: String? {
         
         let index = master_ship.stype.id - 1
         
-        guard case 0..<shortSTypeNames.count = index
-            else { return nil }
+        guard case 0..<shortSTypeNames.count = index else { return nil }
         
         return shortSTypeNames[index]
     }
@@ -115,10 +114,9 @@ extension Ship {
         
         return ["exp"]
     }
-    dynamic var next: NSNumber? {
+    @objc dynamic var next: NSNumber? {
         
-        guard case 0..<levelUpExps.count = lv
-            else { return nil }
+        guard case 0..<levelUpExps.count = lv else { return nil }
         
         if lv == 99 { return nil }
         
@@ -133,7 +131,7 @@ extension Ship {
         
         return ["nowhp", "maxph"]
     }
-    dynamic var status: Int {
+    @objc dynamic var status: Int {
         
         let stat = Double(nowhp) / Double(maxhp)
         
@@ -144,36 +142,15 @@ extension Ship {
         return 0
     }
     
-    class func keyPathsForValuesAffectingStatusColor() -> Set<String> {
-        
-        return ["status"]
-    }
-    dynamic var statusColor: NSColor {
-        
-        switch status {
-        case 0: return NSColor.controlTextColor
-        case 1: return NSColor.yellow
-        case 2: return NSColor.orange
-        case 3: return NSColor.red
-        default: fatalError("status is unknown value")
-        }
-    }
-    
-//    class func keyPathsForValuesAffectingConditionColor() -> Set<String> {
-//        return ["cond"]
-//    }
-    dynamic var conditionColor: NSColor { return NSColor.controlTextColor }
-    
     class func keyPathsForValuesAffectingPlanColor() -> Set<String> {
         
         return ["sally_area"]
     }
-    dynamic var planColor: NSColor {
+    @objc dynamic var planColor: NSColor {
         
         if !UserDefaults.standard[.showsPlanColor] { return NSColor.controlTextColor }
         
-        guard let sally = sally_area
-            else { return NSColor.controlTextColor }
+        guard let sally = sally_area else { return .controlTextColor }
         
         switch sally {
         case 1: return UserDefaults.standard[.plan01Color]
@@ -190,14 +167,14 @@ extension Ship {
 
 extension Ship {
     
-    dynamic var maxBull: Int { return master_ship.bull_max }
-    dynamic var maxFuel: Int { return master_ship.fuel_max }
+    @objc dynamic var maxBull: Int { return master_ship.bull_max }
+    @objc dynamic var maxFuel: Int { return master_ship.fuel_max }
     
     class func keyPathsForValuesAffectingIsMaxKaryoku() -> Set<String> {
         
         return ["karyoku_1", "kyouka_0"]
     }
-    dynamic var isMaxKaryoku: Bool {
+    @objc dynamic var isMaxKaryoku: Bool {
         
         let initial = master_ship.houg_0
         let max = karyoku_1
@@ -210,7 +187,7 @@ extension Ship {
         
         return ["raisou_1", "kyouka_1"]
     }
-    dynamic var isMaxRaisou: Bool {
+    @objc dynamic var isMaxRaisou: Bool {
         
         let initial = master_ship.raig_0
         let max = raisou_1
@@ -223,7 +200,7 @@ extension Ship {
         
         return ["taiku_1", "kyouka_2"]
     }
-    dynamic var isMaxTaiku: Bool {
+    @objc dynamic var isMaxTaiku: Bool {
         
         let initial = master_ship.tyku_0
         let max = taiku_1
@@ -236,7 +213,7 @@ extension Ship {
         
         return ["soukou_1", "kyouka_3"]
     }
-    dynamic var isMaxSoukou: Bool {
+    @objc dynamic var isMaxSoukou: Bool {
         
         let initial = master_ship.souk_0
         let max = soukou_1
@@ -249,7 +226,7 @@ extension Ship {
         
         return ["lucky_1", "kyouka_4"]
     }
-    dynamic var isMaxLucky: Bool {
+    @objc dynamic var isMaxLucky: Bool {
         
         let initial = master_ship.luck_0
         let max = lucky_1
@@ -262,13 +239,13 @@ extension Ship {
         
         return ["ship_id"]
     }
-    dynamic var upgradeLevel: Int { return master_ship.afterlv }
+    @objc dynamic var upgradeLevel: Int { return master_ship.afterlv }
     
     class func keyPathsForValuesAffectingUpgradeExp() -> Set<String> {
         
         return ["exp"]
     }
-    dynamic var upgradeExp: NSNumber? {
+    @objc dynamic var upgradeExp: NSNumber? {
         
         let upgradeLv = upgradeLevel
         
@@ -280,12 +257,11 @@ extension Ship {
         return upExp < 0 ? 0 : upExp as NSNumber
     }
     
-    dynamic var guardEscaped: Bool {
+    @objc dynamic var guardEscaped: Bool {
         
         let store = TemporaryDataStore.default
         
-        guard let _ = store.ensuredGuardEscaped(byShipId: id)
-            else { return false }
+        guard let _ = store.ensuredGuardEscaped(byShipId: id) else { return false }
         
         return true
     }
@@ -294,7 +270,7 @@ extension Ship {
         
         return ["nowhp"]
     }
-    dynamic var steelRequiredInRepair: Int {
+    @objc dynamic var steelRequiredInRepair: Int {
         
         return Int(Double(maxFuel) * 0.06 * Double(maxhp - nowhp))
     }
@@ -303,17 +279,15 @@ extension Ship {
         
         return ["nowhp"]
     }
-    dynamic var fuelRequiredInRepair: Int {
+    @objc dynamic var fuelRequiredInRepair: Int {
         
         return Int(Double(maxFuel) * 0.032 * Double(maxhp - nowhp))
     }
 }
 
-fileprivate let allPlaneTypes: [Int] = [6, 7, 8, 9, 10, 11, 25, 26, 41, 45, 56, 57, 58, 59]
-
 extension Ship {
     
-    func setItem(_ id: Int, for slot: Int) {
+    func setItem(_ id: Int, to slot: Int) {
         
         switch slot {
         case 0: slot_0 = id
@@ -349,7 +323,7 @@ extension Ship {
         }
     }
     
-    private func slotItemMax(_ index: Int) -> Int {
+    func slotItemMax(_ index: Int) -> Int {
         
         switch index {
         case 0: return master_ship.maxeq_0
@@ -361,12 +335,12 @@ extension Ship {
         }
     }
     
-    private func slotItem(_ index: Int) -> SlotItem? {
+    func slotItem(_ index: Int) -> SlotItem? {
         
         return ServerDataStore.default.slotItem(by: slotItemId(index))
     }
     
-    dynamic var totalEquipment: Int {
+    @objc dynamic var totalEquipment: Int {
         
         return (0...4).map(slotItemMax).reduce(0, +)
     }
@@ -376,128 +350,9 @@ extension Ship {
         return ["slot_0", "slot_1", "slot_2", "slot_3", "slot_4",
                    "onslot_0", "onslot_1", "onslot_2", "onslot_3", "onslot_4"]
     }
-    dynamic var seiku: Int {
+    @objc dynamic var seiku: Int {
         
         return SeikuCalclator(ship: self).seiku
     }
     
-    class func keyPathsForValuesAffectingTotalSeiku() -> Set<String> {
-        
-        return ["seiku"]
-    }
-    dynamic var totalSeiku: Int {
-        
-        return SeikuCalclator(ship: self).totalSeiku
-    }
-    
-    var totalDrums: Int {
-        
-        return (0...4).flatMap(slotItem).filter { $0.slotitem_id == 75 }.count
-    }
-    
-    // MARK: - Plane count strings
-    private enum PlaneState {
-        
-        case cannotEquip
-        case notEquip(Int)
-        case equiped(Int, Int)
-    }
-    
-    private func planState(_ index: Int) -> PlaneState {
-        
-        let itemId = slotItemId(index)
-        let maxCount = slotItemMax(index)
-        
-        if maxCount == 0 { return .cannotEquip }
-        if itemId == -1 { return .notEquip(maxCount) }
-        
-        if let item = slotItem(index),
-            allPlaneTypes.contains(item.master_slotItem.type_2) {
-            
-            return .equiped(slotItemCount(index), maxCount)
-        }
-        
-        return .notEquip(maxCount)
-    }
-    
-    private func planeString(_ index: Int) -> String? {
-        
-        switch planState(index) {
-        case .cannotEquip:
-            return nil
-        case .notEquip(let max):
-            return "\(max)"
-        case .equiped(let count, let max):
-            return "\(count)/\(max)"
-        }
-    }
-    
-    class func keyPathsForValuesAffectingPlaneString0() -> Set<String> {
-        
-        return ["onslot_0", "master_ship.maxeq_0", "equippedItem"]
-    }
-    dynamic var planeString0: String? { return planeString(0) }
-    
-    class func keyPathsForValuesAffectingPlaneString1() -> Set<String> {
-        
-        return ["onslot_1", "master_ship.maxeq_1", "equippedItem"]
-    }
-    dynamic var planeString1: String? { return planeString(1) }
-    
-    class func keyPathsForValuesAffectingPlaneString2() -> Set<String> {
-        
-        return ["onslot_2", "master_ship.maxeq_2", "equippedItem"]
-    }
-    dynamic var planeString2: String? { return planeString(2) }
-    
-    class func keyPathsForValuesAffectingPlaneString3() -> Set<String> {
-        
-        return ["onslot_3", "master_ship.maxeq_3", "equippedItem"]
-    }
-    dynamic var planeString3: String? { return planeString(3) }
-    
-    class func keyPathsForValuesAffectingPlaneString4() -> Set<String> {
-        
-        return ["onslot_4", "master_ship.maxeq_4", "equippedItem"]
-    }
-    dynamic var planeString4: String? { return planeString(4) }
-    
-    // MARK: - Plane count string color
-    private func planeStringColor(_ index: Int) -> NSColor {
-        switch planState(index) {
-        case .cannotEquip: return NSColor.controlTextColor
-        case .notEquip: return NSColor.disabledControlTextColor
-        case .equiped: return NSColor.controlTextColor
-        }
-    }
-    
-    class func keyPathsForValuesAffectingPlaneString0Color() -> Set<String> {
-        
-        return ["onslot_0", "master_ship.maxeq_0", "equippedItem"]
-    }
-    dynamic var planeString0Color: NSColor { return planeStringColor(0) }
-    
-    class func keyPathsForValuesAffectingPlaneString1Color() -> Set<String> {
-        
-        return ["onslot_1", "master_ship.maxeq_1", "equippedItem"]
-    }
-    dynamic var planeString1Color: NSColor { return planeStringColor(1) }
-    
-    class func keyPathsForValuesAffectingPlaneString2Color() -> Set<String> {
-        
-        return ["onslot_2", "master_ship.maxeq_2", "equippedItem"]
-    }
-    dynamic var planeString2Color: NSColor { return planeStringColor(2) }
-    
-    class func keyPathsForValuesAffectingPlaneString3Color() -> Set<String> {
-        
-        return ["onslot_3", "master_ship.maxeq_3", "equippedItem"]
-    }
-    dynamic var planeString3Color: NSColor { return planeStringColor(3) }
-    
-    class func keyPathsForValuesAffectingPlaneString4Color() -> Set<String> {
-        
-        return ["onslot_4", "master_ship.maxeq_4", "equippedItem"]
-    }
-    dynamic var planeString4Color: NSColor { return planeStringColor(4) }
 }