From 07032ed4e2c6dbe951bbf5d0a45215d29070ae70 Mon Sep 17 00:00:00 2001 From: Charley <2555085@qq.com> Date: Wed, 12 Jun 2019 21:19:45 +0800 Subject: [PATCH 1/2] update swift5 --- .gitmodules | 3 -- Vendor/SQLite.swift | 2 +- YTKKeyValueStore.xcodeproj/project.pbxproj | 31 +++++++++++++++---- .../xcshareddata/IDEWorkspaceChecks.plist | 8 +++++ .../xcschemes/YTKKeyValueStore.xcscheme | 2 +- YTKKeyValueStore/Info.plist | 2 +- YTKKeyValueStore/YTKConfig.swift | 12 +++---- YTKKeyValueStore/YTKKeyValueStore.swift | 12 +++---- YTKKeyValueStore/YTKSetter.swift | 2 +- YTKKeyValueStore/YTKTable.swift | 20 ++++++------ YTKKeyValueStore_Swift.podspec | 6 ++-- 11 files changed, 62 insertions(+), 38 deletions(-) delete mode 100644 .gitmodules create mode 100644 YTKKeyValueStore.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist diff --git a/.gitmodules b/.gitmodules deleted file mode 100644 index e1692f3..0000000 --- a/.gitmodules +++ /dev/null @@ -1,3 +0,0 @@ -[submodule "Vendor/SQLite.swift"] - path = Vendor/SQLite.swift - url = https://github.com/stephencelis/SQLite.swift.git diff --git a/Vendor/SQLite.swift b/Vendor/SQLite.swift index 5e771a1..691fc89 160000 --- a/Vendor/SQLite.swift +++ b/Vendor/SQLite.swift @@ -1 +1 @@ -Subproject commit 5e771a1af67f52b5154cc5e9ee3f0f5f4a3e07a5 +Subproject commit 691fc89e75873d417d700920e79a63cf210d1d71 diff --git a/YTKKeyValueStore.xcodeproj/project.pbxproj b/YTKKeyValueStore.xcodeproj/project.pbxproj index 674d694..a83ad58 100644 --- a/YTKKeyValueStore.xcodeproj/project.pbxproj +++ b/YTKKeyValueStore.xcodeproj/project.pbxproj @@ -262,7 +262,7 @@ isa = PBXProject; attributes = { LastSwiftUpdateCheck = 0700; - LastUpgradeCheck = 0830; + LastUpgradeCheck = 1020; ORGANIZATIONNAME = sgxiang; TargetAttributes = { 1A5891A41A8B4F6200155614 = { @@ -277,10 +277,11 @@ }; buildConfigurationList = 1A58919F1A8B4F6200155614 /* Build configuration list for PBXProject "YTKKeyValueStore" */; compatibilityVersion = "Xcode 3.2"; - developmentRegion = English; + developmentRegion = en; hasScannedForEncodings = 0; knownRegions = ( en, + Base, ); mainGroup = 1A58919B1A8B4F6200155614; productRefGroup = 1A5891A61A8B4F6200155614 /* Products */; @@ -410,14 +411,22 @@ CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; CLANG_WARN_INFINITE_RECURSION = YES; CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; @@ -461,14 +470,22 @@ CLANG_CXX_LIBRARY = "libc++"; CLANG_ENABLE_MODULES = YES; CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; CLANG_WARN_EMPTY_BODY = YES; CLANG_WARN_ENUM_CONVERSION = YES; CLANG_WARN_INFINITE_RECURSION = YES; CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; CLANG_WARN_SUSPICIOUS_MOVE = YES; CLANG_WARN_UNREACHABLE_CODE = YES; CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; @@ -515,7 +532,7 @@ PRODUCT_NAME = "$(TARGET_NAME)"; SKIP_INSTALL = YES; SWIFT_OPTIMIZATION_LEVEL = "-Onone"; - SWIFT_VERSION = 3.0; + SWIFT_VERSION = 5.0; }; name = Debug; }; @@ -536,7 +553,7 @@ PRODUCT_BUNDLE_IDENTIFIER = "com.sgxiang.$(PRODUCT_NAME:rfc1034identifier)"; PRODUCT_NAME = "$(TARGET_NAME)"; SKIP_INSTALL = YES; - SWIFT_VERSION = 3.0; + SWIFT_VERSION = 5.0; }; name = Release; }; @@ -552,10 +569,11 @@ "$(inherited)", ); INFOPLIST_FILE = YTKKeyValueStoreTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 9.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; PRODUCT_BUNDLE_IDENTIFIER = "com.sgxiang.$(PRODUCT_NAME:rfc1034identifier)"; PRODUCT_NAME = "$(TARGET_NAME)"; - SWIFT_VERSION = 3.0; + SWIFT_VERSION = 5.0; }; name = Debug; }; @@ -567,10 +585,11 @@ "$(inherited)", ); INFOPLIST_FILE = YTKKeyValueStoreTests/Info.plist; + IPHONEOS_DEPLOYMENT_TARGET = 9.0; LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks"; PRODUCT_BUNDLE_IDENTIFIER = "com.sgxiang.$(PRODUCT_NAME:rfc1034identifier)"; PRODUCT_NAME = "$(TARGET_NAME)"; - SWIFT_VERSION = 3.0; + SWIFT_VERSION = 5.0; }; name = Release; }; diff --git a/YTKKeyValueStore.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/YTKKeyValueStore.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000..18d9810 --- /dev/null +++ b/YTKKeyValueStore.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/YTKKeyValueStore.xcodeproj/xcshareddata/xcschemes/YTKKeyValueStore.xcscheme b/YTKKeyValueStore.xcodeproj/xcshareddata/xcschemes/YTKKeyValueStore.xcscheme index 8283e3d..d070698 100644 --- a/YTKKeyValueStore.xcodeproj/xcshareddata/xcschemes/YTKKeyValueStore.xcscheme +++ b/YTKKeyValueStore.xcodeproj/xcshareddata/xcschemes/YTKKeyValueStore.xcscheme @@ -1,6 +1,6 @@ CFBundlePackageType FMWK CFBundleShortVersionString - 0.4.2 + 0.5.0 CFBundleSignature ???? CFBundleVersion diff --git a/YTKKeyValueStore/YTKConfig.swift b/YTKKeyValueStore/YTKConfig.swift index 3ac512e..85150fa 100644 --- a/YTKKeyValueStore/YTKConfig.swift +++ b/YTKKeyValueStore/YTKConfig.swift @@ -9,12 +9,12 @@ import UIKit import SQLite -internal let YTKDEBUG = true +public let YTKDEBUG = true -internal let PATH_OF_DOCUMENT : String = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0] +public let PATH_OF_DOCUMENT : String = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0] -internal let DEFAULT_DB_NAME = "database_swift.sqlite3" +public let DEFAULT_DB_NAME = "database_swift.sqlite3" -internal let ID = Expression("id") -internal let JSON = Expression("json") -internal let CREATEDTIME = Expression("createdTime") +public let ID = Expression("id") +public let JSON = Expression("json") +public let CREATEDTIME = Expression("createdTime") diff --git a/YTKKeyValueStore/YTKKeyValueStore.swift b/YTKKeyValueStore/YTKKeyValueStore.swift index 74da9de..ae43692 100755 --- a/YTKKeyValueStore/YTKKeyValueStore.swift +++ b/YTKKeyValueStore/YTKKeyValueStore.swift @@ -13,13 +13,13 @@ public class YTKKeyValueStore{ private var db : Connection? - private init(dbPath : String!) { + private init(dbPath : String) { db = try! Connection(dbPath) } - convenience public init(_ dbName : String! = DEFAULT_DB_NAME , path : String! = PATH_OF_DOCUMENT) throws{ + convenience public init(_ dbName : String = DEFAULT_DB_NAME , path : String = PATH_OF_DOCUMENT) throws{ - self.init(dbPath:"\(path!)/\(dbName!)") + self.init(dbPath:"\(path)/\(dbName)") guard db != nil else{ throw YTKError.dbConnectionError @@ -27,11 +27,11 @@ public class YTKKeyValueStore{ } - public subscript (tableName : String!) -> YTKTable{ + public subscript (tableName : String) -> YTKTable{ return YTKTable(db: self.db, tableName) } - public func createTable(tableName:String!) throws{ + public func createTable(tableName:String) throws{ guard YTKTable.checkTableName(tableName) else{ throw YTKError.nameFormatError @@ -50,7 +50,7 @@ public class YTKKeyValueStore{ } - public func dropTable(tableName:String!) throws{ + public func dropTable(tableName:String) throws{ guard YTKTable.checkTableName(tableName) else{ throw YTKError.nameFormatError diff --git a/YTKKeyValueStore/YTKSetter.swift b/YTKKeyValueStore/YTKSetter.swift index 916c40e..42f55bb 100644 --- a/YTKKeyValueStore/YTKSetter.swift +++ b/YTKKeyValueStore/YTKSetter.swift @@ -55,6 +55,6 @@ precedencegroup MultiplicationPrecedence { higherThan: AdditionPrecedence } -public func <- (objectId: String!, object: Any!) -> YTKSetter{ +public func <- (objectId: String!, object: Any) -> YTKSetter{ return YTKSetter(objectId , object) } diff --git a/YTKKeyValueStore/YTKTable.swift b/YTKKeyValueStore/YTKTable.swift index 201deaa..b28590b 100755 --- a/YTKKeyValueStore/YTKTable.swift +++ b/YTKKeyValueStore/YTKTable.swift @@ -30,7 +30,7 @@ public struct YTKTable{ internal let db : Connection? internal let tableHandle : Table? - internal init(db : Connection?, _ tableName : String!){ + internal init(db : Connection?, _ tableName : String){ if YTKTable.checkTableName(tableName){ self.db = db self.name = tableName @@ -42,7 +42,7 @@ public struct YTKTable{ } } - internal static func checkTableName(_ tableName : String!)->Bool{ + internal static func checkTableName(_ tableName : String)->Bool{ if tableName.contains(" "){ print("table name : \(tableName) format error") return false @@ -74,7 +74,7 @@ public struct YTKTable{ } - public func deletePreLike(_ objectId : String!) throws -> Int{ + public func deletePreLike(_ objectId : String) throws -> Int{ do{ let changes = try db?.run(tableHandle!.filter(ID.like("\(objectId)%")).delete()) ?? 0 @@ -89,7 +89,7 @@ public struct YTKTable{ case string,number,object } - fileprivate static func valueWithType(_ object : AnyObject!)->YTKKeyValueType{ + fileprivate static func valueWithType(_ object : AnyObject)->YTKKeyValueType{ if object is String{ return .string }else if (object as? NSNumber) != nil{ @@ -111,14 +111,14 @@ public struct YTKTable{ if filter.makeIterator().next() == nil{ do{ try db?.run( tableHandle!.insert(ID <- set.objectId,JSON <- jsonString,CREATEDTIME <- Date()) ) - print("[insert] id : \(set.objectId) jsonString : \(set.jsonString!)") + print("[insert] id : \(set.objectId!) jsonString : \(set.jsonString!)") }catch let error{ throw error } }else{ do{ try db?.run(query.update(JSON <- jsonString,CREATEDTIME <- Date())) - print("[update] id : \(set.objectId) jsonString : \(set.jsonString!)") + print("[update] id : \(set.objectId!) jsonString : \(set.jsonString!)") }catch let error{ throw error } @@ -130,7 +130,7 @@ public struct YTKTable{ } - public func get( _ objectId : String! ) throws -> YTKObject?{ + public func get( _ objectId : String ) throws -> YTKObject?{ do{ if let item = try self.getItem(objectId){ return item.itemObject @@ -141,14 +141,14 @@ public struct YTKTable{ return nil } - public func getItem(_ objectId :String!) throws ->YTKItem?{ + public func getItem(_ objectId :String) throws ->YTKItem?{ do{ if let filter = try db?.prepare( tableHandle!.filter(ID == objectId).limit(1) ){ for v in filter{ var item = YTKItem() item.itemId = objectId item.itemObject = YTKObject(value: v[JSON] as AnyObject ) - item.createdTime = v.get(CREATEDTIME) + item.createdTime = try? v.get(CREATEDTIME) return item } } @@ -167,7 +167,7 @@ public struct YTKTable{ var item = YTKItem() item.itemId = vs[ID] item.itemObject = YTKObject(value:vs[JSON] as AnyObject) - item.createdTime = vs.get(CREATEDTIME) + item.createdTime = try? vs.get(CREATEDTIME) result.append(item) } } diff --git a/YTKKeyValueStore_Swift.podspec b/YTKKeyValueStore_Swift.podspec index e8f98f8..438a43e 100644 --- a/YTKKeyValueStore_Swift.podspec +++ b/YTKKeyValueStore_Swift.podspec @@ -1,14 +1,14 @@ Pod::Spec.new do |s| s.name = "YTKKeyValueStore_Swift" - s.version = "0.4.2" + s.version = "0.5.0" s.summary = "A simple Key-Value storage tool, using Sqlite as backend." s.homepage = "https://github.com/sgxiang/YTKKeyValueStore_Swift" s.license = "MIT" s.author = { "sgxiang" => "690228918@qq.com" } s.platform = :ios, '9.0' - s.source = { :git => "https://github.com/sgxiang/YTKKeyValueStore_Swift.git", :tag => "0.4.2" } + s.source = { :git => "https://github.com/sgxiang/YTKKeyValueStore_Swift.git", :tag => "0.5.0" } s.source_files = "YTKKeyValueStore/*.swift" s.requires_arc = true s.module_name = 'YTKKeyValueStore' - s.dependency "SQLite.swift", "~> 0.11.3" + s.dependency "SQLite.swift", "~> 0.12.0" end \ No newline at end of file From 10a982497b947956d4f712fa6176658bb773035f Mon Sep 17 00:00:00 2001 From: Charley <2555085@qq.com> Date: Wed, 12 Jun 2019 21:29:11 +0800 Subject: [PATCH 2/2] update README.md --- README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 94fe95e..6c315fa 100755 --- a/README.md +++ b/README.md @@ -10,8 +10,8 @@ objc version :https://github.com/yuantiku/YTKKeyValueStore ## Requirements - iOS 9.0+ -- Xcode 8.0 -- Swift 3.0 +- Xcode 10.0 +- Swift 5.0 ## Usage @@ -72,7 +72,7 @@ arrayValue : return Array? Update Cartfile to include the following: ``` -github "sgxiang/YTKKeyValueStore_Swift" ~> 0.4.2 +github "sgxiang/YTKKeyValueStore_Swift" ~> 0.5.0 ``` Run `carthage update` and [add the appropriate framework][Carthage Usage]. @@ -86,7 +86,7 @@ Update Podfile to include the following: ```ruby use_frameworks! -pod 'YTKKeyValueStore_Swift', '~> 0.4.2' +pod 'YTKKeyValueStore_Swift', '~> 0.5.0' ``` Run `pod install`