创建自己的pod库和打包静态链接库.a

创建pod工程

现在有很多工程都是用Cocoapods管理了,如果你想把自己的库托管给CocoaPods,那么只需要以下几个步骤:

1.执行命令pod lib create XXLib

在此期间需要确认下面几个问题。

What language do you want to use?? [ Swift / ObjC ]Objc
Would you like to provide a demo application with your library? [ Yes / No ]yes
Which testing frameworks will you use? [ Specta / Kiwi / None ]None
Would you like to do view based testing? [ Yes / No ]NoWhat is your class prefix?BZ
What is your class prefix?XXD

执行完之后,进入XXLib文件夹,目录结构如下

XXLib工程的目录结构
--Example// 例子目录
-----Podfile
-----Tests
-----XXLib
-----XXLib.xcodeproj
--LICENSE
--README.md
--XXLib // XXLib文件夹是库文件夹,其中Assets存放资源文件,Classes存放代码文件。
-----Assets
-----Classees
--XXLib.podspec
--_Pods.xcodeproj -> Example/Pods/Pods.xcodeproj

2.打开XXLib.podspec文件,看看其中的属性,大部分都见名知意,或查阅官网文档

source可以选定tag或者branch。
frameworkslibraries指定依赖的SDK中的framework和类库,需要注意,依赖项不仅要包含你自己类库的依赖,还要包括所有第三方类库的依赖,只有这样当你的类库打包成.a或.framework时才能让其他项目正常使用。

#
# Be sure to run `pod lib lint XXLib.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 http://guides.cocoapods.org/syntax/podspec.html
#

Pod::Spec.new do |s|
  s.name             = 'XXLib'
  s.version          = '0.1.0'
  s.summary          = 'A short description of XXLib.'

# 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

  s.homepage         = 'https://github.com/<GITHUB_USERNAME>/XXLib'
  # s.screenshots     = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'zhiyu.zhao' => 'zhiyu.zhao@XXX.com' }
  s.source           = { :git => 'https://github.com/<GITHUB_USERNAME>/XXLib.git', :tag => s.version.to_s }
  # s.social_media_url = 'https://twitter.com/<TWITTER_USERNAME>'

  s.ios.deployment_target = '8.0'

  s.source_files = 'XXLib/Classes/**/*'
  
  # s.resource_bundles = {
  #   'XXLib' => ['XXLib/Assets/*.png']
  # }

  # s.public_header_files = 'Pod/Classes/**/*.h'
  # s.frameworks = 'UIKit', 'MapKit'
  # s.dependency 'AFNetworking', '~> 2.3'
end

3.检查podSpec

检查命令很简单

pod spec lint

它会检查当前文件夹下的所有podSpec文件
但是当我使用命令时遇到几个小问题,这里说一下。前提条件:之前学习iOS10新特性,安装了XCode8 beta版,XCode7也没卸载掉,所以电脑里有俩XCode。

当我第一次检查podSpec报错

  • ERROR | [iOS] unknown: Encountered an unknown error (Must be in the root of the repo (/Users/zhiyu.zhao/.cocoapods/repos/master), instead in /Users/zhiyu.zhao/Desktop/XXLib.) during validation.

说我的repo root不对,CocoaPods的Issue里找了找还真有人和遇到我一样的问题链接,通过制定XCode应用路径解决问题
sudo xcode-select -s /Applications/Xcode.app

第二次运行时,依然报错

  • ERROR | [iOS] unknown: Encountered an unknown error (Simulator iPhone 4s is not available.) during validation.

无独有偶也有人遇到我的问题链接

运行xcrun simctl list查看我的设备列表
== Device Types ==
iPhone 4s (com.apple.CoreSimulator.SimDeviceType.iPhone-4s)
iPhone 5 (com.apple.CoreSimulator.SimDeviceType.iPhone-5)
iPhone 5s (com.apple.CoreSimulator.SimDeviceType.iPhone-5s)
iPhone 6 (com.apple.CoreSimulator.SimDeviceType.iPhone-6)
iPhone 6 Plus (com.apple.CoreSimulator.SimDeviceType.iPhone-6-Plus)
iPhone 6s (com.apple.CoreSimulator.SimDeviceType.iPhone-6s)
iPhone 6s Plus (com.apple.CoreSimulator.SimDeviceType.iPhone-6s-Plus)
iPad 2 (com.apple.CoreSimulator.SimDeviceType.iPad-2)
iPad Retina (com.apple.CoreSimulator.SimDeviceType.iPad-Retina)
iPad Air (com.apple.CoreSimulator.SimDeviceType.iPad-Air)
iPad Air 2 (com.apple.CoreSimulator.SimDeviceType.iPad-Air-2)
iPad Pro (com.apple.CoreSimulator.SimDeviceType.iPad-Pro)
Apple TV 1080p (com.apple.CoreSimulator.SimDeviceType.Apple-TV-1080p)
Apple Watch - 38mm (com.apple.CoreSimulator.SimDeviceType.Apple-Watch-38mm)
Apple Watch - 42mm (com.apple.CoreSimulator.SimDeviceType.Apple-Watch-42mm)
== Runtimes ==
iOS 9.1 (9.1 - 13B137) (com.apple.CoreSimulator.SimRuntime.iOS-9-1)
tvOS 9.0 (9.0 - 13T393) (com.apple.CoreSimulator.SimRuntime.tvOS-9-0)
watchOS 2.0 (2.0 - 13S343) (com.apple.CoreSimulator.SimRuntime.watchOS-2-0)
== Devices ==// 因为有俩XCode,其中老版本7.1的模拟器都丢了,自己新建的模拟器
-- iOS 9.1 --
    xocde7_4s (7CFCFB3D-B8E0-4F9B-B328-AC4AC0937CDB) (Shutdown)
    xode7_5s (F832F80F-2E63-431A-9692-AB67C6D7D462) (Shutdown)
    xcode7_6p (D89AEE31-191C-448C-95A1-6FFA0989BD55) (Shutdown)
    xcode7_6s (7C8D4F6E-BA5C-4C39-8511-5CD8CD4F5554) (Shutdown)

