在Xcode中使用Git源代码管理

Git允许您将版本控制嵌入到项目中。通过遍历提交,您可以跟踪所做的应用程序版本以及在这些提交中所做的更改。

提交到存储库时,可以使用命令行。但这有点棘手。因此,您可以使用GUI进行相同的操作。没问题。

先决条件:

  • 对Git命令有一些基本了解

术语

Commit-概念上类似于当前项目的保存或快照。您设置了一条有关已执行的更改的消息,并保存了代码的修订版,您可以单击一次随时将其还原。提交使您可以随时回到项目的此(命名)状态。

Git:Git是一个分布式版本控制系统,用于在软件开发过程中跟踪源代码的更改。

Index - 这是您要提交到git存储库的文件放置位置。也称为暂存区。

Repositories - Repositories 是一个文件位置,您可以在其中存储当前项目的所有相关文件。本地存储库位于系统上,远程Repositories (通常)位于远程计算机上。代码项目可以包含多个帐户中的多个存储库,但通常是单个帐户中的存储库。建议将存储库(也称为存储库)保持在1GB以下。

Working Directory - 文件系统中与存储库关联的目录。


Step-by-step

创建一个新的应用程序

创建一个新的Single View App。

确保已选中“ 在我的Mac上创建Git”存储库复选框(如果未选中,则可以稍后通过Xcode中的“源代码控制”菜单添加)。

查看源代码管理导航器

源代码管理导航器在屏幕的左侧:

在这种情况下,我已经扩展了文件夹,以便可以看到当前的分支。


更改文件

您可以对文件进行任何更改。我对ViewController.swift进行了一些更改,并多次执行了提交过程(如下所述),以创建多个提交。任何更改都会生效,打印命令或注释或实际工作(无论您选择什么)。

提交文件

您可以从Xcode屏幕顶部的源代码控制菜单中选择提交:

我的选择文件已在屏幕左侧修改,您可以看到对代码进行了哪些更改。

您甚至可以在屏幕左侧更改代码(如果进行更改,该代码将被带入该文件的主编辑器中,因此即使您按取消,也不会丢失任何工作)。

Choosing individual changes

可以通过选择屏幕中间的数字来进行更改

然后,您可以为每个选项选择放弃更改,或者

放弃更改也会在源文件中进行更改,因此应格外小心。

Branches

通常,您将在dev分支上工作,而在master分支上留下了您的App不断发布的版本。

Xcode屏幕左窗格中的Source Control导航器使我们可以创建新分支。右键单击提供菜单

然后我们可以从“ master”分支创建功能分支

此功能分支将自动成为当前分支,如Source Control导航器中所示

在任何时候,我们都可以通过右键单击切换分支,然后签出您要使用的分支。请注意,无论何时提交,都将提交到当前分支。

同样,您可以放弃更改(返回到先前的提交)

查看提交

要查看您的提交,您可以单击您的分支。现在,如果您已经进行了一些先前的提交,您将在屏幕中央看到它们。

右键单击其中任何一个,您都可以签出该特定的提交。

查看提交之间的差异

要查看提交之间的差异,请在文件检查器中选择您选择的文件(在我的情况下,我对ViewController进行了更改)。

现在选择菜单项:视图>版本编辑器>显示比较视图

在屏幕底部,您可以选择要选择的两个文件中的哪个

您可以单击时钟按钮,然后选择要与之比较的提交。这是查看已进行更改的好方法!

还有其他选择。您可以通过“视图”>“版本编辑器”菜单项查看日志,作者视图(向您显示更改的地方)或我们已经浏览过的比较视图。替代方法是在比较视图中选择选项(在比较视图中,屏幕右上角的箭头)。

如果继续使用比较视图,我们可以看到可以回滚到该提交中的特定更改-通过选择屏幕中间的数字并选择放弃更改。


当然,如果您进行更改,则需要提交这些更改(这将更新您的更改记录,以便团队中的每个人都可以看到您所做的更改)。

合并分支

这只有在有遥控器时才有意义。这里的想法是即使您同时也在与其他人一起处理文件。


创建repository

在github.com的右上角(假设您有一个帐户:如果没有,请先创建,然后继续阅读本指南)

创建一个名称为XcodeRepo的repository:

创建此repository:

将现有repository推送到远程存储库

我们需要复制github存储库的位置。它显示在屏幕中央

我的地址是(您的地址会有所不同!):

https://github.com/stevencurtis/XcodeRepo.git

您可以右键单击“ Remotes”文件夹并添加现有的遥控器

然后可以将遥控器添加到对话框中-但请记住,您的位置将与我的不同!点击添加...

然后转到Source Control> Push…

然后,您可以选择推送到功能分支。这将具有在远程存储库上创建功能分支的作用。

刷新Web浏览器存储库,您可以看到features分支已更新。

更改远程repository

然后,您可以在浏览器中遍历到ViewController。然后,我们将通过选择笔图标进行更改。

并且在View中确实加载了新行的更改。我选择打印“这是新行”

然后使用屏幕底部的按钮提交更改。这些可以直接提交到功能分支。

更改Xcode源代码

移到Xcode的ViewController中相同的viewDidLoad函数。

我们将输入一个新行,但打印不同的内容。

现在,我们可以通过“源代码”控制菜单来提交此更改。我称我的提交为我做。

现在,当我们尝试推送到远程服务器时,我们被告知我们的本地repository 已过时。

所以我们就这样做,并通过Source Contro> Pull

Xcode提供了我们之前进行提交时所看到的选项。但是,我们需要选择是使用左侧(本地更改)还是右侧(远程更改)。

我将选择远端(右侧)。

然后,拉动按钮变为,进行更改。


结论:总结变更

然后,您需要提交合并更改,然后将其推送到远程。(尽管在这种情况下,我是从远程进行更改的,所以没有任何可推送的内容。在Xcode中,您不会收到任何消息,因此,以防万一,习惯这样做是一种很好的做法)。


更多信息

这是其中一些功能宣布时的WWDC演示
https://developer.apple.com/videos/play/wwdc2017/405/

翻译自:https://medium.com/@stevenpcurtis.sc/using-git-source-control-with-xcode-227b4dfe5eb7

你可能感兴趣的:(在Xcode中使用Git源代码管理)