你的位置:首页 > 操作系统

[操作系统].xcodeproj目录中各文件


转自:http://blog.csdn.net/lixing333/article/details/47700687

在iOS多人协同开发时,一般会使用版本管理工具,比如SVN/Git。
经常的,在提交修改的时候,除了我们自己主动修改的.h、.m和资源文件之外,还会出现一些莫名其妙的文件,在.xcodeproj里面,如下图:
这里写图片描述

.xcodeproj是项目文件,包含项目配置文件,这是很多人都知道的。然而,.xcodeproj里面的各个文件都有什么用呢?提交版本时,要不要提交这些文件/目录?下面总结一下。

一个xcodeproj文件,其实是一个目录,它的格式大体上是这样的:
这里写图片描述

有的文件,比如user.mode1v3,在没有多个用户操作项目的时候,是没有的。Apple并没有提供.xcodeproj文件的文档,而且它也没有准备提供,更坑爹的是,xcodeproj的格式、内容都是随时可变的,比如一个Xcode版本上来,可能其目录就会变化,而没有任何通知。这可苦了那些为.xcodeproj开发每三方库的同学,不仅要一点一点摸索各个文件的内容,修改方法,还要忍受Apple没有任何通知地修改格式。Stackoverflow中这位就在抱怨苹果开发人员的傲慢:http://stackoverflow.com/questions/49478/git-ignore-file-for-xcode-projects/12021580#12021580
闲话少说,下面进入正题:各个文件/目录的作用,以及要不要提交更新。

  1. project.pbxproj文件
    这个文件包含了所有此项目build需要的元数据,setting、file reference、configuration、targets…也就是说,这个文件代表的就是这个project。
    因此,在修改了这个文件之后,需要提交上去。

  2. project.xcworkspace目录
    这个文件比较特殊。
    首先要了解的是workspace和project的概念。project应该比较清楚,那workspace是什么呢?workspace是一种Xcode documentation,可以将多个project和其它文件放到一起,这样可以work on them together。一个project也可以属于多个workspace。所以简单来讲,workspace里面就是一个或多个projects的reference,放在一起,有时候比较好工作。
    这样的话,如果项目里面根本就没有workspace的概念,或者只有一个workspace+一个project,这个workspace并不会有什么变动,那这个文件就不需要提交同步。如果project很依赖workspace,没有workspace就运行不了,活不下去了,这时候这个文件肯定是要同步的。

  3. user.pbxuser文件
    Xcode项目为每一个使用这个项目的用户创建一个user.pbxuser文件,存储了此用户对项目的偏好设置,如Xcode的位置和大小、文件书签等。可以看到这个文件是针对某个用户的,可以说是私人性质的,跟整个项目没有太大关系,所以一般不需要同步。

  4. user.mode1v3和user.mode2v3文件
    这个也是用户相关的文件,和user.pbxuser差不多,存储某用户特定的项目设置,比如Xcode中window的状态和结构,断点等等。
    因此也不需要同步。

  5. xcuserdata目录/xcshareddata目录:
    大体上来说,和上面两种一样,也是用户相关的文件,包含user state,folders的状态,最后打开的文件等。因此一般来说是不需要同步的。
    例外是,这个目录里也包含了scheme相关的内容。如果项目里需要同步特定的scheme,这时候,需要在Edit Scheme里,勾选Share框,然后把新生成的xcshareddata目录提交上去。

  6. .xccheckout
    我没有碰到过这个文件。
    这个文件在xcworkspace目录里。
    .xccheckout文件包含了关于workspace中用到了什么repo的数据。
    根据说明,它的规则和xcworkspace差不多:如果没用过,或者只是简单使用workspace,不需要同步;如果深入使用workspace,则需要同步。

总结1:
.xcodeproj里的文件大体上有3种:

  • 项目文件
  • 单个用户的文件
  • 跟workspace相关的文件

项目文件,需要同步;
单个用户的文件,不需要同步;
跟workspace相关的文件,视有没有深入使用workspace而定。

总结2:

    1. 需要同步的文件:

      • project.pbxproj文件
      • xcsharedata目录
    2. 不需要同步的文件

      • user.pbxuser文件
      • user.mode1v3/user.mode2v3文件
      • xcuserdata目录
    3. 视workspace情况而定的文件:

      • .xcworkspace目录
      • .xccheckout文件

问题:.xccheckout' remains in conflict 

解决:在终端下到达特定路径xxx.xccheckout文件,在终端下执行svn resolved xxx.xccheckout命令,成功之后会得到一SVN消息“conflict resolved on this file”。