`

iOS开发那些事-Git在Xcode中的配置与使用常见问题总结

阅读更多

书接上回提出的Git在Xcode中的配置与使用常见问题4个问题

 

问题1,如何在Xcode中创建代码库,并添加和提交代码到代码库?

问题2,如何在Xcode中提交推送给远程服务器代码库?

问题3,如何在Xcode中克隆远程服务器代码库到本地?

问题4,如何使用Xcode获取远程代码库数据,并解决冲突问题?

 

1、问题1

创建代码库有两种方式,一种是新建工程时候创建,另一种是把现有的工程拷贝到代码库下,再初始化代码库。

如果是新建工程时候创建,在保存文件时候可以选择是否创建,如果勾选“Create local git repository for this project”,则就会为工程创建代码库。

 1

注意Xcode 4生成的目录结构如下:

1  HelloWorld

2 ├── HelloWorld

3 │   ├── …

4 │   ├── ViewController.h

5 │   ├── ViewController.m

6 │   ├── en.lproj

7 │   │   ├── InfoPlist.strings

8 │   │   └── MainStoryboard.storyboard

9 │   └── main.m

10└── HelloWorld.xcodeproj

11│

12└──.git

第一行的HelloWorld是工程目录也是代码库的根目录,第二行的HelloWorld目录是存放源程序目录。而我们以前的目录结构与此不同,目录结构如下所示:

1  myrepo

2└── HelloWorld

3│   ├── HelloWorld

4│   │   ├── …

5│   │   ├── ViewController.m

6│   │   └── main.m

7│   └── HelloWorld.xcodeproj

8└──.git

第一行myrepo是代码库的根目录,第二行的HelloWorld是工程目录,这样的结构可以一个代码库可以放置多个工程,是一对多的关系,而Xcode生成的方式是代码库就是工程目录,它们是一对一的关系。

如果我们还是采用一对多的关系,就不用在创建工程的时候勾选“Create local git repository for this project”选项了。这就需要将现有的HelloWorld工程拷贝到myrepo目录,在终端中执行如下命令:

$ cd ~/myrepo

$ git init

Initialized empty Git repository in  ~/.git/

初始化完成之后在添加并提交HelloWorld工程,在终端中执行如下命令:

$ git add .

$ git commit -m ‘tony init’

[master (root-commit) 98d7e4a] tony init

10 files changed, 643 insertions(+)

create mode 100644 HelloWorld/HelloWorld.xcodeproj/project.pbxproj

create mode 100644 HelloWorld/HelloWorld/AppDelegate.h

create mode 100644 HelloWorld/HelloWorld/AppDelegate.m

create mode 100644 HelloWorld/HelloWorld/HelloWorld-Info.plist

create mode 100644 HelloWorld/HelloWorld/HelloWorld-Prefix.pch

create mode 100644 HelloWorld/HelloWorld/ViewController.h

create mode 100644 HelloWorld/HelloWorld/ViewController.m

create mode 100644 HelloWorld/HelloWorld/en.lproj/InfoPlist.strings

create mode 100644 HelloWorld/HelloWorld/en.lproj/ViewController.xib

create mode 100644 HelloWorld/HelloWorld/main.m

然后就可以在Xcode中代码这个工程了。我们修改并保存文件后,会看到在导航面板中文件的后面有一个“M”图标,这说明文件修改了但没有提交。

 2

如 果只是想提交选中的文件,可以是右键菜单Source Control→Commit Selected Files…,其中的Source Control菜单都是有关代码控制的。如果想提交全部的修改文件,可以菜单File→Source Control→Commit…。然后会弹出对话框。

 3

其中有两个代码窗口,左边是本地未提交版本,右边是代码库中的版本,这里可以比较看看修改了哪些内容。在下面输入框中添加注释,点击提交按钮就可以提交了。

2、问题2

本地有代码库提交推送给远程服务器代码库,在Xcode中可以通过菜单File→Source Control→Push…进行推送,但是如果是第一次访问,会出现对话框,没有可以推送的远程服务器代码库名。

 4

我 们需要建立这个名字,在命令行中我们是通过$ git remote add hw git@192.168.1.108:myrepo创建的,其中hw就是这个名字。在Xcode中可以通过菜单Window → Organizer,选中Repositories→myrepo→Remotes,点击左下角的“Add Remote”按钮,弹出对话框,在Remote Name项目中输入remote_repo,Location项目中输入git@192.168.1.108:myrepo,完成之后点击Create按 钮创建这个名字。

 5

创建完成再重新推送,如果弹出对话框,Push按钮是可以点击的,点击Push按钮推送。

 6

3、问题3

这 个问题是从服务器代码库克隆到本地,首先需要在Xcode中添加一个远程代码库,需要通过菜单Window → Organizer进入到Repositories画面,点选左下角的“+”按钮,选择Add Repository,在Location项目中输入git@192.168.1.108,Type项目选择Git,Name项目会自动添加,如果 Authentication required为变为黄色小点,说明配置连接没有问题,然后点击Add按钮创建。

7

如果创建成功,就会出现在左边代码库列表中,请选择刚才创建的代码库,然后选择下面的Clone按钮,并选择本地保存位置。

 8

4、问题4

如果服务器代码有新的版本,获取远程代码库数据到本地,可以通过菜单File→Source Control→Pull…。然后会弹出对话框。选择Choose按钮就可以获取新的版本了。

9

如果这个过程中有冲突发生,会弹出对话框在两个代码窗口中可以看到它们的冲突点,

10

下面的4个按钮,可以把冲突点进行合并,并进行编辑。如果没有冲突,Pull是可以点击,点击Pull按钮就可以了。

分享到:
评论

相关推荐

    IOS开发Git在Xcode开发环境下的使用

    通过以上步骤,您可以在Xcode开发环境中配置并使用Git进行iOS项目的版本控制。掌握这些基本操作对于提升个人技能和提高团队协作效率都具有重要意义。随着实践经验的积累,您可以进一步探索Git更高级的功能,如分支...

    Xcode模拟器下载地址(iOS 8 - iOS 12)

    4. **启动Xcode并使用**:安装完成后,在Xcode中即可看到新增加的iOS版本,并可用于创建和测试虚拟设备。 #### 四、提供的iOS版本 本文档列出了从iOS 8至iOS 12期间的各个小版本模拟器的下载地址,具体包括: - *...

    iOS git 配置文件

    在iOS开发过程中,版本控制是不可或缺的一环,Git作为最常用的分布式版本控制系统,为我们提供了强大的代码管理和协作功能。本文将详细讲解如何在iOS项目中配置Git,特别是针对大文件的处理以及忽略特定文件的设置。...

    xcode Command-Line-Tools-macOS-10.14-for-Xcode-10.1.rar

    本文将详细阐述Xcode的Command-Line-Tools在macOS 10.14系统中的作用、安装与使用方法,并探讨其在日常开发中的重要性。 一、Command-Line-Tools概述 Command-Line-Tools for Xcode是一系列轻量级的开发工具集合,...

    iOS开发—环境准备1—Xcode集成开发环境的安装使用与项目建立流程视频教程下载(8课程).txt

    ### iOS开发—环境准备1—Xcode集成开发环境的安装使用与项目建立流程 #### Xcode简介 Xcode是苹果公司为开发者提供的官方集成开发环境(Integrated Development Environment, IDE),主要用于开发iOS、iPadOS、...

    Xcode配置iOS15.4开发包DeviceSupport

    在iOS应用开发中,Xcode是苹果官方提供的集成开发环境(IDE),用于编写、调试和发布iOS和macOS应用程序。当开发者需要支持新的iOS版本时,例如iOS 15.4,他们必须确保Xcode中包含了相应的“DeviceSupport”文件。这...

    很好用的Xcode qmui-ios-codesnippets

    总之,"qmui-ios-codesnippets"是QMUI框架开发者不可或缺的工具,它通过集成在Xcode中,使得QMUI的使用更加顺滑高效。无论你是正在学习QMUI,还是已经在项目中广泛使用,这套代码片段库都能让你的工作变得更加轻松。...

    iPad iOS 4 App开发要点-Xcode 4版iPad iOS 4 App development Essentials - Xcode 4 Edition

    本篇内容将聚焦于iPad上运行的iOS 4应用程序开发的核心知识点,特别强调在Xcode 4这一集成开发环境下的开发流程和技术细节。 #### iOS 4简介 iOS 4是苹果公司在2010年推出的操作系统版本,主要针对iPhone、iPod ...

    VVDocumenter-Xcode xcode6 亲测

    此外,VVDocumenter-Xcode的使用并非孤立的,它可以与其他代码管理和版本控制工具如Git、SVN等配合使用,进一步提升团队开发的效率。在注释完成后,这些注释可以被集成到项目文档中,提供完整的API参考,方便团队...

    Xcode根据编译次数自动增加Build属性(Xcode自带功能实现)

    在软件开发中,特别是在iOS应用开发中,使用Xcode作为主要的开发环境,开发者需要管理不同版本的构建(Build)。通常情况下,每次编译应用时,开发者会手动增加Build版本号来区分不同版本的构建,以便于内部测试和...

    Xcode iOS10.0配置包

    在本文中,我们将深入探讨Xcode iOS 10.0配置包的细节,以及如何有效地利用它进行iOS应用开发。 首先,我们要明白Xcode 10.0是一个重要的版本,因为它支持iOS 10.0操作系统。iOS 10带来了许多显著的更新,包括用户...

    ios开发 Xcode ios12.0 (16A5308d)支持包

    在实际开发中,使用Xcode的版本管理功能,如Git,可以帮助开发者跟踪代码变更,协作开发,以及回滚到之前的稳定状态。此外,Xcode的调试工具,如断点、变量查看器和内存泄漏检测,都是定位和解决问题的关键。 总之...

    IOS应用源码Demo-电子书阅读器 - iOS PDF Reader-毕设学习.zip

    这个项目可能包含了一个完整的PDF阅读器应用的实现,适合初学者或开发者了解如何在iOS平台上开发类似的应用。 【描述】提到该源码是“前两年”的,这意味着它可能基于较早版本的Xcode(4.2)和iOS(5)。虽然技术...

    Git、github与Xcode的配合使用

    Git是一个版本控制系统,由Linus Torvalds开发,最初用于管理Linux内核代码,后来发展成为几乎所有开发者都会使用的版本...这些功能可以帮助开发者在Xcode中直接使用Git进行版本控制操作,提高开发效率和协作便利性。

    Jenkins项目实战之-xcode+jenkins自动化打iOS包.rar

    在IT行业中,持续集成(Continuous Integration,CI)和持续部署(Continuous Deployment,CD)是现代软件开发的关键实践,它们能够显著提高开发效率和代码质量。本篇将详细讲解如何使用Jenkins结合Xcode进行iOS应用...

    xcode 15.4 真机调试包

    Xcode 15.4 真机调试包是一个针对苹果开发者的重要工具,它允许开发者在实际设备上测试和调试iOS、iPadOS、macOS、tvOS以及watchOS应用程序。这个版本的Xcode包含了编译器、模拟器、界面设计工具、性能分析工具等一...

    iOS-Tagent-master.zip

    网易airtest for mac必备agent, iOS-Tagent 其实就是 WebDriverAgent 仔细看,会发现iOS-Tagent会比WebDriverAgent简略得多。 iOS-Tagent其实就是WDA的优化版本。 git clone ...

    基于IOS平台(object-c)的游戏五子棋程序设计

    2. **MVC设计模式**:在iOS开发中,Model-View-Controller (MVC) 是一种常见的架构模式。在这个五子棋游戏中,模型负责游戏规则和逻辑,视图处理用户界面的显示,控制器则协调模型和视图的交互。 3. **用户界面设计...

    IOS应用源码Demo-记事本界面-毕设学习.zip

    在iOS应用开发中,记事本界面是一种常见的功能模块,常用于实现用户记录文本信息的需求。这个"IOS应用源码Demo-记事本界面-毕设学习.zip"压缩包提供了一个示例,非常适合那些正在进行iOS毕业设计或者希望深入理解iOS...

Global site tag (gtag.js) - Google Analytics