在iOS开发者一般引用第三方插件的方式有两种:
1. 使用coacoapods
进行依赖。
pod '库名'
pod '库名', '~> 版本号'
pod '库名', :git => 'https://xxx.git'
pod '库名', :path => '../'
这几种是使用pod进行依赖三方库的常用写法。
2. 使用swiftPM
进行依赖。
就像这种。
我们并不需要为swiftPM
单独创建一个仓库。可以在已有的三方库基础上,升级为支持swiftPM
引入。
首先这个一个已存在的library的目录。
我们需要在根目录下添加一个文件: Package.swift
。
如果你没有这个文件,可以去其他的比较知名的仓库复制一个,比如 MBProgressHUD
MJRefresh
还有其他更大的库,基本上都是配置了的。
来展示一下最基础的配置。
1. 这是你的包名,可以自定义,一般都是库名的小写。
2. 库名,在文件中 'improt 库名'
3. products和targets, 可以看到这是一个数组,也就代表它可以同时设置多个,但是我们只有一个。如果你对多个感兴趣,请移步[firebase](https://github.com/firebase/firebase-ios-sdk/blob/main/Package.swift)。
4. 你的库中需要依赖的其他库,'url'是该库的homepage地址。'from'参数一般是指定某个版本。"值得注意的是,如果你引用的三方库并没有配置swiftPM,我们可以这里进行引用,但是下面6却依赖不了,还是不能使用的。"
5. 上面的'products'下属的'targets'的具体配置,我们只有一个'LNTools_fyh',要指定它的路径和依赖项。
6. 在上面'4'的'dependencies'中,我们添加了两个库,在这里我们要将依赖添加到具体的'target'里面。
7. 'path'参数就是我们的源文件的路径。如果我们还有更深一层,那就是'LNTools_fyh/xxx'
如果你的库没有特殊的结构和文件,这个是基本满足需求的。
如果你的库中包含了framework:
包含了其他文件。
和coacoapods
库的pod repo push
一样,我们在配置完成之后,更改spec
文件版本号,提交git
,添加tag
,push
到远程仓库。
我们的配置就算结束了。
然后就是引用。
还有,我们在配置swiftPM
的时候并不能同时使用两种语言混编(Swift & Objective-C
),要么删掉OC
部分,要么改成swift
编写。