| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 | source 'https://github.com/CocoaPods/Specs.git'install! 'cocoapods', :deterministic_uuids => false# Location of gRPC's repo root relative to this file.GRPC_LOCAL_SRC = '../../..'target 'CronetTests' do  platform :ios, '9.0'  pod 'Protobuf', :path => "#{GRPC_LOCAL_SRC}/third_party/protobuf", :inhibit_warnings => true  pod '!ProtoCompiler',            :path => "#{GRPC_LOCAL_SRC}/src/objective-c"  pod '!ProtoCompiler-gRPCCppPlugin', :path => "#{GRPC_LOCAL_SRC}/src/objective-c"  pod 'Protobuf-C++', :podspec => "#{GRPC_LOCAL_SRC}/src/cpp", :inhibit_warnings => true  pod 'BoringSSL-GRPC',       :podspec => "#{GRPC_LOCAL_SRC}/src/objective-c", :inhibit_warnings => true  pod 'gRPC-Core',      :path => GRPC_LOCAL_SRC  pod 'gRPC-C++/Cronet-Implementation',      :path => GRPC_LOCAL_SRC  pod 'gRPC-C++/Protobuf',       :path => GRPC_LOCAL_SRC  pod 'RemoteTestCpp', :path => "RemoteTestClientCpp", :inhibit_warnings => true  pod 'gRPC-Core/Cronet-Implementation', :path => GRPC_LOCAL_SRC  pod 'CronetFramework', :podspec => "#{GRPC_LOCAL_SRC}/src/objective-c"  pod 'gRPC-Core/Tests', :path => GRPC_LOCAL_SRC, :inhibit_warnings => trueend# gRPC-Core.podspec needs to be modified to be successfully used for local development. A Podfile's# pre_install hook lets us do that. The block passed to it runs after the podspecs are downloaded# and before they are installed in the user project.## This podspec searches for the gRPC core library headers under "$(PODS_ROOT)/gRPC-Core", where# Cocoapods normally places the downloaded sources. When doing local development of the libraries,# though, Cocoapods just takes the sources from whatever directory was specified using `:path`, and# doesn't copy them under $(PODS_ROOT). When using static libraries, one can sometimes rely on the# symbolic links to the pods headers that Cocoapods creates under "$(PODS_ROOT)/Headers". But those# aren't created when using dynamic frameworks. So our solution is to modify the podspec on the fly# to point at the local directory where the sources are.## TODO(jcanizales): Send a PR to Cocoapods to get rid of this need.pre_install do |installer|  # This is the gRPC-Core podspec object, as initialized by its podspec file.  grpc_core_spec = installer.pod_targets.find{|t| t.name.start_with?('gRPC-Core')}.root_spec  # Copied from gRPC-Core.podspec, except for the adjusted src_root:  src_root = "$(PODS_ROOT)/../#{GRPC_LOCAL_SRC}"  grpc_core_spec.pod_target_xcconfig = {    'GRPC_SRC_ROOT' => src_root,    'HEADER_SEARCH_PATHS' => '"$(inherited)" "$(GRPC_SRC_ROOT)/include"',    'USER_HEADER_SEARCH_PATHS' => '"$(GRPC_SRC_ROOT)"',    # If we don't set these two settings, `include/grpc/support/time.h` and    # `src/core/lib/gpr/string.h` shadow the system `<time.h>` and `<string.h>`, breaking the    # build.    'USE_HEADERMAP' => 'NO',    'ALWAYS_SEARCH_USER_PATHS' => 'NO',  }  # This is the RemoteTestCpp podspec object.  remote_test_cpp_spec = installer.pod_targets.find{|t| t.name.start_with?('RemoteTestCpp')}.root_spec  # ios-cpp-test-cronet failes by chance because the RemoteTestCpp target cannot find Protobuf-C++.  remote_test_cpp_spec.pod_target_xcconfig = {    'HEADER_SEARCH_PATHS' => '"$(inherited)" "$(PODS_ROOT)/header/Public/Protobuf-C++"',  }endpost_install do |installer|  installer.pods_project.targets.each do |target|    target.build_configurations.each do |config|      config.build_settings['GCC_TREAT_WARNINGS_AS_ERRORS'] = 'YES'    end    # CocoaPods creates duplicated library targets of gRPC-Core when the test targets include    # non-default subspecs of gRPC-Core. All of these library targets start with prefix 'gRPC-Core'    # and require the same error suppresion.    if target.name.start_with?('gRPC-Core')      target.build_configurations.each do |config|        # TODO(zyc): Remove this setting after the issue is resolved        # GPR_UNREACHABLE_CODE causes "Control may reach end of non-void        # function" warning        config.build_settings['GCC_WARN_ABOUT_RETURN_TYPE'] = 'NO'        config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] = '$(inherited) COCOAPODS=1 GRPC_CRONET_WITH_PACKET_COALESCING=1'      end    end    # Activate Cronet for the dedicated build configuration 'Cronet', which will be used solely by    # the test target 'InteropTestsRemoteWithCronet'    # Activate GRPCCall+InternalTests functions for the dedicated build configuration 'Test', which will    # be used by all test targets using it.    if /gRPC-(mac|i)OS/.match(target.name)      target.build_configurations.each do |config|        if config.name == 'Cronet'          config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] = '$(inherited) COCOAPODS=1 GRPC_COMPILE_WITH_CRONET=1 GRPC_TEST_OBJC=1'        elsif config.name == 'Test'          config.build_settings['GCC_PREPROCESSOR_DEFINITIONS'] = '$(inherited) COCOAPODS=1 GRPC_TEST_OBJC=1'        end      end    end    # Enable NSAssert on gRPC    if /(gRPC|ProtoRPC|RxLibrary)-(mac|i)OS/.match(target.name)      target.build_configurations.each do |config|        if config.name != 'Release'          config.build_settings['ENABLE_NS_ASSERTIONS'] = 'YES'        end      end    end  endend
 |