删除分支

新建一个分支 A 后,要想把 A 分支删除掉,只需跳到另一个分支上去,选中 A 分支然后右击,在弹出的菜单栏中选中 【删除 A 分支】即可;

在分支下建一个文件夹

左上的然后弹出选框,在【新分支】处建一个 Develop 的文件夹,在 Delvelop 文件夹下新建一个 feature 分支可以在【新分支】的栏目输入:Develop/feature ,即可;

合并后的恢复

例如:你在当前的 A 分支的 a 节点,但是你鼠标放在 B 分支的一个 b 节点上,在 B 分支的 b 节点上右击,选中【合并】,会将 B 分支节点上的内容合并到 A 分支上,形成一个在 A 分支上的新节点 c。

当你误合并时,选中 a,b,c中的任意一个节点,选中导航栏中的【仓库】->【重置】,即可恢复原样,像没发生一样。

将 xx 重置到这次提交

master分支上有 a->b->c->d->e 5 个节点,现再在 e 节点,鼠标放在 d 节点上,右击鼠标出现弹框选中【将 master 重置到这次提交】,会出现在 d 提交的基础上内容 加上现在变化的内容,代码不会改变。就算你提交到 e 节点,但是鼠标放在 a 节点,右击鼠标出现弹框选中【将 master 重置到这次提交】,也会将你的分支回到 a 节点上,但是代码不变。

注意:如果这时你点击导航栏亩的【仓库】->【重置】会把你写的代码全清除掉,只有你当前提交的部分,慎重啊!

提交回滚

有 "master 分支->1 master 分支->2 master" 分支3个节点,提交后变为 "master 分支->1 master 分支->2 master 分支->3 master分支" 分支 4个节点,选中 "2 master 分支" 节点,将鼠标放在 "3 master" 节点然后右击选中【提交回滚】,会出现这种警告:

 HEAD detached at 464855f
nothing to commit, working directory clean

意思是:

分离主管464855 f
没有什么可提交的,工作目录是干净的

不会改变。

开始状态:

所以鼠标选中 ”3 master分支" 节点,然后右击选中【提交回滚】,代码会回到 "2 master 分支" 提交的状态,变为:

也就是 “2 master 分支” 提交代码的状态。

然后写一段与 “3 master分支” 一样的代码,再次命名分支名为 “3 master分支”,变为:

代码rebase(变基)

git rebase用于把一个分支的修改合并到当前分支.

假设你现在在 master 分支上,已有 a, b, c, d, e, f 几个节点,在 b 节点新建一个分支为 mywork:

 $ git checkout -b branch

在 branch 分支做两次提交:

 $ git add .

 $ git commit -m "1 代码 branch"

 $ git add .

 $ git commit -m "2 代码 branch"

如果你想让"master"分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase,切换到 master:

//这些命令会把你的"branch"分支里的每个提交(commit)取消掉,并且把它们临时保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把"branch"分支更新 为最新的"master"分支,最后把保存的这些补丁应用到"master"分支上。

 $ git checkout master

 $ git rebase branch

这时会有冲突,解决冲突后使用:

 $ git rebase --continue

然后提交,中间会再次出现冲突,再次使用:

 $ git rebase --continue

就好了!

若中途弃 rebase,可以使用:

$ git rebase --aborkt

另外,我们在使用git pull命令的时候,可以使用--rebase参数,即git pull --rebase,这里表示把你的本地当前分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把本地当前分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到本地当前分支上。

参见资料:rebase简介

多次提交的合并

1.先查看有多少次提交:

$ git log

可以看到下面有4个:

若对 4 个进行提交合并,输入:

 $ git rebase -i head~

然后会弹出一个 vim 编辑界面,会看到编辑界面分为两部分:

pick xxxx    XXXX

pick xxxx    XXXX

pick xxxx    XXXX

pick xxxx    XXXX

# . . . . .  . . .

# . . . . .  . . .

.

.

.

.

# . . . . .  . . .

带 # 的都是注释部分,把要合并的改为 【pick】改为 【s】或者 【squash】即可,然后点击 esc,再输入 :wq 即可,会跳入另一 vim 编辑界面,修改其中的提交 message,其中第一个提交 message 回作为多次提交合并后的新的提交 message,如:

 第一个message为:1.0 创建 master,//下面不修改也行

 第2个message为:

 第3个message为:

 第4个message为:

 第5个message为:

然后,输入::wq ,退出编辑界面即可,会看到一个叫 【1.0 创建 master】的分支节点,只剩它一个了。

撤销提交

参见资料:撤销提交

iOS文件的忽略

如果想忽略某一个文件,可以设置到SourceTree中你提交文件的那个右上角:【设置】->【高级】->【编辑】,然后在里面输入你想要忽略的文件。

  .xcodeproj属于包文件,它内部的很多东西是不能提交的,包括:project.xcworkspace和xcuserdata,它们是与用户有关的。

  

CocosPods 产生的文件: 框架管理工具会生成Podfile、Podfile.lock、Pods文件夹和.xcworkspace四个。其中:

以上除Podfile外,其它三个文件都不是必须提交的。
"其中Pods目录没必要提交,里面的文件都是根据Podfile描述的依赖库的配置信息下载和生成的文件。
因为CocoaPods支持语义化版本号,所以需要Podfile.lock文件记住当前使用的版本,当然这个文件也不是必须。不过提交这个的好处是,可以提醒团队里面的人,依赖库版本已经更新”。

忽略文件在SourceTree分为两种,一种是针对于某一个仓库,另一种针对于所有的仓库,最开始没注意经常提交以后在下载出错,后来用半天时间终于搞清楚了。

