2019-01-30

转载自https://www.jianshu.com/p/a282489a6cfb

这个我是为了保存.

[Git] Xcode9 版本控制管理Git<图文教程>

 

流火绯瞳 关注

2017.12.06 11:24* 字数 2603 阅读 5271评论 10喜欢 35

一. 前言

在Xcode9中重新定义了其自带的Git, 使版本管理更加的方便:

在左侧资源导航区块, 多了个 Source Control navigator 选项, 用于本地的Git仓库管理;

2019-01-30_第1张图片

如果没有添加Git仓库, 这里是没有东西的:

2019-01-30_第2张图片

二. 本地项目版本控制

2.1 添加Git管理

2.1.1 方式一

对项目添加Git管理支持, 可以在新建项目最后一步选择保存位置的时候勾选Create Git respository on my Mac 选项:

2019-01-30_第3张图片

2.1.2 方式二

也可以通过终端对现有项目来添加仓库:

如果本地没有安装Git, 可参考 [Command Line]使用Command Line(终端)提交代码到远程库 如何添加Git.

通过 cd 指令, 进入到文件的根目录:

cd/Users/mac/Desktop/WKWebTest

然后通过 git init 指令来初始化一个Git本地仓库:

git init

然后通过 git add 指令, 添加文件到本地仓库:

git add .

最后的 点(.) 意思是将所有的文件都添加到Git仓库;

最后通过 git commit 指令提交:

git commit -m"提交"

后面是添加提交说明;

这样就建立了一个本地仓库:

2019-01-30_第4张图片

2.1.3 方式三

也是最简单的方式:

在Xcode菜单栏: Source Control -> Create Git Repositories...

2019-01-30_第5张图片

新建Git仓库

一般使用第一种来为新的项目添加Git管理, 使用第三种对已有项目添加Git管理.

添加Git管理后, 打开 Source Control navigator 会看到三个文件夹:

Branches : 所有分支

Tags : 所有标签

Remotes : 远程仓库

need-to-insert-img

开始只有Branches文件夹下有一个主分支(master), 其他两个文件夹都是空的;

2.2 Commit 提交更改

接下来, 我们修改一下代码, 这里我在ViewController类里面打印了一句话, 并新加了一个People类:

2019-01-30_第6张图片

这时, 会看到文件导航栏中, 文件名称后面有点小小的变化:

2019-01-30_第7张图片

M : 修改的文件, 未提交, 这里是ViewController.swift文件

A : 新加的文件, 未添加到Git管理; 这里是People.swift文件

然后点击导航 Source Control -> Commit...

2019-01-30_第8张图片

在弹出的页面中, 可以看到所做的更改:

2019-01-30_第9张图片

最左边是变动的文件列表, 中间部分的左半边是文件变动之后, 右边边是文件变动之前, 下面的空白区域是填写提交的变更信息;

如果有多处变更, 我们不想一同提交, 可在最左侧选择要提交的文件, 同一文件里不同的代码选择可以在中间部分选择:

2019-01-30_第10张图片

这里可以选择不提交, 或者取消更改;

然后点击Commit 3Files 即可!

提交成功后, 会看到主分支多了一个版本记录:

2019-01-30_第11张图片

2.3 分支(Branch)管理

2.3.1 新建分支

在需要新建分支的分支上右键(开始是在master主分支上) -> Branch from ""...

2019-01-30_第12张图片

然后填写分支名称即可!, 这里我起的名称是 "第一个分支"

2019-01-30_第13张图片

由上图可知, 新建了一个分支, 并且当前分支切换到新建的这个分支上面来了, 注意分支名称后面的 current , 代表当前所处的分支! 这里所处的分支即为: 第一个分支!

此时提交的更改就会提交到这个分支上面

2.3.2 切换分支

分支间切换, 可在需要切换的分支上右键 -> Checkout

如下图所示, 当前分支是在 "第二个分支", 下面我切换到主分支(master)

2019-01-30_第14张图片

选中master分支 -> 右键选择Checkout

2019-01-30_第15张图片

会弹出是否切换的提示框, 选择 Checkout 即可!

如果在切换时, 弹出下面的提示:

need-to-insert-img

这是因为, 当前所处的分支上有更改还未提交, 需要先提交了, 才能切换, 只需要 Source Control -> Commit..., 提交一下, 就能正常切换了. 如果当前的更改不需要提交, 或者不打算要的更改, 可以放弃当前的更改: Source Control -> Discard All Changes...

need-to-insert-img

放弃(discard)更改

然后, 就可以正常切换了!!!

2.3.3 合并分支

分支的合并只能是各子分支与主分支之间进行!

将分支合并到另一个分支上, 只需要在需要合并的分支上右键 -> 选择 Merge "分支名称" into "另一个分支名称"

例如这里将"第二个分支" , 合并到 "主分支" :

need-to-insert-img

合并分支

也可以选择 "Merge 'master' into '第二个分支'..." 来将主分支的一些更改合并到"第二个分支" 上来!

2.3.4 删除分支

在新建的子分支上(主分支master是不能删除的)右键, 可以选择删除该分支:

need-to-insert-img

删除分支

2.3.5 合并分支冲突解决

在合并分支的时候, 难免会有冲突, 如果发生冲突, 会显示如下图所示的页面:

need-to-insert-img

冲突

