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

简介: <p>书接上回提出的Git在Xcode中的配置与使用常见问题4个问题</p><p><span id="more-255"></span></p><p>问题1,如何在Xcode中创建代码库,并添加和提交代码到代码库?</p><p>问题2,如何在Xcode中提交推送给远程服务器代码库?</p><p>问题3,如何在Xcode中克隆远程服务器代码库到本地?</p><p>问题4,如何使用Xco

书接上回提出的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按钮就可以了。

目录
相关文章
|
3月前
|
存储 安全 开发工具
Git安装与配置:操作步骤+Gitee绑定
本文系统介绍了Git从安装配置到远程协作的全流程,涵盖基础概念、常用命令、分支管理、冲突解决及Gitee实战操作,助你高效掌握代码版本控制与团队协作技巧。
608 155
|
4月前
|
网络安全 开发工具 git
配置本地环境以管理Git多账户SSH连接的方法
通过以上步駟设置后, 您可以轻松管理多個 Git 账户并且根据不同项目需求切换 SSH 密匙进行版本控制操作。
356 20
|
4月前
|
存储 Java 开发工具
【Git】零基础入门:配置与初始操作实战指南
本文聚焦 Git 的“从 0 到 1”配置与基础操作,旨在帮助 Java 开发者快速掌握环境搭建、用户配置、仓库初始化、代码提交、版本回退等核心技能。内容设计上避免涉及复杂的分支策略或高级命令,以实用为导向,适合零基础入门者系统学习,为后续参与企业级项目开发奠定版本控制基础。
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
736 67
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
7月前
|
安全 Shell 开发工具
Windows下使用git配置gitee远程仓库
就在前几天因为一些原因,我的电脑重装了系统,然后再重新配置git的环境的时候就遇到了一些小问题。所以我决定自己写一篇文章,以便以后再配置git时,避免一些错误操作,而导致全网搜方法,找对的文章去找对应的解决方法。下面为了演示方便就拿gitee来演示,不拿GitHub了写文章了。
346 0
|
9月前
|
安全 Linux 网络安全
在Linux(CentOS和AWS)上安装更新的git2的方法并配置github-ssh
经过以上这些步骤,你现在就能在GitHub上顺利往返,如同海洋中的航海者自由驰骋。欢迎你加入码农的世界,享受这编程的乐趣吧!
396 10
|
11月前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
441 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
366 66
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
1361 11
|
11月前
|
人工智能 程序员 API
iOS|记一名 iOS 开发新手的前两次 App 审核经历
啥,这玩意也有新手保护期?
338 0

热门文章

最新文章