针对某一个仓库忽略设置

可以在这里设置忽略文件,也可以不设置,看你喜好了!

针对所有仓库文件设置

第一步:

第二步:

第三步:

这样就好了,不用针对一个一个仓库进e行设置!若你喜欢受虐,可以单个仓库设置,

SourceTree 使用的更多相关文章

  1. 关于如何使用sourcetree将本地项目提交到远端github总结?

    使用sourcetree将本地项目提交到github里,目前来说还是很流行的,我也是听说好玩,所以来琢磨了一下,从环境搭建到配置好,差不多用了一下午加一晚上的时间,有点虐心,好吧,废话不多说,介绍一下 ...

  2. [Tool] SourceTree操作中遇到错误(Filename too long)的解决方案

    [Tool] SourceTree操作中遇到错误(Filename too long)的解决方案 问题情景 使用SourceTree,可以方便开发人员使用图形化接口的Git指令来管理原始码.但是在Wi ...

  3. SourceTree安装教程和GitLab配置详解

    一.安装Git 链接: http://pan.baidu.com/s/1mh7rICK 密码: 48dj 二.安装SourceTree 链接: http://pan.baidu.com/s/1skWk ...

  4. SourceTree 免登录跳过初始设置 - 转

    转自:http://www.cnblogs.com/xiofee/p/sourcetree_pass_initialization_setup.html 在SourceTree的配置目录新建(或修改) ...

  5. git&sourcetree安装及在IntelliIJ下拉取项目基础使用

    be careful: 1)git版本与Sourcetree版本最好一致 ,不能git为2.5,sourcetree为1.8 2)先安装git再安装Sourcetree 3)拥有git和sourcet ...

  6. bitbucket+sourcetree+p4merge for windows 版本控制

    这里选择bitbucket作为仓库的原因是,它能够在设置私有仓库的前提下组建5人团队 一:https://bitbucket.org/ 注册bitbucket 二:http://www.sourcet ...

  7. [Tool] SourceTree初始化GitFlow遇到错误(git command not found)的解决方案

    [Tool] SourceTree初始化GitFlow遇到错误(git command not found)的解决方案 问题情景 使用SourceTree,可以方便开发人员快速的套用GitFlow开发 ...

  8. GitHub和SourceTree入门教程

    -->本教程适用于主流的开源网站github和bitbucket,个人认为sourceTree还是比较好用的git客户端,支持windows和mac os. -->soureceTree的 ...

  9. Git SourceTree 冲突解决方案

    Git现在越来越火,很多人都从Svn迁移到Git上面,Git让我们更加与世界接轨,不再是"局域网"的程序猿,特别是掌握了Git之后,会发现它真的很好用,本文对Git中比较烦人的冲突 ...

  10. git -c diff.mnemonicprefix=false -c core.quotepath=false -c credential.helper=sourcetree fetch origin

    git -c diff.mnemonicprefix=false -c core.quotepath=false -c credential.helper=sourcetree fetch origi ...

随机推荐

  1. Java ServiceLoader(SPI)学习

    1. 几个不错的关于ServiceLoader的文章,大家可以先参考一下 1) http://www.myexception.cn/program/1355384.html 这篇的后面的问题分析不错 ...

  2. nodejs 学习五 单元测试一

    一. chai chai 自身是依赖nodejs的 assert,让检测更加语义化. chai 采用两种模式,TDD和BDD, TDD是类似自然语言方式 BDD是结构主义 chai文旦地址 二.moc ...

  3. 封装 vue 组件的过程

    首先,组件可以提升整个项目的开发效率.能够把页面抽象成多个相对独立的模块,解决了我们传统项目开发的缺点:效率低,难维护,复用性等问题: 然后,使用Vue.extend方法创建一个组件,然后使用 Vue ...

  4. IGMP协议

    IGMP报文格式: 4bit的IGMP版本(1)+4bit的IGMP类型(1-2)+8bit未用+16bit检验和(同ICMP)+32bit组地址(D类IP地址) 类型为1说明是由多播路由器发出的查询 ...

  5. MySQL前缀索引和索引选择性

    有时候需要索引很长的字符列,这会让索引变得大且慢.通常可以索引开始的部分字符,这样可以大大节约索引空间,从而提高索引效率.但这样也会降低索引的选择性.索引的选择性是指不重复的索引值(也称为基数,car ...

  6. mysql 初识sql语句

    有了mysql这个数据库软件,就可以将程序员从对数据的管理中解脱出来,专注于对程序逻辑的编写 mysql服务端软件即mysqld帮我们管理好文件夹以及文件,前提是作为使用者的我们,需要下载mysql的 ...

  7. php程序猿面试分享

    面试总结 今天去了北京著名IT公司进行PHP程序猿的面试.这是人生第一次么,怎么不紧张?我是不是有病.不是.这叫自信呵. 首先是做一些笔试题. 1.mysql数据库索引使用的数据结构?这样做的优点是? ...

  8. python文件的md5加密方法

    本文实例讲述了python文件的md5加密方法.分享给大家供大家参考,具体如下: 一.简单模式: from hashlib import md5 def md5_file(name): m = md5 ...

  9. python中base64编码与解码

    在python3中用base64进行编码和解码的时候特别注意: 题目要求: 准备一张.jpg图片,比如:mm.jpg,读取图片数据并通过b85encode加密之后写入到新文件mm.txt文件中,然后读 ...

  10. mysql 分组 列转行

    SELECT aa.type,CONCAT('(',GROUP_CONCAT('\'',aa.user_id separator '\'\,'),'\')') FROM (select  aa.typ ...