From 5995708fb86c9a9e311e290a7a372a66be7734e8 Mon Sep 17 00:00:00 2001 From: Greg Bolsinga Date: Wed, 1 May 2019 12:40:48 -0700 Subject: [PATCH] Ensure ASControlMode properties lock before accessing their ivars (#1476) Enable `#pragma clang diagnostic error "-Wobjc-missing-property-synthesis"` for this file. --- Source/ASControlNode.h | 5 ++++ Source/ASControlNode.mm | 63 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 68 insertions(+) diff --git a/Source/ASControlNode.h b/Source/ASControlNode.h index 0918fdb0b..862f8fc83 100644 --- a/Source/ASControlNode.h +++ b/Source/ASControlNode.h @@ -11,6 +11,9 @@ #pragma once +#pragma clang diagnostic push +#pragma clang diagnostic error "-Wobjc-missing-property-synthesis" + NS_ASSUME_NONNULL_BEGIN /** @@ -147,3 +150,5 @@ static UIControlState const ASControlStateSelected ASDISPLAYNODE_DEPRECATED_MSG( #endif NS_ASSUME_NONNULL_END + +#pragma clang diagnostic pop diff --git a/Source/ASControlNode.mm b/Source/ASControlNode.mm index 1256d2d62..08d4536d9 100644 --- a/Source/ASControlNode.mm +++ b/Source/ASControlNode.mm @@ -33,6 +33,7 @@ @interface ASControlNode () // Control Attributes BOOL _enabled; BOOL _highlighted; + BOOL _selected; // Tracking BOOL _tracking; @@ -121,6 +122,68 @@ - (void)__exitHierarchy } } +#pragma mark - ASDisplayNode Overrides + +- (BOOL)isEnabled +{ + ASLockScopeSelf(); + return _enabled; +} + +- (void)setEnabled:(BOOL)enabled +{ + ASLockScopeSelf(); + _enabled = enabled; +} + +- (BOOL)isHighlighted +{ + ASLockScopeSelf(); + return _highlighted; +} + +- (void)setHighlighted:(BOOL)highlighted +{ + ASLockScopeSelf(); + _highlighted = highlighted; +} + +- (void)setSelected:(BOOL)selected +{ + ASLockScopeSelf(); + _selected = selected; +} + +- (BOOL)isSelected +{ + ASLockScopeSelf(); + return _selected; +} + +- (void)setTracking:(BOOL)tracking +{ + ASLockScopeSelf(); + _tracking = tracking; +} + +- (BOOL)isTracking +{ + ASLockScopeSelf(); + return _tracking; +} + +- (void)setTouchInside:(BOOL)touchInside +{ + ASLockScopeSelf(); + _touchInside = touchInside; +} + +- (BOOL)isTouchInside +{ + ASLockScopeSelf(); + return _touchInside; +} + #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wobjc-missing-super-calls"