目前iOS组件化经常使用的解决方案是Pod+路由+持续集成,一般架构设计完成后第一步就是将原来工程里的模块按照架构图分解为一个个独立的pod工程(组件),今天咱们就来看看如何建立一个Pod私有库。html
假设咱们须要建立的库名为TestLib,下面咱们使用Pod官方提供的建立模板:ios
pod lib create TestLib
import Foundation public class ClassA { //这是public类,可被外部工程访问 public let name = "ClassA" let age = 18 } class ClassB { //不是public类,不能被外部工程访问 let name = "ClassB" }
pod install
public
修饰的属性到这里使用Pod新建一个私有库就完成了。git
新建完成后,咱们还须要验证,须要修改配置文件,经过下面的截图路径找到新建的私有库的配置文件:
github
或者在Xcode里的:
swift
文件内容:xcode
# # Be sure to run `pod lib lint TestLib.podspec' to ensure this is a # valid spec before submitting. # # Any lines starting with a # are optional, but their use is encouraged # To learn more about a Podspec see https://guides.cocoapods.org/syntax/podspec.html # Pod::Spec.new do |s| # 名称、版本号、概述 s.name = 'TestLib' s.version = '0.1.0' s.summary = 'A short description of TestLib.' # This description is used to generate tags and improve search results. # * Think: What does it do? Why did you write it? What is the focus? # * Try to keep it short, snappy and to the point. # * Write the description between the DESC delimiters below. # * Finally, don't worry about the indent, CocoaPods strips it! # 详细描述 s.description = <<-DESC TODO: Add long description of the pod here. DESC # 主页、截图、license证书、做者信息、源代码地址、社交地址 s.homepage = 'https://github.com/xxx/TestLib' # s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2' s.license = { :type => 'MIT', :file => 'LICENSE' } s.author = { 'xxx' => 'xxx@xxx.com' } s.source = { :git => 'https://github.com/xxx/TestLib.git', :tag => s.version.to_s } # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>' # iOS版本 s.ios.deployment_target = '8.0' # 源码所在路径 s.source_files = 'TestLib/Classes/**/*' # 资源文件所在地址 # s.resource_bundles = { # 'TestLib' => ['TestLib/Assets/*.png'] # } # 对外公开的h文件地址,swift通常用不到 # s.public_header_files = 'Pod/Classes/**/*.h' # 包含的系统framework # s.frameworks = 'UIKit', 'MapKit' # 包含的第三方pod # s.dependency 'AFNetworking', '~> 2.3' end
更详细的介绍能够访问官网https://guides.cocoapods.org/syntax/podspec.html服务器
配置好之后咱们须要作一次验证,在工程目录下使用命令架构
pod lib lint
Could not find a `ios` simulator (valid values: ). Ensure that Xcode -> Window -> Devices has at least one `ios` simulator listed or otherwise add one.
1.sudo gem uninstall fourflusher 2.sudo gem install fourflusher
必要的话还须要更新podapp
sudo gem update cocoapods
[!] TestLib did not pass validation, due to 3 warnings (but you can use `--allow-warnings` to ignore them).
--allow-warnings
pod lib lint --allow-warnings
若是验证经过,会看到TestLib passed validation.
,到这一步既完成验证ide
经过pod官方模板作出来的工程iOS版本为8.0,Swift版本为4.0,咱们有时须要根据须要修改版本号,须要在spec文件中添加:
# iOS版本 s.ios.deployment_target = '9.0' # Swift版本 s.swift_versions = '5.0'
而后执行pod install
更新工程便可
如今私有Git服务器建立TestLib项目,而后回到工程目录,使用Git初始化命令:
git init git remote add origin http://私有仓库地址/TestLib.git git add . git commit -m 'init' git push -u origin master
而后修改spec文件内容
# 主页、截图、license证书、做者信息、源代码地址、社交地址 s.homepage = 'http://私有库地址/TestLib.git' # s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2' s.license = { :type => 'MIT', :file => 'LICENSE' } s.author = { 'xxx' => 'xxx@xxx.com' } s.source = { :git => 'http://私有库地址/TestLib.git', :tag => s.version.to_s }
若是须要对外发布版本时需打tag,而后建立同名branch
git tag -a 0.1.0 -m '0.1.0'
git branch 0.1.0
有时咱们不但愿提供源代码,只提供framework给外部调用,可使用package
,首先安装pod插件:
sudo gem install cocoapods-packager
package参数:
参数名 | 注释 |
---|---|
--force | 覆盖以前的文件 |
--no-mangle | 1.表示不使用name mangling技术,pod package默认是使用这个技术的。咱们能在用pod package生成二进制库的时候会看到终端有输出Mangling symbols和Building mangled framework。表示使用了这个技术。2.若是你的pod库没有其余依赖的话,那么不使用这个命令也不会报错。可是若是有其余依赖,不使用--no-mangle这个命令的话,那么你在工程里使用生成的二进制库的时候就会报错:Undefined symbols for architecture x86_64。 |
--embedded | 生成静态framework |
--library | 生成静态.a |
--dynamic | 生成动态framework |
--bundle-identifier | 动态framework须要的签名 |
--exclude-deps | 不包含依赖的符号表,生成动态库的时候不能包含这个命令,动态库必定须要包含依赖的符号表 |
--configuration | 表示生成的库是debug仍是release,默认是release。--configuration=Debug |
--subspecs | 若是你的pod库有subspec,那么加上这个命名表示只给某个或几个subspec生成二进制库,--subspecs=subspec1,subspec2。生成的库的名字就是你podspec的名字,若是你想生成的库的名字跟subspec的名字同样,那么就须要修改podspec的名字。 这个脚本就是批量生成subspec的二进制库,每个subspec的库名就是podspecName+subspecName。 |
--spec-sources=private,https://github.com/CocoaPods/Specs.git | 一些依赖的source,若是你有依赖是来自于私有库的,那就须要加上那个私有库的source,默认是cocoapods的Specs仓库。--spec-sources=private,https://github.com/CocoaPods/Specs.git。 |
可使用下面的命令打包:
pod package TestLib.podspec --force