一.利用Git进行版本管理:(OSChina版本 and macdown版)
不得不说用了MACDown排版就是好
1.首先确保你的工程在创建之初就加入了Git。iOS如何在已建工程内添加git
2.在Git中建立项目,获得SSH或者HTTPS(远程仓库地址)
3.建立本地仓库和远程仓库关联:
第一步:$ cd 你的工程路径
第二步:设置提交代码时的用户信息
$ git config --global user.name “你的账户名"
$ git config --global user.email “你的邮箱地址"
第三步:初始化本地仓库并关联远程仓库。
$ git init //初始化本地仓库
$ git remote add origin 【https://....... 】 //git账号中的网址
或者
$ git remote add origin 【git@git.oschina....... 】 //git账号中的ssh地址
添加好之后可以使用:
$ git remote (可以查询添加的远程仓库)
4.设置忽略文件,忽略某些不必要提交的文件。
怎么添加忽略文件?
生成一个.gitignore文件,加点表示是隐藏文件(Mac怎么查看忽略文件?)
$ touch .gitignore
$ vi .gitignore 编辑gitnore文件
————————————— 以下是忽略文件,直接粘贴进去就行
# Xcode
.DS_Store
*/build/*
*.pbxuser
!default.pbxuser
*.mode1v3
!default.mode1v3
*.mode2v3
!default.mode2v3
*.perspectivev3
!default.perspectivev3
xcuserdata
profile
*.moved-aside
DerivedData
.idea/
*.hmap
#CocoaPods
Pods
$ cat .gitignore
可以查看gitnore文件
5.添加忽略文件,把忽略文件提交上去。
$ git add .gitignore
//需要先添加以下这个忽略文件(貌似直接git add * 并不鞥)
$ git add *
//添加刚刚导入的整个工程
$ git pull origin master
//还是要先更新
$ git commit -m “提交描述说明"
$ git push origin master
//把忽略文件提交 上去git push -u origin master 加上-u就是设为默认,以后不用在写origin master
去git上查看正常之后,把自己的工程提交上去即可。
$ git add *
$ git commit -m “提交描述说明"
$ git push origin master
(第一次的话有冲突,强制Push:git push -f origin master)
=======================
如果你在git push的时候一直出现下边的错误,那么参考以下链接 或者 问题解决链接...出现以下错误主要是因为你使用的是SSH关联的远程仓库,但你的SSH key没有添加到github帐号设置中,系统会报下面的错误:
Permission denied (publickey).
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
6.Git Clone
通常是从远程主机克隆一个版本库,这时就要用到git clone命令
$ git remote -v
// 显示详细的仓库地址
$ git clone https://版本库的网址
该命令会在本地主机生成一个目录,与远程主机的版本库同名。如果要指定不同的目录名,可以将目录名作为git clone命令的第二个参数。克隆下来的文件默认存放在 前往--> 个人
$ git clone <版本库的网址> <本地目录名>
git clone支持多种协议,除了HTTP(s)以外,还支持SSH、Git、本地文件协议等,下面是一些例子。
$ git clone http[s]://example.com/path/to/repo.git/
$ git clone ssh://example.com/path/to/repo.git/
$ git clone git://example.com/path/to/repo.git/
$ git clone /opt/git/project.git
$ git clone file:///opt/git/project.git
$ git clone ftp[s]://example.com/path/to/repo.git/
$ git clone rsync://example.com/path/to/repo.git/
7.Git Pull
git pull命令的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并。它的完整格式稍稍有点复杂。
$ git pull <远程主机名> <远程分支名>:<本地分支名>
比如,取回origin主机的next分支,与本地的master分支合并,需要写成下面这样。
$ git pull origin next:master
如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
$ git pull origin next
上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再做git merge。
$ git fetch origin
$ git merge origin/next
8.删除远程仓库文件:
参考:http://www.cnblogs.com/xusir/p/4111723.html
$ git rm -r -n --cached */src/\*
//-n:加上这个参数,执行命令时,是不会删除任何文件,而是展示此命令要删除的文件列表预览。
$ git rm -r --cached */src/\*
//最终执行命令.
$ git commit -m"移除src目录下所有文件的版本控制"
//提交
$ git push origin master
//提交到远程服务器
例如:
$ ls -al
查看该目录下的所有文件
$ git rm -r --cached Pods
删除远程文件夹里面的文件(Pods是文件名)
9.替换远程仓库
查看远程仓库
$ git remote -v
删除远程仓库
$ git remote rm origin
$
然后重新添加仓库即可
$ git remote add origin https://...
参考链接:
Git远程操作详解 - 阮一峰的网络日志