zoukankan      html  css  js  c++  java
  • App开发流程之源代码Git管理

    base项目已经可以编译运行了,只不过没有实际功能而已。继续完善base项目前,我们需要考虑一下代码管理的事情了。

    不管是一个人开发还是一个团队开发,对源代码进行版本管理是必须的,任何人对代码的的任何操作都可以被管理,理由还不够充分么。

    以前使用过SVN,不过体验最好的,还是Git方式。

    1.本地仓库简单易用,可以完全脱离远程仓库来使用
    2.所有主干和分支都统一管理,切换自如
    3.合并代码轻松愉快

    Xcode自带代码Git管理,创建项目时候就提到过,当时有建议不采用,因为准备使用其他的管理工具。如果创建项目时候,使用了Xcode的git管理,可以通过下面两种方式修改:

    方式一:
    1.打开终端,输入指令:defaults write com.apple.finder AppleShowAllFiles -bool true(false 表示不显示隐藏类型的文件)
    2.删除项目根目录下的隐藏文件.git
    3.使用新的管理软件进行git管理

    方式二:
    直接将根目录下可见的文件及文件夹拷贝到新的根文件夹里,即可对该根文件夹进行版本管理。

     

    源代码Git管理配置

    管理方案:Github + SourceTree

    1.前往https://github.com,注册一个账号

    2.下载git客户端。Github也提供了一个客户端,直接使用账号密码登录来管理项目,下载地址:https://desktop.github.com/。也有用命令行来控制的朋友,我就不讨论了。我由于还在使用SourceTree管理其他项目,所以这里就继续采用SourceTree了。

    使用git方式,多半都会涉及SSH key,简单记录一下生成过程。

    说明一下:github客户端采用账号密码就可以验证使用者的身份,进而对自己的项目进行管理。SSH key简化了输入账号密码的流程,将SSH key加入github账号后,github授权生成该SSH key的设备可以使用git管理工具管理github上的项目。

     

    SSH key生成及设置过程:
    1.在Finder的当前用户根目录下,前往(shift+command+G)文件夹“~/.ssh”
     如果存在xxxx.pub文件,则是目标文件,用文本编辑器打开,将全部内容拷贝
     根据如下示图,找到github添加SSH key的位置:

    如上图点击登录后页面的最右边的icon -> settings 进入设置页面

    如上图选中SSH and GPG keys栏,点击“New SSH key”按钮,title用来描述用,key栏copy上拷贝的SSH key内容,最后点击“Add SSH key”即可。

     

    2.如果上述文件不存在。打开终端,输入:ssh-keygen -t rsa -C "xxxx@xxxx.com",然后回车,根据提示完成操作即可。“xxxx@xxxx.com”建议为github的账号邮箱
       生成以后,按照步骤1即可。

     

    完成上述操作以后,就可以使用SourceTree了。

    到这里,我们可以选择在SourceTree中设置远程账户,先根据base项目生成本地仓库,然后根据本地仓库创建远程仓库。也可以不设置账户,先在Github上创建一个仓库名为“base”,然后使用ssh克隆到本地,再将项目文件移入其中。我使用了后者。

    创建仓库

    1.点击下图所示右上角加号按钮 -> new repository 出现如下页面

     

    说明:输入仓库名和可选描述,类型默认公开,如果想设置为私密类型,需要付费。在此,提供另一个git仓库平台Gitlab(地址:https://about.gitlab.com/),可以免费创建私密仓库,使用方式和Github类似。

    还可以勾选添加一个README文件和.gitignore文件,前者可以使得立即克隆该仓库到本地,忽略文件默认不显示,记录git仓库不管理的文件或者类型。license暂时就不没有必要添加了吧。

     

    2.创建成功以后的页面如下图:

    建议使用SSH验证方式克隆,点击clone or download按钮,复制字符串:xxxxxxx/base.git

    3.打开本地已安装好的Sourcetree,点击“+新仓库” -> 从url克隆,出现如下界面

    将copy的字符串作为源URL,目标路径和名称会自动填写。

    我将Xcode创建的项目和SourceTree克隆下来的项目放到了同一个文件夹下,为了区别,将克隆下来的根目录重命名为“githubbase”。

    完成克隆以后,将base项目复制到githubbase目录下即可。

     

    打开这个本地仓库以后,就可以看到未暂存文件了。

     

     

    关于SourceTree的使用,只记录如下几点:
    1.勾选未暂存文件,可以加入已暂未文件列表,即成为待提交文件
    2.左上角“提交”按钮,只是将修改提交到本地仓库
    3.“推送”按钮即是提交到远程仓库
    4.“拉取”按钮即是同步远程仓库最新代码
    5.可以右键暂存文件,“忽略”此文件或者此类型,例如.xcworkspacedata
    6.“分支”按钮可以创建新的分支,具体到分支或者主干版本,右键可以checkout切换当前编辑分支
    7.右键到非编辑分支,可以合并入当前分支
    8.右键到某个文件,可以查看修改日志
    9.解决冲突可以使用外联工具
    10.菜单栏SourceTree -> 偏好设置 ->通用,可以设置提交代码时候的全名和电子邮件地址作为身份标识
    11.就算设置了通用身份标识,也可以为每个仓库分别设置。

    右上角的设置 ->高级,可以设置当前仓库的用户信息

     

    更多详细功能和操作就不一一记录了。

    至此,源代码已经被管理起来。

    源代码:https://github.com/ALongWay/base 

  • 相关阅读:
    JAVA中线程同步的方法(4种)汇总
    java
    指定的元素已经是另一个元素的逻辑子元素。请先将其断开连接。(解决问题总结)
    无法将类型为“System.Windows.Controls.SelectedItemCollection”的对象强制转换为类型“System.Collections.Generic.IList`1
    foreach---集合已修改;可能无法执行枚举操作。
    WPF_View中控件使用单例ViewModel
    判断s2是否能够被通过s1做循环移位(rotate)得到的字符串是否包含
    多列转1列 SqlServer 实现oracle10g的 wmsys.wm_concat()--for xml path('')
    异步对象(XMLHttpRequest)的帮助脚本
    在vs2010使用EF出现CS0012: 类型“System.Data.Objects.DataClasses.EntityObject”在未被引用的程序集中定义
  • 原文地址:https://www.cnblogs.com/ALongWay/p/5829258.html
Copyright © 2011-2022 走看看