码云 podspec项目管理

利用了两天时间建八个测试项目各种报错,今天终于有所收获,此文章贡献给和我一样还在摸索的人,希望能有点帮助,也便于以后查阅!

大致步骤:

1、利用码云新建一个项目,以及ssh密钥等配置

2、创建并设置一个私有的Spec Repo

3、创建pod所需要的项目工程文件

4、验证本地配置的podspec文件是否可用

5、测试

6、更新维护podspec

7、小偏方

第一:利用码云新建一个项目,以及ssh密钥等配置 参考码云基本操作,创建成功后的项目。

码云 podspec项目管理_第1张图片

第二:创建并设置一个私有的Spec Repo

在码云中打开创建的项目工程,页面右边会有克隆/下载按钮,点击复制HTTPS地址

码云 podspec项目管理_第2张图片

打开Terminal,执行如下命令

命令格式# pod repo add [Private Repo Name(最好和项目名保持一致)] [码云HTTPS clone URL]

$ pod repo add TestTools https://git.oschina.net/helen_add/testtools.git

详情:如果有遇到需要输入username和password的输入回车就可以了

YRdeMacBook-Air:~ yr$ pod repo add TestTools https://git.oschina.net/helen_add/testtools.git

Cloning spec repo `TestTools` from `https://git.oschina.net/helen_add/testtools.git`

检查是否安装成功

$ cd ~/.cocoapods/repos/TestTools

$ pod repo lint .   (注意:“ .” 不能省略)

第三:创建Pod项目工程文件

将路径切换到放项目的文件夹下:

$ cd /Users/yr/Desktop/T9   (没错这是我创的第九个测试文件)

$ pod lib create TestTools    创建pod文件

创建过程中需要回答问题

What language do you want to use?? [ Swift / ObjC ] 直接输入Objc  不输入直接回车默认选择第一个,以下几个问题都是。

Would you like to include a demo application with your library? [ Yes / No ] 

Which testing frameworks will you use? [ Specta / Kiwi / None ]

Would you like to do view based testing? [ Yes / No ]

What is your class prefix?

问题回答:Objc - Yes - Specta - Yes - TT (供参考)

为了模拟代码提交过程,这里利用Xcode新建了一个.m和.h文件,在.m文件中随便写了几句代码,找到下面文件路径,将创建的.m和.h文件放到Classes文件夹下


码云 podspec项目管理_第3张图片

将路径切换到Example文件夹下,执行pod install,用xcode打开Example下的pod管理的项目,根据下图路径查看,你会看到放Classe下的文件,到了Demo的pod中,这只是本地的成功。

插句嘴:每当你向TestTools中添加了新的文件或者以后更新了podspec的版本都需要重新执行一遍pod update命令。

码云 podspec项目管理_第4张图片

继续将本地仓库关联到远程仓库,一步步执行下面命令

$ cd /Users/yr/Desktop/T9/TestTools       切换到项目目录下

$ git add .

$ git commit -s -m "Initial Commit of Tools"

$ git remote add origin https://git.oschina.net/helen_add/testtools.git  (之前复制的码云中的下载地址)

$ git push -u origin master    //报错  

报错信息:

To https://git.oschina.net/helen_add/testtools.git

! [rejected]        master -> master (fetch first)

error: failed to push some refs to 'https://git.oschina.net/helen_add/testtools.git'

hint: Updates were rejected because the remote contains work that you do

hint: not have locally. This is usually caused by another repository pushing

hint: to the same ref. You may want to first integrate the remote changes

hint: (e.g., 'git pull ...') before pushing again.

hint: See the 'Note about fast-forwards' in 'git push --help' for details.


继续执行

$ git fetch

$ git push --force origin master    //直接强推,成功

信息:

Counting objects: 241, done.

Delta compression using up to 4 threads.

Compressing objects: 100% (230/230), done.

Writing objects: 100% (241/241), 122.05 KiB | 0 bytes/s, done.

Total 241 (delta 49), reused 0 (delta 0)

To https://git.oschina.net/helen_add/testtools.git

+ dc12b7c...ccb5dae master -> master (forced update)

完成后可以去码云查看工程

码云 podspec项目管理_第5张图片

第四、验证本地配置的podspec文件是否可用

因为podspec文件中获取Git版本控制的项目还需要tag号,所以先打个tag

$ git tag -m "first release" 0.1.0

$ git push --tags  推送tags到远程仓库

$ git tag    查看tag

接下来podspec文件的编写,根据下面路径找到podspec文件,双击打开

码云 podspec项目管理_第6张图片

如下图,简单设置需要更改的地方,设置homepage通过前提是你的项目是公开的,更多配置信息可以参考podspec文件配置

码云 podspec项目管理_第7张图片

设置完成后继续执行,检查podspec是否可用

$ pod lib lint

成功输出:

-> TestTools (0.1.0)

TestTools passed validation.

如果有错误,根据提示一一修改

将修改的文件提交到远端仓库

$ git add .

$ git commit -m "set podsepc"

$ git push --set-upstream origin master

5、测试,能否将穿件的TestTools通过pod拉取到项目中,在一个pod管理的项目,打开podfile,加入

pod ’TestTools’, :git=>’[email protected]:helen_add/testtools.git’

执行pod install,打开项目,在pods下会看到刚添加的TestTools成功!


码云 podspec项目管理_第8张图片

6、维护和更新

如果想加入一个装icon的文件夹,直接把文件拖到和Classe同级


码云 podspec项目管理_第9张图片

重新打卡TestTools.podspec文件,然后重新上传修改的文件代码到远端仓库,在使用pod install更新就可以使用添加的图片啦!文件夹为空编辑 pod lint lib  会报错   

码云 podspec项目管理_第10张图片

附上demo地址:码云地址

7、还有这样的操作!!!

编译podspec时候可以先不在Classes里面放代码  等编译通过  提交成功 可以从pod上拉这个库后 再在Classes中添加你的库代码  这样做的好处就是podspec文件配置内容后 执行pod lib lint 时候非常容易报错  要求代码可以正常运行  但是等你podspec可是正常使用成后直接提交代码到git上就可以了 错误代码也没关系  (偏方)

你可能感兴趣的:(码云 podspec项目管理)