Skip to content

Commit e5497ca

Browse files
Javier Cuevasfacebook-github-bot
Javier Cuevas
authored andcommitted
Exclude all FlipperKit transitive dependencies from iOS Release builds (#28504)
Summary: The `:configuration` option from `pod` only affects the specified pod and not its dependencies [1]. Therefore in order to avoid all transitive dependencies being linked in the resulting Release IPA we need to list them in the `Podfile`. Note that this will still build Flipper's pods when doing a Release, but it won't link it in the resulting IPA. [1] https://guides.cocoapods.org/syntax/podfile.html#pod Fixes react-native-community/upgrade-support#28 Related CocoaPods/CocoaPods#9658 ## Changelog * [iOS] [Fixed] - Exclude Flipper from iOS Release builds Pull Request resolved: #28504 Test Plan: Create a new React Native 0.62 project, run `pod install`, then diff: ``` ProjectName/ios/Pods/Target Support Files/Pods-ProjectName/Pods-ProjectName.debug.xcconfig` ``` and ``` ProjectName/ios/Pods/Target Support Files/Pods-ProjectName/Pods-ProjectName.relaese.xcconfig ``` ![image](https://user-images.githubusercontent.com/855995/78337679-a3fa0280-7591-11ea-8142-6f82cbc6be58.png) Reviewed By: passy Differential Revision: D20894406 Pulled By: priteshrnandgaonkar fbshipit-source-id: 680780f0f5a85fd8423b85a271a499bd12f06d00
1 parent 02dd5c6 commit e5497ca

File tree

1 file changed

+30
-6
lines changed

1 file changed

+30
-6
lines changed

scripts/react_native_pods.rb

+30-6
Original file line numberDiff line numberDiff line change
@@ -57,12 +57,36 @@ def use_react_native! (options={})
5757
end
5858
end
5959

60-
def use_flipper!(version = '~> 0.33.1')
61-
pod 'FlipperKit', version, :configuration => 'Debug'
62-
pod 'FlipperKit/FlipperKitLayoutPlugin', version, :configuration => 'Debug'
63-
pod 'FlipperKit/SKIOSNetworkPlugin', version, :configuration => 'Debug'
64-
pod 'FlipperKit/FlipperKitUserDefaultsPlugin', version, :configuration => 'Debug'
65-
pod 'FlipperKit/FlipperKitReactPlugin', version, :configuration => 'Debug'
60+
def use_flipper!(versions = {})
61+
versions['Flipper'] ||= '~> 0.33.1'
62+
versions['DoubleConversion'] ||= '1.1.7'
63+
versions['Flipper-Folly'] ||= '~> 2.1'
64+
versions['Flipper-Glog'] ||= '0.3.6'
65+
versions['Flipper-PeerTalk'] ||= '~> 0.0.4'
66+
versions['Flipper-RSocket'] ||= '~> 1.0'
67+
68+
pod 'FlipperKit', versions['Flipper'], :configuration => 'Debug'
69+
pod 'FlipperKit/FlipperKitLayoutPlugin', versions['Flipper'], :configuration => 'Debug'
70+
pod 'FlipperKit/SKIOSNetworkPlugin', versions['Flipper'], :configuration => 'Debug'
71+
pod 'FlipperKit/FlipperKitUserDefaultsPlugin', versions['Flipper'], :configuration => 'Debug'
72+
pod 'FlipperKit/FlipperKitReactPlugin', versions['Flipper'], :configuration => 'Debug'
73+
74+
# List all transitive dependencies for FlipperKit pods
75+
# to avoid them being linked in Release builds
76+
pod 'Flipper', versions['Flipper'], :configuration => 'Debug'
77+
pod 'Flipper-DoubleConversion', versions['DoubleConversion'], :configuration => 'Debug'
78+
pod 'Flipper-Folly', versions['Flipper-Folly'], :configuration => 'Debug'
79+
pod 'Flipper-Glog', versions['Flipper-Glog'], :configuration => 'Debug'
80+
pod 'Flipper-PeerTalk', versions['Flipper-PeerTalk'], :configuration => 'Debug'
81+
pod 'Flipper-RSocket', versions['Flipper-RSocket'], :configuration => 'Debug'
82+
pod 'FlipperKit/Core', versions['Flipper'], :configuration => 'Debug'
83+
pod 'FlipperKit/CppBridge', versions['Flipper'], :configuration => 'Debug'
84+
pod 'FlipperKit/FBCxxFollyDynamicConvert', versions['Flipper'], :configuration => 'Debug'
85+
pod 'FlipperKit/FBDefines', versions['Flipper'], :configuration => 'Debug'
86+
pod 'FlipperKit/FKPortForwarding', versions['Flipper'], :configuration => 'Debug'
87+
pod 'FlipperKit/FlipperKitHighlightOverlay', versions['Flipper'], :configuration => 'Debug'
88+
pod 'FlipperKit/FlipperKitLayoutTextSearchable', versions['Flipper'], :configuration => 'Debug'
89+
pod 'FlipperKit/FlipperKitNetworkPlugin', versions['Flipper'], :configuration => 'Debug'
6690
end
6791

6892
# Post Install processing for Flipper

0 commit comments

Comments
 (0)