人家说了,这是按照系统默认命名(iPhone 4s)来的查找的,我改过一次当然就找不到对应模拟器了。
几番折腾之后,终于过了检查

4.本地调试

Example文件夹下Podfile默认引入了XXLib,使用了path指定了路径,此处是为本地上级目录。这么写时,不需要依赖~/.cocoa/repo下的podspec,直接能pod update,而且XXLib的源码会在Example的pod工程下一个名为Development的group下。直接在XCode中就能修改Classes文件夹中内容。

example的Podfile
use_frameworks!

target 'XXLib_Example' do
  pod 'XXLib', :path => '../'

  target 'XXLib_Tests' do
    inherit! :search_paths

    pod 'FBSnapshotTestCase'
  end
end

四个步骤就完成了一个完整的pod架子,把自己的代码加入进去后,剩下的就是向远程提交了

打包静态链接库

库建好了,也提交了,但是是开源的。总有那么些东西没办法给别人看,怎么办,打成静态链接库呗。

手动创建.a流程

网上很多资料可以查询,是一个力气活儿
1.新建一个工程,类型选static library
2.将需要打包的源文件拖入
3.配置静态库target的build phases
将所有.m文件拖入到Compile Sources中。因为我的这个库中是OC和C++混编的,所以还需要加入.mm、.hpp、.cpp等类型文件。
4.暴露头文件
新建一个标签Headers Phase,将想要暴露出来的头文件放到里面。网上也有说将想暴露的头文件放到Copy Files下的,可以都放,没有测试过。
5.合并模拟器&真机架构下的静态库
新建一个Aggregate类型的target,在Build Phases中新建Run Scropt写上合并的操作,一般.a在工程的products文件夹下可以找到。

具体路径
~/Developer/XCode/DerivedData/xxxxxxx/Build/Products/Debug(Release)-iphoneos(iphonesimulator)

命令很简单

 lipo -create 静态库1.a(路径) 静态库2.a(路径) -output 新静态库.a  

6.添加资源文件
如果有用到资源文件,需要将他们放到一个bundle里可以自己新建bundle类型target,也可以修改文件夹后缀成.bundle完成。在静态库target的Build Phases页下的Target Dependencies和Copy Bundle Resources标签中加上你的bundle就可以了。
7.编写podspec文件
xxxxx

使用cocopods-packager打包库

前面说到了手动创建时需要新建一个static library的target,这里介绍cocoapods-packager插件,它支持直接使用命令,依赖项目的podspec文件进行打包。

安装方式很简单

$ gem install cocoapods-packager

打包命令也很简单

$ pod package XXLib.podspec --library --force

--library指定打包成.a文件,如果不带上将会打包成.framework文件。
--force是指强制覆盖已存在的文件夹。

需要特别强调的是,该插件通过对引用的三方库进行重命名很好的解决了类库命名冲突的问题。

生成文件目录结构如下:

XXLib-0.1.0
--build
--ios
----libXXLib.a
--XXLib.podspec

坑:
此插件对--library的支持不是很好,打包出来只有.a,没有头文件和资源文件而且生成的podspec文件还是framework的。对于这个bug,作者很愉快的承认了,并表示--library用得少,我不着急改🙂

所以我们还是使用它的framework格式的库吧
命令也很简单

$ pod package XXLib.podspec --force

xxxxx

Tips:

1.如果iphone升级新iOS系统了,但是Xcode没有升级,这时候会报

[Could not find Developer Disk Image]

错误,如下图

Could not find Developer Disk Image

解决方法,找到一个最新版的XCode,把以下路径的iOS Support文件夹拷贝到老版本的XCode相应位置,既可
/Applications/Xcode-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/DeviceSupport
参考:栈爆网

2.有两个版本的XCode,老版本的模拟器打不开怎么办。
解决方案:
打开 Xcode -> Developer Tool -> iOS simulator (即时模拟器启动不了,Simulator.app也会启动).
在Simulator应用中,找到 Hardware -> Device -> Manage Devices.
然后在里面点加号添加想要的模拟器

参考:栈爆网

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容