Skip to content

Commit

Permalink
Remove warnings and bump deployment target to 10.15
Browse files Browse the repository at this point in the history
  • Loading branch information
qvacua committed Nov 5, 2022
1 parent 0ac4aca commit 9d9d894
Show file tree
Hide file tree
Showing 7 changed files with 41 additions and 30 deletions.
11 changes: 7 additions & 4 deletions Commons/Sources/Commons/AppKitCommons.swift
Original file line number Diff line number Diff line change
Expand Up @@ -63,8 +63,10 @@ public extension NSColor {
}

convenience init?(hex: String) {
var result: UInt32 = 0
guard hex.count == 6, Scanner(string: hex).scanHexInt32(&result) else { return nil }
guard hex.count == 6,
let uint64 = Scanner(string: hex).scanUInt64(representation: .hexadecimal)
else { return nil }
let result = UInt32(uint64)

let r = (result & 0xFF0000) >> 16
let g = (result & 0x00FF00) >> 8
Expand Down Expand Up @@ -126,15 +128,16 @@ public extension NSView {
/// - Warning: Call only in drawRect()
func rectsBeingDrawn() -> [CGRect] {
var rectsPtr: UnsafePointer<CGRect>?
var count: Int = 0
var count = 0
self.getRectsBeingDrawn(&rectsPtr, count: &count)

return Array(UnsafeBufferPointer(start: rectsPtr, count: count))
}
}

public extension NSEvent.ModifierFlags {
// Values are from https://github.com/SFML/SFML/blob/master/src/SFML/Window/OSX/SFKeyboardModifiersHelper.mm
// Values are from
// https://github.com/SFML/SFML/blob/master/src/SFML/Window/OSX/SFKeyboardModifiersHelper.mm
static let rightShift = NSEvent.ModifierFlags(rawValue: 0x020004)
static let leftShift = NSEvent.ModifierFlags(rawValue: 0x020002)
static let rightCommand = NSEvent.ModifierFlags(rawValue: 0x100010)
Expand Down
5 changes: 0 additions & 5 deletions Commons/Sources/Commons/FoundationCommons.swift
Original file line number Diff line number Diff line change
Expand Up @@ -134,9 +134,4 @@ public extension URL {
var isPackage: Bool { (try? self.resourceValues(forKeys: [.isPackageKey]))?.isPackage ?? false }
}

public extension ValueTransformer {
static var keyedUnarchiveFromDataTransformer
= ValueTransformer(forName: .keyedUnarchiveFromDataTransformerName)!
}

private let log = OSLog(subsystem: "com.qvacua.vimr.commons", category: "general")
4 changes: 2 additions & 2 deletions Commons/Support/CommonsSupport.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -202,7 +202,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.13;
MACOSX_DEPLOYMENT_TARGET = 10.15;
MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
MTL_FAST_MATH = YES;
ONLY_ACTIVE_ARCH = YES;
Expand Down Expand Up @@ -257,7 +257,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.13;
MACOSX_DEPLOYMENT_TARGET = 10.15;
MTL_ENABLE_DEBUG_INFO = NO;
MTL_FAST_MATH = YES;
SWIFT_COMPILATION_MODE = wholemodule;
Expand Down
4 changes: 2 additions & 2 deletions NvimView/Support/NvimViewSupport.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -564,7 +564,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.13;
MACOSX_DEPLOYMENT_TARGET = 10.15;
MTL_ENABLE_DEBUG_INFO = YES;
ONLY_ACTIVE_ARCH = YES;
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
Expand Down Expand Up @@ -623,7 +623,7 @@
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.13;
MACOSX_DEPLOYMENT_TARGET = 10.15;
MTL_ENABLE_DEBUG_INFO = NO;
SWIFT_COMPILATION_MODE = wholemodule;
SWIFT_DISABLE_SAFETY_CHECKS = YES;
Expand Down
3 changes: 2 additions & 1 deletion VimR/VimR.xcodeproj/project.pbxproj
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
archiveVersion = 1;
classes = {
};
objectVersion = 52;
objectVersion = 54;
objects = {

/* Begin PBXBuildFile section */
Expand Down Expand Up @@ -933,6 +933,7 @@
/* Begin PBXShellScriptBuildPhase section */
4B19BEFF1E110208007E823C /* ShellScript */ = {
isa = PBXShellScriptBuildPhase;
alwaysOutOfDate = 1;
buildActionMask = 2147483647;
files = (
);
Expand Down
42 changes: 27 additions & 15 deletions VimR/VimR/ShortcutsPref.swift
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,24 @@ import PureLayout
import RxSwift
import ShortcutRecorder

final class ShortcutValueTransformer: ValueTransformer {
static let shared = ShortcutValueTransformer()

override class func allowsReverseTransformation() -> Bool { true }

/// Data to Shortcut
override func transformedValue(_ value: Any?) -> Any? {
guard let value, let data = value as? Data else { return nil }
return try? NSKeyedUnarchiver.unarchivedObject(ofClass: Shortcut.self, from: data)
}

/// Shortcut to Data
override func reverseTransformedValue(_ value: Any?) -> Any? {
guard let value, let shortcut = value as? Shortcut else { return nil }
return try? NSKeyedArchiver.archivedData(withRootObject: shortcut, requiringSecureCoding: true)
}
}

final class ShortcutsPref: PrefPane,
UiComponent,
NSOutlineViewDelegate,
Expand Down Expand Up @@ -93,17 +111,15 @@ final class ShortcutsPref: PrefPane,
shortcut = defaultShortcuts[id] ?? nil
}

let data = ValueTransformer
.keyedUnarchiveFromDataTransformer
.reverseTransformedValue(shortcut) as? NSData
let data = ShortcutValueTransformer.shared.reverseTransformedValue(shortcut) as? NSData
self.shortcutsUserDefaults?.set(data, forKey: id)
}

self.shortcutsUserDefaults?.set(defaultsVersion, forKey: defaultsVersionKey)
}

private func initShortcutUserDefaults() {
let transformer = ValueTransformer.keyedUnarchiveFromDataTransformer
let transformer = ShortcutValueTransformer.shared
defaultShortcuts.forEach { id, shortcut in
if self.shortcutsUserDefaults?.value(forKey: id) == nil {
let shortcutData = transformer.reverseTransformedValue(shortcut) as? NSData
Expand Down Expand Up @@ -206,7 +222,7 @@ final class ShortcutsPref: PrefPane,
}

private func updateShortcutService() {
let transformer = ValueTransformer.keyedUnarchiveFromDataTransformer
let transformer = ShortcutValueTransformer.shared
let shortcuts = defaultShortcuts.compactMap { id, shortcut -> Shortcut? in
if self.shortcutsUserDefaults?.value(forKey: id) == nil { return shortcut }

Expand Down Expand Up @@ -269,9 +285,7 @@ extension ShortcutsPref {
guard response == .alertSecondButtonReturn else { return }
self.traverseMenuItems { identifier, _ in
let shortcut = defaultShortcuts[identifier] ?? Shortcut(keyEquivalent: "")
let valueToWrite = ValueTransformer
.keyedUnarchiveFromDataTransformer
.reverseTransformedValue(shortcut)
let valueToWrite = ShortcutValueTransformer.shared.reverseTransformedValue(shortcut)

self.shortcutsDefaultsController.setValue(valueToWrite, forKeyPath: "values.\(identifier)")

Expand Down Expand Up @@ -329,8 +343,7 @@ extension ShortcutsPref {
forKeyPath: "values.\(identifier)"
) as? NSData else { return true }

guard let shortcutFromDefaults = ValueTransformer
.keyedUnarchiveFromDataTransformer
guard let shortcutFromDefaults = ShortcutValueTransformer.shared
.transformedValue(dataFromDefaults) as? Shortcut else { return true }

let defaultShortcut = defaultShortcuts[identifier] ?? nil
Expand All @@ -353,18 +366,17 @@ private let defaultsVersion = 337

private class DataToKeyEquivalentTransformer: ValueTransformer {
override func transformedValue(_ value: Any?) -> Any? {
guard let shortcut = ValueTransformer
.keyedUnarchiveFromDataTransformer
.transformedValue(value) as? Shortcut else { return "" }
guard let shortcut = ShortcutValueTransformer.shared.transformedValue(value) as? Shortcut else {
return ""
}

return KeyEquivalentTransformer.shared.transformedValue(shortcut)
}
}

private class DataToKeyEquivalentModifierMaskTransformer: ValueTransformer {
override func transformedValue(_ value: Any?) -> Any? {
guard let shortcut = ValueTransformer
.keyedUnarchiveFromDataTransformer
guard let shortcut = ShortcutValueTransformer.shared
.transformedValue(value) as? Shortcut else { return NSNumber(value: 0) }

return KeyEquivalentModifierMaskTransformer.shared.transformedValue(shortcut)
Expand Down
2 changes: 1 addition & 1 deletion VimR/VimR/ShortcutsTableSubviews.swift
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ final class ShortcutTableCell: NSTableCellView {
.value,
to: content,
withKeyPath: keypath,
options: [.valueTransformer: ValueTransformer.keyedUnarchiveFromDataTransformer]
options: [.valueTransformer: ShortcutValueTransformer.shared]
)
}

Expand Down

0 comments on commit 9d9d894

Please sign in to comment.