×
广告

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

96
孢子菌
2016.08.31 12:10* 字数 1520

创建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.
然后在里面点加号添加想要的模拟器

参考:栈爆网

平日小问
Web note ad 1