1# This file describes to Cocoapods how to integrate the Objective-C runtime into a dependent 2# project. 3# Despite this file being specific to Objective-C, it needs to be on the root of the repository. 4# Otherwise, Cocoapods gives trouble like not picking up the license file correctly, or not letting 5# dependent projects use the :git notation to refer to the library. 6Pod::Spec.new do |s| 7 s.name = 'Protobuf' 8 s.version = '3.21.12' 9 s.summary = 'Protocol Buffers v.3 runtime library for Objective-C.' 10 s.homepage = 'https://github.com/protocolbuffers/protobuf' 11 s.license = 'BSD-3-Clause' 12 s.authors = { 'The Protocol Buffers contributors' => '[email protected]' } 13 s.cocoapods_version = '>= 1.0' 14 15 s.source = { :git => 'https://github.com/protocolbuffers/protobuf.git', 16 :tag => "v#{s.version}" } 17 18 s.source_files = 'objectivec/*.{h,m}', 19 'objectivec/google/protobuf/Any.pbobjc.h', 20 'objectivec/google/protobuf/Api.pbobjc.h', 21 'objectivec/google/protobuf/Duration.pbobjc.h', 22 'objectivec/google/protobuf/Empty.pbobjc.h', 23 'objectivec/google/protobuf/FieldMask.pbobjc.h', 24 'objectivec/google/protobuf/SourceContext.pbobjc.h', 25 'objectivec/google/protobuf/Struct.pbobjc.h', 26 'objectivec/google/protobuf/Timestamp.pbobjc.h', 27 'objectivec/google/protobuf/Type.pbobjc.h', 28 'objectivec/google/protobuf/Wrappers.pbobjc.h' 29 # The following would cause duplicate symbol definitions. GPBProtocolBuffers is expected to be 30 # left out, as it's an umbrella implementation file. 31 s.exclude_files = 'objectivec/GPBProtocolBuffers.m' 32 33 # Set a CPP symbol so the code knows to use framework imports. 34 s.user_target_xcconfig = { 'GCC_PREPROCESSOR_DEFINITIONS' => '$(inherited) GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS=1' } 35 s.pod_target_xcconfig = { 'GCC_PREPROCESSOR_DEFINITIONS' => '$(inherited) GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS=1' } 36 37 s.ios.deployment_target = '9.0' 38 s.osx.deployment_target = '10.9' 39 s.tvos.deployment_target = '9.0' 40 s.watchos.deployment_target = '2.0' 41 s.requires_arc = false 42 43 # The unittest need the generate sources from the testing related .proto 44 # files. So to add a `test_spec`, there would also need to be something like a 45 # `script_phases` to generate them, but there would also need to be a way to 46 # ensure `protoc` had be built. Another option would be to move to a model 47 # where the needed files are always generated and checked in. Neither of these 48 # seem that great at the moment, so the tests have *not* been wired into here 49 # at this time. 50end 51