书接上回提出的Git在Xcode中的配置与使用常见问题4个问题
问题1,如何在Xcode中创建代码库,并添加和提交代码到代码库?
问题2,如何在Xcode中提交推送给远程服务器代码库?
问题3,如何在Xcode中克隆远程服务器代码库到本地?
问题4,如何使用Xcode获取远程代码库数据,并解决冲突问题?
1、问题1
创建代码库有两种方式,一种是新建工程时候创建,另一种是把现有的工程拷贝到代码库下,再初始化代码库。
如果是新建工程时候创建,在保存文件时候可以选择是否创建,如果勾选“Create local git repository for this project”,则就会为工程创建代码库。
注意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”图标,这说明文件修改了但没有提交。
如 果只是想提交选中的文件,可以是右键菜单Source Control→Commit Selected Files…,其中的Source Control菜单都是有关代码控制的。如果想提交全部的修改文件,可以菜单File→Source Control→Commit…。然后会弹出对话框。
其中有两个代码窗口,左边是本地未提交版本,右边是代码库中的版本,这里可以比较看看修改了哪些内容。在下面输入框中添加注释,点击提交按钮就可以提交了。
2、问题2
本地有代码库提交推送给远程服务器代码库,在Xcode中可以通过菜单File→Source Control→Push…进行推送,但是如果是第一次访问,会出现对话框,没有可以推送的远程服务器代码库名。
我 们需要建立这个名字,在命令行中我们是通过$ 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按 钮创建这个名字。
创建完成再重新推送,如果弹出对话框,Push按钮是可以点击的,点击Push按钮推送。
3、问题3
这 个问题是从服务器代码库克隆到本地,首先需要在Xcode中添加一个远程代码库,需要通过菜单Window → Organizer进入到Repositories画面,点选左下角的“+”按钮,选择Add Repository,在Location项目中输入git@192.168.1.108,Type项目选择Git,Name项目会自动添加,如果 Authentication required为变为黄色小点,说明配置连接没有问题,然后点击Add按钮创建。
如果创建成功,就会出现在左边代码库列表中,请选择刚才创建的代码库,然后选择下面的Clone按钮,并选择本地保存位置。
4、问题4
如果服务器代码有新的版本,获取远程代码库数据到本地,可以通过菜单File→Source Control→Pull…。然后会弹出对话框。选择Choose按钮就可以获取新的版本了。
如果这个过程中有冲突发生,会弹出对话框在两个代码窗口中可以看到它们的冲突点,
下面的4个按钮,可以把冲突点进行合并,并进行编辑。如果没有冲突,Pull是可以点击,点击Pull按钮就可以了。
相关推荐
从零来讲如何在xcode下,来配置git
Xcode 模拟器手动下载地址,内容只包含从iOS 8 - iOS 12 之间的各个小版本。
网易airtest for mac必备agent, iOS-Tagent 其实就是 WebDriverAgent 仔细看,会发现iOS-Tagent会比WebDriverAgent简略得多。 iOS-Tagent其实就是WDA的优化版本。 git clone ...
很好用的Xcode qmui-ios-codesnippets直接下载 或者到https://github.com/QMUI/QMUI_iOS_CodeSnippets下载
Title: Xcode 5 Start to Finish: iOS and OS X Development Author: Fritz Anderson Length: 624 pages Edition: 1 Language: English Publisher: Addison-Wesley Professional Publication Date: 2014-05-16 ISBN-...
subtitle: Bulid Settings -> Documentation Comments -> NO原因从Xcode8.0开始,引入了文档注释警告,
这是一门快速入门iOS开发的课程,目的是让大家快速学会,iOS开发环境搭建,和iOS一些基础知识,最后完成一个小项目。 项目信息 提供完整的Git提交历史,和每节视频一一对应,目前有41次提交,355行注释,271行...
用于 iOS 移动开发的 Gradle 插件 有一个适用于 Gradle 的 Android 插件,为什么没有适用于 iOS 的插件? 请参阅示例 - 要求 XCode (iOS SDK) CocoaPods(依赖项) iOS-Deploy(部署到设备) 安装 XCode 安装 ...
学习如何使用Git进行代码版本控制,其中包括Git服务器的搭建,Git常用命令,协同开发,还介绍了Xcode中配置和使用Git工具。 第19章“把你的应用放到App Store”。掌握如何在App Store发布应用。介绍应用发布流程以及...
Move into iOS development by getting a firm grasp of its fundamentals, including the Xcode 9 IDE, Cocoa Touch, and the latest version of Apple’s acclaimed programming language, Swift 4. With this ...
iOS-Tagent简介 iOS-Tagent是一个基于facebook 的项目,旨在适合 。 我们对其进行了一些自定义的优化和调整,它在以下方面效果很... 1.2使用Xcode打开iOS-Tagent并使用数据线将iPhone连接到Mac 在Xcode的顶部菜单中选
依存关系设置如下所示将仓库克隆到Xcode代码段目录中git clone :ustwo/xcode-snippets.git ~/Library/Developer/Xcode/UserData/CodeSnippets/ 重新启动Xcode 就是这样!用法例如,使用底部的“ US2”使用Xcode检查...
在这里,您可以找到用于在iOS平台上开发与Galileo兼容的应用程序的资源。 对于其他平台并访问我们的开发人员博客和论坛,请访问motrr开发人员门户,为 。 下载框架 可以以或格式手动下载GalileoControl框架。 只需...
git clone git@github.com:yokurin/RxSwift-MVVM-iOS.git在Xcode中打开RxSwiftMVVM.xcworkspace 。 跑描述RxSwiftMVVM是使用MVVM架构以RxSwift编写的示例iOS应用。 使用 , , 查看源代码单元测试在制品...Xcode...
要求:苹果开发者计划帐户(仿真器没有相机)Xcode 9.2 OpenCV 3.3.1 iOS Pack Git LFS Tensorflow-lite任何iOS开发者Tensorflow-lite Deeplab RealTime 1. Demo 2要求:Apple开发者计划帐户(模拟器没有相机)Xcode...
在开发过程中,为了测试应用能否对 iOS 系统的内存警告通知作出正确响应,经常需要开发者手动模拟该消息的产生。iOS 模拟器中提供了直观的方式模拟向当前运行的应用发送内存使用警告。但是当开发者需要在真机上测试...
hipmob-ios-体验 该项目为 Hipmob iOS 库支持的功能提供了一组详细的示例。 Hipmob 允许您将整个常见问题解答...在 XCode 中打开文件hipmob-ios-experience.xcodeproj 。 运行。 这是一个现场演示,您将与我们交谈。
awtk-ios awtk ios移植 编译awtk ios版本,需要MacOS电脑,并安装Xcode。 下载awtk和awtk-ios源码 git clone https://github.com/zlgopen/awtk.git git clone https://github.com/zlgopen/awtk-ios.git 创建并编译...
我们还假设它已经预装了XCode,因为该公司的IT部门重视您的时间:)第1步:克隆仓库在设置公司电子邮件地址之后,在新计算机上要做的第一件事是下载代码库: 在这种情况下,该项目在GitHub @ 上具有公共可见性,但是您...