美文网首页闻道丶iOS(大杂烩)iOS OC 学习手册iOS 开发
创建自己的pod库和打包静态链接库.a

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

作者: 孢子菌 | 来源:发表于2016-08-31 12:10 被阅读1956次

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

    参考:栈爆网

    相关文章

      网友评论

      • 3e8eb14bdf82:正在尝试你下载ios9.3的系统,来安装iPhone 4s 模拟器,用了最贵的vpn,依旧只用200k,WTF
        3e8eb14bdf82:@孢子菌哈哈,搞定了,用迅雷下的dmg,然后移到Xcode下载文件夹下,再从Xcode里下载,一会就好了
        孢子菌:坚持就是胜利:yum:
      • NSBug:请问4s模拟器那个问题怎么解决的
        NSBug:@孢子菌 我把cocoapods更新到最新版本就解决了,感谢大神
        孢子菌:先在xcode设置里下载了一个老版本的支持iphone4的ios sdk,然后新建一个device,类型选择iphone4就可以了
      • aff99d7a6dd7:我也遇到你的问题 不过还没有解决 加个QQ被 咨询一下 我的 1073856565 或者我加你也好
        孢子菌:@来自天堂的白魔鬼 遇到的是哪个问题?

      本文标题:创建自己的pod库和打包静态链接库.a

      本文链接:https://www.haomeiwen.com/subject/obdgsttx.html