左侧是文件列表, 有冲突的文件旁边会有个红色的C, 中间部分是具体的冲突内容, 左侧为本地版本, 右侧为合并过来的分支版本, 带问号的需要你选择使用本地版本还是使用合并过来的, 选中某个冲突(带问号的哪一行, 如图中红色背景部分), 这时, 最下面中间部分有四个选项, 第一第四个都是保留两个版本, 第二个是使用本地版本(即左侧), 第三个是保留合并而来的分支版本(右侧), 这时做个选择即可, 图中4/4, 是共有几处冲突, 当前处在第几个冲突; 而且此时的Merge按钮是不可点击的, 当所有的冲突解决之后, 该按钮即变为可点击状态.

need-to-insert-img

2.4 添加Tag

如果我们想对一些提交或者分支, 添加一些标记, 可以使用Tag:

在想要添加tag的commit或者分支上右键:

在提交(Commit)记录上添加Tag:

need-to-insert-img

在提交(Commit)记录上添加Tag

选择 Tag"a720618"... , 在弹出的选项卡内填上tag名称和说明:

need-to-insert-img

新建Tag

这时, 提交的版本旁便有了一个tag标签:

need-to-insert-img

左侧Tags文件夹内, 就多了一个Tag记录.

也可以在分支上添加Tag, 方法是一样的, 在要添加tag的分支上右键 -> 选择 Tag "第二个分支"...

need-to-insert-img

在所选的tag上右键, 可以选择删除/添加新的tag或者分支等操作!!!

2.5 更改管理

2.5.1 取消更改

如果我们做的更改, 不想提交, 可在 Source Control 中选择放弃某个文件的更改: Discard Changes in "文件名称"...

或者选择放弃所有的更改: Discard All Changes...

2019-01-30_第16张图片

也可以在提交界面进行舍弃(Discard):

2019-01-30_第17张图片

注意: 这里的取消, 会删除这些文件, 或者这些的更改的代码!!!

如果仅仅只是不想提交, 但是还想保留这些更改的代码, 可以在提交界面进行选择不提交:

2019-01-30_第18张图片

2.5.2 恢复到某次提交

如果想要将代码退回到某个版本, 只需要在要退回的版本右键 -> Checkout "***"... 即可将代码恢复到某此提交的版本:

2019-01-30_第19张图片

2.5.3 多个版本比较

如果想查看某个文件的更改记录, 什么时间增加了什么内容, 可以选择这个文件, 然后打开Show the Version editor, 即下面这个反方向的双箭头:

2019-01-30_第20张图片

例如, 这里查看People类的相关更改:

2019-01-30_第21张图片

左半边是现在最新的内容, 右半边是某个提交版本的内容, 具体哪个版本的提交, 可以在下面进行选择, 即右下角的那里!

Log

也可以查看所有的Log: 点击 Show the Version editor 右下的倒三角, 选择 Log :

need-to-insert-img

这时屏幕中间部分的右半边会显示Log信息:

need-to-insert-img

点击, Show modified files 会显示两个版本的具体不同部分, 界面和上面类似!

Blame

同样在Show the Version editor 可打开Blame页面, 这里可以查看, 谁在什么时候做了哪些更改, 可用于责任定位:

need-to-insert-img

当鼠标放到右侧各行时, 会有一个更多信息的符号i 点击后打开是这样的:

need-to-insert-img

Show modified files 和 Open in Comparison 都是可以点击查看具体的更改内容的!!!

2.6 忽略配置文件.ignore

Git 提供了一个机制去忽略这些文件:这类文件后缀名为 .gitignore 。

这个文件不需要我们手动去写, 可以按如下方法下载:

打开终端输入:

git config --globalalias.ignore'!gi() { curl -L -s https://www.gitignore.io/api/$@ ;}; gi'

这样对于任何使用 Git 的工程,只需要输入以下命令行(如果是OC项目,将下面代码的swift 替换为 Objective-C )就可以下载一个.ignore文件:

首先cd到文件根目录:

cd/Users/mac/Desktop/GitTest

然后接着输入以下指令:

gitignoreswift,macos>.gitignoregitadd.gitignoregitcommit-m"Add.gitignorefile"

这时, 再去查看项目文件夹, 会发现多了一个.ignore文件, 当然这个文件是隐藏的, 也可看不到:

need-to-insert-img

三. 远程项目版本控制

3.1 绑定Github账号

新版的Xcode9 与Github深度整合, 现在可以在Xcode -> Preferences 中添加Github账号, 点击左下角的 "+" 在弹出的列表中选择 Github :

need-to-insert-img

然后输入账号和密码, 即可!!!

need-to-insert-img

3.2 将项目上传到Github

现在将项目上传到Github的时候, 只需要在Source Control navigator页面操作即可, 选择项目文件夹(蓝色那个) -> 右键 -> Create "GitTest" Remote on Github...

其中 GitTest 为项目名称;

need-to-insert-img

然后在弹出的页面中填写相关的信息:

need-to-insert-img

主要是选择账号, 项目名称, 说明等, 点击 Create 即可!

PS: 如果这里一直创建失败, 可能是远程仓库名称冲突了, 换个名称提交即可!

完成后来到你的Github账号, 就会看到刚刚提交的项目:

need-to-insert-img

屏幕快照 2017-12-06 上午11.02.22.png

3.3 Push & Pull

远程仓库建立之后, 更改只要执行一次Push即可:

2019-01-30_第22张图片

与远程版本同步可执行Pull

3.4 从Github克隆(clone)到本地

在Xcode导航栏, 选择 Source Control -> Clone...

2019-01-30_第23张图片

屏幕快照 2017-12-05 上午11.25.06.png

所有你账号下的项目都会出现在这里, 选择自己需要的点击clone:

2019-01-30_第24张图片

屏幕快照 2017-12-05 上午11.24.56.png

最后选择一个保存位置, 即可!!!

你可能感兴趣的:(2019-01-30)