target和scheme、.xcarchive和.ipa的详细解析

前言

workspace、project、target、scheme,这些基本概念非常容易混淆,特别是经常使用Xcode编译和打包的开发者,往往会忽视这些基础知识。 最近开始用xcodebuild,Xcode的可视化操作带来的便利就是对命令行的生疏,特写一篇文章来回顾下。

workspace、project、target和scheme

了解这四个基本概念,有利于理解用命令行编译的参数设置。

  • project是基本工程,包含了所有的代码文件和资源文件、以及基本的编译相关设置。project可以单独存在,也可以被包含在workspace。
  • workspace是project的管理文件,一个workspace可以包含多个project,同个workspace内的project之间可以引用。
  • target是编译目标,target会继承project的基本设置,并重新设置target相关的编译信息(主要是Build Settings 和 Build Phases)。 一个target对应一个product,一个工程里可以有多个target。target之间可以存在依赖,如果targetA依赖targetB,那么编译targetA的时候会先编译targetB。多个target只能有一个处于active状态,由Xcode的scheme决定。 如下图,圆圈所在就是编译目标,有两个target,分别是产生product和测试相关,其中的LearnAnimationTests就是依赖LearnAnimation

scheme和target

  • scheme是编译任务,配置了Build、Run、Test、Profile、Analyze、Archive相关的信息(见下图),同时可以指定运行的目标(如图中是iPhone 7 Plus) 我们可以定义多个scheme,但是只能使用一个。

.app .xcarchive 和 .ipa的区别

这三个文件都是Xcode直接产出的运行相关文件,通过指令同样可以生成这三个文件。

  • .xcarchive 是通过Xcode打包或者 xcodebuild archive打包出来的文件,里面包括了.app文件、dSYM符号文件等;
  • .ipa 是一个zip压缩包,主要有Payload文件夹,里面有.app文件,Symbols是符号文件;
  • .app 程序运行包,其中包括二进制的可执行文件以及运行所需要的资源以及plist,还有就是签名文件和privisioning file;

命令行编译

xcodebuild是命令行构建工具,接下来尝试用xcodebuild产生上面所说的.app、.xcarchive 和 .ipa文件。(苹果文档,通过在命令行输入man xcodebuild同样可以看到)

1、产生.app文件

如果工程设置的Mach-O Type设置是Executable,编译产生的就会是.app文件。 例如,我们使用Debugconfiguration设置来编译Livetarget,命令是xcodebuild -target Live -configuration Debug,结果如下:

类似,如果使用Release也可以产生.app文件,命令是: xcodebuild -target Live -configuration Release,结果如下

image.png

2、产生.xcarchive文件

xcodebuild的archive 动作(action)可以产生.xcarchive文件,下面是一个普通的archive指令: xcodebuild archive -project "LearnAnimation.xcodeproj" -scheme "LearnAnimation" -configuration Release -archivePath archive/learn.xcarchive

3、产生.ipa文件

xcodebuild的-exportArchive参数可以用来打包.ipa文件,下面是一个普通的打包指令: xcodebuild -exportArchive -archivePath archive/learn.xcarchive -exportPath App -exportProvisioningProfile "provisioning file name"

扩展内容

1、命令行修改plist参数

PlistBuddy支持修改plist,下面是一个修改指令: /usr/libexec/PlistBuddy -c "Set :TestVersion ${TestVersion}" ${infoplist_path} ${infoplist_path} 替换为自己的plist的路径。

PlistBuddy简单使用,简书上也有详细介绍的文章。

2、编译project工程和xcworkspace工程的区别

xcodebuild编译project,可添加-project projectName参数,也可以不添加 xcodebuild编译xcworkspace,需要添加-workspace workspaceName参数 如果对于缺省的参数,xcodebuild会优先使用xcode工程内的设置,再使用默认值。

3、xcodebuild编译报错library not found

ld: library not found for -lAFNetworking
clang: error: linker command failed with exit code 1 (use -v to see invocation)

报错是链接时AFNetworking找不到,检查工程设置中是否有引入AFNetworking;如果工程设置正常,那么检查AFNetworking是否为pod方式引入,如果是则xcodebuild的目标需要是xcworkspace

4、蒲公英上传ipa指令

打包出来的ipa配合下面的上传指令,可以把ipa包直接发到蒲公英上。 curl -F "file=@Live.ipa" -F "uKey=key12345" -F "_api_key=key54321" http://www.pgyer.com/apiv1/app/upload

总结

真机的代码覆盖率测试的背景驱动下,我强行对Xcode基础知识进行一遍回顾,同时也要复习bash脚本语言,然后用xcodebuild对以前的工程进行编译、打包,加深理解。 如果再有必要,搭建自动化构建的环境,应该不是难题。

bash脚本语言 workspace、project、target和scheme的官方介绍

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏云服务试衣间

三步瘦身,做名副其实的「小程序」

手把手教你使用微信小程序瘦身方案 WeCOS。腾讯云为小程序量身打造了小程序相关解决方案,帮助开发者解决小程序包超过大小限制的问题。仅需三步,即可快速使用 We...

1.3K00
来自专栏一“技”之长

获取iOS应用的URL Schemes 原

3、打开iTunes,查看应用程序,选中相应的应用程序点击右键,选择在Finder中显示,然后解压ipa文件,得到一个文件夹。

11830
来自专栏我与狸奴不出门

基于CentOS搭建微信小程序--响应错误502

在腾讯云开发者实验室的搭建微信小程序中  ,遇到了在完成实验二会话部署失败后,实验一http访问测试也显示失败并且表示响应错误-错误码:502。(域名是可以正常...

31730
来自专栏魏艾斯博客www.vpsss.net

快云小助手网页版 Linux 面板安装过程记录

前几天老魏在快云小助手(快云管理助手)windows 服务器快速部署 web 环境中提到了体验景安快云提供的 web 面板,可以提供简单的服务器管理功能,同时老...

49170
来自专栏Youngxj

YoungxjTools开源工具箱

答:项目本身支持站内站外跳转,添加新的工具箱,你只需要在网站根目录创建一个文件夹,在文件夹内部就是你的工具箱,只需要在头部插入

1K260
来自专栏菩提树下的杨过

IntelliJ IDEA 13试用手记(附详细截图)

从去年开始转java以来,一直在寻找一款趁手的兵器,eclipse虽然是很多java程序员的首选,但是我发现一旦安装了一些插件,workspace中的项目达到数...

13030
来自专栏散尽浮华

Ubuntu16.04下使用rdesktop命令远程连接windows机器

前段时间在本机安装了ubuntu16.04桌面版,后来需要远程连接一台win10系统的跳转机,下面介绍使用rdesktop命令远程连接windows机器的操作记...

15520
来自专栏韩伟的专栏

在Linux上用Eclipse写C++程序

我厂很多同学使用VC在windows上编写linux的C/C++程序,然后再传的开发服务器上,然后再编译和调试。如果有修改,可能会直接用vi去改了,然后再把源代...

47570
来自专栏進无尽的文章

Fastlane| 一句代码完成自动打包发布到蒲公英

第一个选项的意思是:自动截屏。这个功能能帮我们自动截取APP中的截图,并添加手机边框(如果需要的话) 第二个选项的意思是:自动发布beta版本用于TestFli...

21630
来自专栏PHP技术大全

grafana+ prometheus+php 监控系统实践

团队在开发流媒体服务,需要实现一个监控在线人数的功能,可以看到历史有多少人在线,当前有多少人在线的功能。 如果用mysql等关系型数据库来实现,可以用事件记录日...

34130

扫码关注云+社区

领取腾讯云代金券