From 25bce8bd144c7f7cfe0eee37e061b50976b8f4b1 Mon Sep 17 00:00:00 2001 From: Brandon Richards Date: Wed, 18 Mar 2015 19:30:05 -0500 Subject: [PATCH 1/5] Afloat runs only on 64-bit architecture. (Sadly, this was required.) --- Afloat.xcodeproj/project.pbxproj | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Afloat.xcodeproj/project.pbxproj b/Afloat.xcodeproj/project.pbxproj index a0f940a..2a6c0e7 100644 --- a/Afloat.xcodeproj/project.pbxproj +++ b/Afloat.xcodeproj/project.pbxproj @@ -502,7 +502,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { - ARCHS = "$(ARCHS_STANDARD_32_64_BIT)"; + ARCHS = "$(ARCHS_STANDARD_64_BIT)"; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", "\"$(SRCROOT)\"", @@ -533,7 +533,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { - ARCHS = "$(ARCHS_STANDARD_32_64_BIT)"; + ARCHS = "$(ARCHS_STANDARD_64_BIT)"; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", From c8a5b2f3e5ec6168f9426cbf1bf8353b18df42c7 Mon Sep 17 00:00:00 2001 From: Brandon Richards Date: Wed, 18 Mar 2015 19:32:27 -0500 Subject: [PATCH 2/5] Used Xcode's 'Update to recommended settings' feature. --- Afloat.xcodeproj/project.pbxproj | 7 ++++--- AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj | 5 ++++- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/Afloat.xcodeproj/project.pbxproj b/Afloat.xcodeproj/project.pbxproj index 2a6c0e7..1afb3a6 100644 --- a/Afloat.xcodeproj/project.pbxproj +++ b/Afloat.xcodeproj/project.pbxproj @@ -333,7 +333,7 @@ 089C1669FE841209C02AAC07 /* Project object */ = { isa = PBXProject; attributes = { - LastUpgradeCheck = 0420; + LastUpgradeCheck = 0620; }; buildConfigurationList = 1DEB913E08733D840010E9CD /* Build configuration list for PBXProject "Afloat" */; compatibilityVersion = "Xcode 3.2"; @@ -502,7 +502,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { - ARCHS = "$(ARCHS_STANDARD_64_BIT)"; + COMBINE_HIDPI_IMAGES = YES; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", "\"$(SRCROOT)\"", @@ -533,7 +533,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { - ARCHS = "$(ARCHS_STANDARD_64_BIT)"; + COMBINE_HIDPI_IMAGES = YES; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", @@ -561,6 +561,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { + ONLY_ACTIVE_ARCH = YES; SDKROOT = macosx; }; name = Debug; diff --git a/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj b/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj index c86efaa..c4b808e 100644 --- a/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj +++ b/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj @@ -208,7 +208,7 @@ 29B97313FDCFA39411CA2CEA /* Project object */ = { isa = PBXProject; attributes = { - LastUpgradeCheck = 0420; + LastUpgradeCheck = 0620; }; buildConfigurationList = C01FCF4E08A954540054247B /* Build configuration list for PBXProject "AfloatScripting" */; compatibilityVersion = "Xcode 3.2"; @@ -285,6 +285,7 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; + COMBINE_HIDPI_IMAGES = YES; COPY_PHASE_STRIP = NO; GCC_DYNAMIC_NO_PIC = NO; GCC_MODEL_TUNING = G5; @@ -301,6 +302,7 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; + COMBINE_HIDPI_IMAGES = YES; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; GCC_MODEL_TUNING = G5; GCC_PRECOMPILE_PREFIX_HEADER = YES; @@ -319,6 +321,7 @@ GCC_OPTIMIZATION_LEVEL = 0; GCC_WARN_ABOUT_RETURN_TYPE = YES; GCC_WARN_UNUSED_VARIABLE = YES; + ONLY_ACTIVE_ARCH = YES; SDKROOT = macosx; }; name = Debug; From 2cf180218878a13ed9cf8b454e1a7527af67d68f Mon Sep 17 00:00:00 2001 From: Brandon Richards Date: Wed, 18 Mar 2015 19:37:04 -0500 Subject: [PATCH 3/5] Fixed errors on 'rearmDeathTimer' getting called. --- AfloatScripting/AfloatDisableOverlaysCommand.m | 3 ++- AfloatScripting/AfloatMakeLessTransparentCommand.m | 3 ++- AfloatScripting/AfloatMakeMoreTransparentCommand.m | 3 ++- AfloatScripting/AfloatScriptingSetAlphaValueCommand.m | 4 +++- AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m | 4 +++- AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m | 4 +++- AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m | 7 +++++-- AfloatScripting/AfloatSetOverlayCommand.m | 4 +++- AfloatScripting/AfloatSetPinnedToDesktopCommand.m | 4 +++- AfloatScripting/AfloatShowWindowFileInFinderCommand.m | 3 ++- 10 files changed, 28 insertions(+), 11 deletions(-) diff --git a/AfloatScripting/AfloatDisableOverlaysCommand.m b/AfloatScripting/AfloatDisableOverlaysCommand.m index bf7a0a4..0dead36 100644 --- a/AfloatScripting/AfloatDisableOverlaysCommand.m +++ b/AfloatScripting/AfloatDisableOverlaysCommand.m @@ -13,7 +13,8 @@ @implementation AfloatDisableOverlaysCommand - (id) performDefaultImplementation { - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptDisableAllOverlaysNotification object:kAfloatScriptWireObject]; diff --git a/AfloatScripting/AfloatMakeLessTransparentCommand.m b/AfloatScripting/AfloatMakeLessTransparentCommand.m index 62b6268..5d2022c 100644 --- a/AfloatScripting/AfloatMakeLessTransparentCommand.m +++ b/AfloatScripting/AfloatMakeLessTransparentCommand.m @@ -13,7 +13,8 @@ @implementation AfloatMakeLessTransparentCommand - (id) performDefaultImplementation { - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptLessTransparentNotification object:kAfloatScriptWireObject]; diff --git a/AfloatScripting/AfloatMakeMoreTransparentCommand.m b/AfloatScripting/AfloatMakeMoreTransparentCommand.m index 67c4178..80347d9 100644 --- a/AfloatScripting/AfloatMakeMoreTransparentCommand.m +++ b/AfloatScripting/AfloatMakeMoreTransparentCommand.m @@ -13,7 +13,8 @@ @implementation AfloatMakeMoreTransparentCommand - (id) performDefaultImplementation { - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptMoreTransparentNotification object:kAfloatScriptWireObject]; diff --git a/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m b/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m index 0899272..160b803 100644 --- a/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m +++ b/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m @@ -15,7 +15,9 @@ @implementation AfloatScriptingSetAlphaValueCommand - (id) performDefaultImplementation { float alphaValue = [[self directParameter] floatValue]; - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetAlphaValueNotification object:kAfloatScriptWireObject userInfo: [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithFloat:alphaValue], @"alphaValue", diff --git a/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m b/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m index 9a47f95..b422e50 100644 --- a/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m +++ b/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m @@ -16,7 +16,9 @@ - (id) performDefaultImplementation { BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); BOOL keptAfloat = AfloatBOOLFromObject([self directParameter], NO); - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetKeptAfloatNotification object:kAfloatScriptWireObject userInfo: [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithBool:showsBadgeAnimation], @"showsBadgeAnimation", diff --git a/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m b/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m index f3d52dc..dea2b49 100644 --- a/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m +++ b/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m @@ -15,7 +15,9 @@ @implementation AfloatScriptingSetKeptOnAllSpacesCommand - (id) performDefaultImplementation { BOOL keptOnAllSpaces = [[self directParameter] boolValue]; - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetKeptOnAllSpacesNotification object:kAfloatScriptWireObject userInfo: [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithBool:keptOnAllSpaces], @"keptOnAllSpaces", diff --git a/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m b/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m index f9339c3..967e204 100644 --- a/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m +++ b/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m @@ -13,8 +13,11 @@ @implementation AfloatScriptingToggleKeptAfloatCommand - (id) performDefaultImplementation { - BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); - [[NSApp delegate] rearmDeathTimer]; + BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); + + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptToggleKeptAfloatNotification object:kAfloatScriptWireObject userInfo:[NSDictionary dictionaryWithObject:[NSNumber numberWithBool:showsBadgeAnimation] forKey:@"showsBadgeAnimation"]]; return nil; } diff --git a/AfloatScripting/AfloatSetOverlayCommand.m b/AfloatScripting/AfloatSetOverlayCommand.m index 0c91921..ac43e44 100644 --- a/AfloatScripting/AfloatSetOverlayCommand.m +++ b/AfloatScripting/AfloatSetOverlayCommand.m @@ -16,7 +16,9 @@ - (id) performDefaultImplementation { BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); BOOL overlay = AfloatBOOLFromObject([self directParameter], NO); - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetOverlayNotification object:kAfloatScriptWireObject userInfo: [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithBool:showsBadgeAnimation], @"showsBadgeAnimation", diff --git a/AfloatScripting/AfloatSetPinnedToDesktopCommand.m b/AfloatScripting/AfloatSetPinnedToDesktopCommand.m index 9f550b4..d1139f1 100644 --- a/AfloatScripting/AfloatSetPinnedToDesktopCommand.m +++ b/AfloatScripting/AfloatSetPinnedToDesktopCommand.m @@ -17,7 +17,9 @@ - (id) performDefaultImplementation { NSLog(@"Will pin to desktop = %@ (%d)", [self directParameter], pinnedToDesktop); BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; + [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetPinnedToDesktopNotification object:kAfloatScriptWireObject userInfo: [NSDictionary dictionaryWithObjectsAndKeys: [NSNumber numberWithBool:pinnedToDesktop], @"pinnedToDesktop", diff --git a/AfloatScripting/AfloatShowWindowFileInFinderCommand.m b/AfloatScripting/AfloatShowWindowFileInFinderCommand.m index 12cf60a..aa1c246 100644 --- a/AfloatScripting/AfloatShowWindowFileInFinderCommand.m +++ b/AfloatScripting/AfloatShowWindowFileInFinderCommand.m @@ -13,7 +13,8 @@ @implementation AfloatShowWindowFileInFinderCommand - (id) performDefaultImplementation { - [[NSApp delegate] rearmDeathTimer]; + AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptShowWindowFileInFinderNotification object:kAfloatScriptWireObject]; From ff1028f96a44e6e0d0af45c7981b8d61cb53eb53 Mon Sep 17 00:00:00 2001 From: Brandon Richards Date: Wed, 18 Mar 2015 19:41:02 -0500 Subject: [PATCH 4/5] Converted Afloat to Objective-C ARC. --- Afloat.m | 4 +--- Afloat.xcodeproj/project.pbxproj | 6 ++++-- AfloatBadgeController.h | 2 +- AfloatBadgeController.m | 8 +------- AfloatNagPreferences.h | 5 ++--- AfloatPanel.m | 4 ---- AfloatPanelController.h | 2 +- AfloatPanelController.m | 6 +----- AfloatScripting/AfloatDisableOverlaysCommand.m | 2 +- AfloatScripting/AfloatMakeLessTransparentCommand.m | 2 +- AfloatScripting/AfloatMakeMoreTransparentCommand.m | 2 +- AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj | 2 ++ AfloatScripting/AfloatScriptingAppDelegate.m | 5 +---- AfloatScripting/AfloatScriptingSetAlphaValueCommand.m | 2 +- AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m | 2 +- .../AfloatScriptingSetKeptOnAllSpacesCommand.m | 2 +- AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m | 2 +- AfloatScripting/AfloatSetOverlayCommand.m | 2 +- AfloatScripting/AfloatSetPinnedToDesktopCommand.m | 2 +- AfloatScripting/AfloatShowWindowFileInFinderCommand.m | 2 +- AfloatStorage.h | 4 ++-- AfloatStorage.m | 2 -- AfloatWindowIdentifier.m | 8 +------- Afloat_AfloatScripting.m | 2 +- 24 files changed, 28 insertions(+), 52 deletions(-) diff --git a/Afloat.m b/Afloat.m index 36f7c9d..0f84be8 100644 --- a/Afloat.m +++ b/Afloat.m @@ -117,9 +117,8 @@ - (void) install { if (index < [menu numberOfItems] && ![[menu itemAtIndex:index] isSeparatorItem]) [menu insertItem:[NSMenuItem separatorItem] atIndex:index]; - [badge release]; - [_menuWithItems release]; _menuWithItems = nil; + _menuWithItems = nil; // Set up swizzling sendEvents: in NSApplication -------------- @@ -348,7 +347,6 @@ - (void) beginTrackingWindow:(NSWindow*) window { L0Log(@"tracker = %@ view = %@", tracker, v); - [tracker release]; } - (void) endTrackingWindow:(NSWindow*) window { diff --git a/Afloat.xcodeproj/project.pbxproj b/Afloat.xcodeproj/project.pbxproj index 1afb3a6..56a1826 100644 --- a/Afloat.xcodeproj/project.pbxproj +++ b/Afloat.xcodeproj/project.pbxproj @@ -502,6 +502,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { + CLANG_ENABLE_OBJC_ARC = YES; COMBINE_HIDPI_IMAGES = YES; FRAMEWORK_SEARCH_PATHS = ( "$(inherited)", @@ -509,7 +510,7 @@ ); GCC_C_LANGUAGE_STANDARD = c99; GCC_DYNAMIC_NO_PIC = NO; - GCC_ENABLE_OBJC_GC = supported; + GCC_ENABLE_OBJC_GC = unsupported; GCC_MODEL_TUNING = G5; GCC_OPTIMIZATION_LEVEL = 0; GCC_PRECOMPILE_PREFIX_HEADER = YES; @@ -533,6 +534,7 @@ isa = XCBuildConfiguration; baseConfigurationReference = 1512ABDB0E09AB7300BA67AC /* Afloat.xcconfig */; buildSettings = { + CLANG_ENABLE_OBJC_ARC = YES; COMBINE_HIDPI_IMAGES = YES; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; FRAMEWORK_SEARCH_PATHS = ( @@ -540,7 +542,7 @@ "\"$(SRCROOT)\"", ); GCC_C_LANGUAGE_STANDARD = c99; - GCC_ENABLE_OBJC_GC = supported; + GCC_ENABLE_OBJC_GC = unsupported; GCC_MODEL_TUNING = G5; GCC_PRECOMPILE_PREFIX_HEADER = YES; GCC_PREFIX_HEADER = Afloat_Prefix.pch; diff --git a/AfloatBadgeController.h b/AfloatBadgeController.h index f084185..835291a 100644 --- a/AfloatBadgeController.h +++ b/AfloatBadgeController.h @@ -22,7 +22,7 @@ typedef NSUInteger AfloatBadgeType; unsigned int enqueuedFades; } -@property(retain) NSWindow* parentWindow; +@property(strong) NSWindow* parentWindow; - (id) initAttachedToWindow:(NSWindow*) parentWindow; + (id) badgeControllerForWindow:(NSWindow*) w; diff --git a/AfloatBadgeController.m b/AfloatBadgeController.m index ef18421..7dae1fb 100644 --- a/AfloatBadgeController.m +++ b/AfloatBadgeController.m @@ -19,7 +19,7 @@ + (id) badgeControllerForWindow:(NSWindow*) w { if (panel) return panel; else - return [[[self alloc] initAttachedToWindow:w] autorelease]; + return [[self alloc] initAttachedToWindow:w]; } - (id) initAttachedToWindow:(NSWindow*) parentWindow { @@ -48,7 +48,6 @@ - (void) setParentWindow:(NSWindow*) newParent { if (_parentWindow) { [AfloatStorage removeSharedValueForWindow:_parentWindow key:kAfloatBadgeControllerKey]; - [_parentWindow release]; } if (newParent) { @@ -58,7 +57,6 @@ - (void) setParentWindow:(NSWindow*) newParent { // addObserver:self selector:@selector(parentWindowDidResize:) name:NSWindowDidResizeNotification object:_parentWindow]; - [newParent retain]; } _parentWindow = newParent; @@ -188,9 +186,5 @@ + (NSImage*) didEndKeepingAfloatBadge { } -- (void) dealloc { - self.parentWindow = nil; - [super dealloc]; -} @end diff --git a/AfloatNagPreferences.h b/AfloatNagPreferences.h index b2ac6a9..2a0b8fd 100644 --- a/AfloatNagPreferences.h +++ b/AfloatNagPreferences.h @@ -15,13 +15,12 @@ enum { typedef NSInteger AfloatNagAction; static id AfloatNagGetPreferenceForKey(CFStringRef key, Class cl) { - id obj = (id) CFPreferencesCopyAppValue(key, kAfloatNagPreferencesIdentifier); + id obj = (id) CFBridgingRelease(CFPreferencesCopyAppValue(key, kAfloatNagPreferencesIdentifier)); if (cl && obj && ![obj isKindOfClass:cl]) { - [obj release]; obj = nil; } - return [obj autorelease]; + return obj; } static BOOL AfloatNagGetBooleanForKey(CFStringRef key) { diff --git a/AfloatPanel.m b/AfloatPanel.m index f2bf2cc..f7ed512 100644 --- a/AfloatPanel.m +++ b/AfloatPanel.m @@ -25,10 +25,6 @@ - (id) initWithFrame:(NSRect) frame { return self; } -- (void) dealloc { - [_image release]; - [super dealloc]; -} - (void) drawRect:(NSRect) r { [[NSColor clearColor] set]; NSRectFill(r); diff --git a/AfloatPanelController.h b/AfloatPanelController.h index de943ee..bf1b07b 100644 --- a/AfloatPanelController.h +++ b/AfloatPanelController.h @@ -27,7 +27,7 @@ typedef enum { - (IBAction) disableAllOverlays:(id) sender; -@property(retain) NSWindow* parentWindow; +@property(strong) NSWindow* parentWindow; @property CGFloat alphaValue; // @property(getter=isKeptAfloat) BOOL keptAfloat; @property AfloatWindowState windowState; diff --git a/AfloatPanelController.m b/AfloatPanelController.m index 65bd904..e2ccde0 100644 --- a/AfloatPanelController.m +++ b/AfloatPanelController.m @@ -43,7 +43,6 @@ - (void) setParentWindow:(NSWindow*) newParent { [[NSNotificationCenter defaultCenter] removeObserver:self name:NSWindowDidResizeNotification object:_parentWindow]; - [_parentWindow release]; } if (newParent) { @@ -53,7 +52,6 @@ - (void) setParentWindow:(NSWindow*) newParent { addObserver:self selector:@selector(parentWindowDidResize:) name:NSWindowDidResizeNotification object:_parentWindow]; - [newParent retain]; } _parentWindow = newParent; @@ -98,13 +96,11 @@ + (id) panelControllerForWindow:(NSWindow*) w { if (panel) return panel; else - return [[[self alloc] initAttachedToWindow:w] autorelease]; + return [[self alloc] initAttachedToWindow:w]; } - (void) dealloc { [AfloatStorage removeSharedValueForWindow:self.parentWindow key:kAfloatPanelControllerKey]; - self.parentWindow = nil; - [super dealloc]; } - (IBAction) toggleWindow:(id) sender { diff --git a/AfloatScripting/AfloatDisableOverlaysCommand.m b/AfloatScripting/AfloatDisableOverlaysCommand.m index 0dead36..24f1530 100644 --- a/AfloatScripting/AfloatDisableOverlaysCommand.m +++ b/AfloatScripting/AfloatDisableOverlaysCommand.m @@ -13,7 +13,7 @@ @implementation AfloatDisableOverlaysCommand - (id) performDefaultImplementation { - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] diff --git a/AfloatScripting/AfloatMakeLessTransparentCommand.m b/AfloatScripting/AfloatMakeLessTransparentCommand.m index 5d2022c..a245a22 100644 --- a/AfloatScripting/AfloatMakeLessTransparentCommand.m +++ b/AfloatScripting/AfloatMakeLessTransparentCommand.m @@ -13,7 +13,7 @@ @implementation AfloatMakeLessTransparentCommand - (id) performDefaultImplementation { - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] diff --git a/AfloatScripting/AfloatMakeMoreTransparentCommand.m b/AfloatScripting/AfloatMakeMoreTransparentCommand.m index 80347d9..a3aa668 100644 --- a/AfloatScripting/AfloatMakeMoreTransparentCommand.m +++ b/AfloatScripting/AfloatMakeMoreTransparentCommand.m @@ -13,7 +13,7 @@ @implementation AfloatMakeMoreTransparentCommand - (id) performDefaultImplementation { - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] diff --git a/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj b/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj index c4b808e..567f9b5 100644 --- a/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj +++ b/AfloatScripting/AfloatScripting.xcodeproj/project.pbxproj @@ -285,6 +285,7 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ENABLE_OBJC_ARC = YES; COMBINE_HIDPI_IMAGES = YES; COPY_PHASE_STRIP = NO; GCC_DYNAMIC_NO_PIC = NO; @@ -302,6 +303,7 @@ isa = XCBuildConfiguration; buildSettings = { ALWAYS_SEARCH_USER_PATHS = NO; + CLANG_ENABLE_OBJC_ARC = YES; COMBINE_HIDPI_IMAGES = YES; DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; GCC_MODEL_TUNING = G5; diff --git a/AfloatScripting/AfloatScriptingAppDelegate.m b/AfloatScripting/AfloatScriptingAppDelegate.m index 7956299..7dd8b05 100644 --- a/AfloatScripting/AfloatScriptingAppDelegate.m +++ b/AfloatScripting/AfloatScriptingAppDelegate.m @@ -18,10 +18,9 @@ - (void) applicationDidFinishLaunching:(NSNotification*) n { - (void) rearmDeathTimer { if (deathTimer) { [deathTimer invalidate]; - [deathTimer release]; } - deathTimer = [[NSTimer scheduledTimerWithTimeInterval:60 target:self selector:@selector(deathTimerTicked:) userInfo:nil repeats:NO] retain]; + deathTimer = [NSTimer scheduledTimerWithTimeInterval:60 target:self selector:@selector(deathTimerTicked:) userInfo:nil repeats:NO]; } - (void) deathTimerTicked:(NSTimer*) t { @@ -30,8 +29,6 @@ - (void) deathTimerTicked:(NSTimer*) t { - (void) dealloc { [deathTimer invalidate]; - [deathTimer release]; - [super dealloc]; } @end diff --git a/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m b/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m index 160b803..ab69096 100644 --- a/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m +++ b/AfloatScripting/AfloatScriptingSetAlphaValueCommand.m @@ -15,7 +15,7 @@ @implementation AfloatScriptingSetAlphaValueCommand - (id) performDefaultImplementation { float alphaValue = [[self directParameter] floatValue]; - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetAlphaValueNotification object:kAfloatScriptWireObject userInfo: diff --git a/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m b/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m index b422e50..48243a4 100644 --- a/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m +++ b/AfloatScripting/AfloatScriptingSetKeptAfloatCommand.m @@ -16,7 +16,7 @@ - (id) performDefaultImplementation { BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); BOOL keptAfloat = AfloatBOOLFromObject([self directParameter], NO); - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetKeptAfloatNotification object:kAfloatScriptWireObject userInfo: diff --git a/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m b/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m index dea2b49..87d362a 100644 --- a/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m +++ b/AfloatScripting/AfloatScriptingSetKeptOnAllSpacesCommand.m @@ -15,7 +15,7 @@ @implementation AfloatScriptingSetKeptOnAllSpacesCommand - (id) performDefaultImplementation { BOOL keptOnAllSpaces = [[self directParameter] boolValue]; - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetKeptOnAllSpacesNotification object:kAfloatScriptWireObject userInfo: diff --git a/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m b/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m index 967e204..9a5393b 100644 --- a/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m +++ b/AfloatScripting/AfloatScriptingToggleKeptAfloatCommand.m @@ -15,7 +15,7 @@ @implementation AfloatScriptingToggleKeptAfloatCommand - (id) performDefaultImplementation { BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptToggleKeptAfloatNotification object:kAfloatScriptWireObject userInfo:[NSDictionary dictionaryWithObject:[NSNumber numberWithBool:showsBadgeAnimation] forKey:@"showsBadgeAnimation"]]; diff --git a/AfloatScripting/AfloatSetOverlayCommand.m b/AfloatScripting/AfloatSetOverlayCommand.m index ac43e44..c293986 100644 --- a/AfloatScripting/AfloatSetOverlayCommand.m +++ b/AfloatScripting/AfloatSetOverlayCommand.m @@ -16,7 +16,7 @@ - (id) performDefaultImplementation { BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); BOOL overlay = AfloatBOOLFromObject([self directParameter], NO); - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetOverlayNotification object:kAfloatScriptWireObject userInfo: diff --git a/AfloatScripting/AfloatSetPinnedToDesktopCommand.m b/AfloatScripting/AfloatSetPinnedToDesktopCommand.m index d1139f1..da10cc7 100644 --- a/AfloatScripting/AfloatSetPinnedToDesktopCommand.m +++ b/AfloatScripting/AfloatSetPinnedToDesktopCommand.m @@ -17,7 +17,7 @@ - (id) performDefaultImplementation { NSLog(@"Will pin to desktop = %@ (%d)", [self directParameter], pinnedToDesktop); BOOL showsBadgeAnimation = AfloatBOOLFromObject([[self evaluatedArguments] objectForKey:@"showsBadgeAnimation"], YES); - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] postNotificationName:kAfloatScriptSetPinnedToDesktopNotification object:kAfloatScriptWireObject userInfo: diff --git a/AfloatScripting/AfloatShowWindowFileInFinderCommand.m b/AfloatScripting/AfloatShowWindowFileInFinderCommand.m index aa1c246..0aa4003 100644 --- a/AfloatScripting/AfloatShowWindowFileInFinderCommand.m +++ b/AfloatScripting/AfloatShowWindowFileInFinderCommand.m @@ -13,7 +13,7 @@ @implementation AfloatShowWindowFileInFinderCommand - (id) performDefaultImplementation { - AfloatScriptingAppDelegate *asap = [[[AfloatScriptingAppDelegate alloc] init] autorelease]; + AfloatScriptingAppDelegate *asap = [[AfloatScriptingAppDelegate alloc] init]; [asap rearmDeathTimer]; [[NSDistributedNotificationCenter defaultCenter] diff --git a/AfloatStorage.h b/AfloatStorage.h index 8731542..1c5e164 100644 --- a/AfloatStorage.h +++ b/AfloatStorage.h @@ -14,7 +14,7 @@ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND @interface AfloatStorage : NSObject { NSMutableDictionary* _backingStorage; - id _delegate; + id __strong _delegate; NSArray* _persistedKeys; } @@ -28,7 +28,7 @@ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND - (NSMutableDictionary*) mutableDictionaryForWindow:(NSWindow*) w; -@property(assign) id delegate; +@property(strong) id delegate; @property(copy) NSArray* persistedKeys; - (void) removeValueForWindow:(NSWindow*) w key:(NSString*) k; diff --git a/AfloatStorage.m b/AfloatStorage.m index de16a18..01b6d2a 100644 --- a/AfloatStorage.m +++ b/AfloatStorage.m @@ -39,8 +39,6 @@ - (id) init { - (void) dealloc { [[NSNotificationCenter defaultCenter] removeObserver:self]; - [_backingStorage release]; - [super dealloc]; } - (id) valueForWindow:(NSWindow*) w key:(NSString*) k { diff --git a/AfloatWindowIdentifier.m b/AfloatWindowIdentifier.m index 4086e27..3fc08c0 100644 --- a/AfloatWindowIdentifier.m +++ b/AfloatWindowIdentifier.m @@ -144,12 +144,6 @@ + (NSArray*) identifierSubclasses { return classes; } -- (void) dealloc { - self.category = nil; - self.key = nil; - - [super dealloc]; -} @synthesize category = _category, key = _key, canMatchMultipleWindows = _canMatchMultipleWindows; @@ -158,7 +152,7 @@ + (NSArray*) allIdentifiersForWindow:(NSWindow*) w { for (Class c in [self identifierSubclasses]) { if ([c canInitWithWindow:w]) - [results addObject:[[[c alloc] initWithWindow:w] autorelease]]; + [results addObject:[[c alloc] initWithWindow:w]]; } return results; diff --git a/Afloat_AfloatScripting.m b/Afloat_AfloatScripting.m index e680b78..ebb793b 100644 --- a/Afloat_AfloatScripting.m +++ b/Afloat_AfloatScripting.m @@ -58,7 +58,7 @@ - (void) installScriptingSupport { [[NSDistributedNotificationCenter defaultCenter] addObserver:self selector:@selector(_scriptShouldShowWindowFileInFinder:) name:kAfloatScriptShowWindowFileInFinderNotification object:kAfloatScriptWireObject]; NSString* pathToScriptingApp = [[[[NSBundle bundleForClass:[self class]] bundlePath] stringByAppendingPathComponent:@"Contents"] stringByAppendingPathComponent:@"Afloat Scripting.app"]; - LSRegisterURL((CFURLRef) [NSURL fileURLWithPath:pathToScriptingApp], false); + LSRegisterURL((__bridge CFURLRef) [NSURL fileURLWithPath:pathToScriptingApp], false); L0LogS(@"Scripting support installed."); } From be7c1c3596f019c252c3251818a7cdc5d6befc0c Mon Sep 17 00:00:00 2001 From: Brandon Richards Date: Wed, 18 Mar 2015 19:42:53 -0500 Subject: [PATCH 5/5] Fixed a couple of small warnings. --- Afloat.m | 13 +++++++++++-- AfloatBadgeController.h | 2 +- AfloatPanelController.h | 2 +- AfloatWindowIdentifier.m | 2 +- 4 files changed, 14 insertions(+), 5 deletions(-) diff --git a/Afloat.m b/Afloat.m index 0f84be8..3d17356 100644 --- a/Afloat.m +++ b/Afloat.m @@ -94,8 +94,17 @@ - (void) install { NSUInteger index = [self indexForInstallingInMenu:menu]; - [NSBundle loadNibNamed:@"Afloat" owner:self]; - + //[NSBundle loadNibNamed:@"Afloat" owner:self]; + // Replaced with more functional nibLoading below + + if ([[NSBundle mainBundle] respondsToSelector:@selector(loadNibNamed:owner:topLevelObjects:)]) { + // We're running on Mountain Lion or higher + [[NSBundle mainBundle] loadNibNamed:@"Afloat" owner:self topLevelObjects:nil]; + } else { + // We're running on Lion + [NSBundle loadNibNamed:@"Afloat" owner:self]; + } + NSImage* badge = [[NSImage alloc] initWithContentsOfFile: [[self bundle] pathForImageResource:@"AfloatMenuBadge"]]; diff --git a/AfloatBadgeController.h b/AfloatBadgeController.h index 835291a..446e4eb 100644 --- a/AfloatBadgeController.h +++ b/AfloatBadgeController.h @@ -22,7 +22,7 @@ typedef NSUInteger AfloatBadgeType; unsigned int enqueuedFades; } -@property(strong) NSWindow* parentWindow; +@property(nonatomic, strong) NSWindow* parentWindow; - (id) initAttachedToWindow:(NSWindow*) parentWindow; + (id) badgeControllerForWindow:(NSWindow*) w; diff --git a/AfloatPanelController.h b/AfloatPanelController.h index bf1b07b..b00f789 100644 --- a/AfloatPanelController.h +++ b/AfloatPanelController.h @@ -27,7 +27,7 @@ typedef enum { - (IBAction) disableAllOverlays:(id) sender; -@property(strong) NSWindow* parentWindow; +@property(nonatomic, strong) NSWindow* parentWindow; @property CGFloat alphaValue; // @property(getter=isKeptAfloat) BOOL keptAfloat; @property AfloatWindowState windowState; diff --git a/AfloatWindowIdentifier.m b/AfloatWindowIdentifier.m index 3fc08c0..1410d1f 100644 --- a/AfloatWindowIdentifier.m +++ b/AfloatWindowIdentifier.m @@ -148,7 +148,7 @@ + (NSArray*) identifierSubclasses { @synthesize category = _category, key = _key, canMatchMultipleWindows = _canMatchMultipleWindows; + (NSArray*) allIdentifiersForWindow:(NSWindow*) w { - NSMutableArray* results = [NSArray array]; + NSMutableArray* results = [NSArray mutableCopy]; for (Class c in [self identifierSubclasses]) { if ([c canInitWithWindow:w])