mac下svn怎么checkout

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mac下svn怎么checkout相关的知识,希望对你有一定的参考价值。

1、Xcode4苹自带SVN软件------>Organizer------>Repositories

2、SVN checkout本删除本file服务器影响?
影响服务器执行svn updatezai再自载;删除再执行svn commit服务器应删除

3、连接服务器
点击file-》repositories-》点击坐边+-》名字及svn服务器址type选subversionnext等等

4、Xcode4,SVN用命令
Commit 提交
checkout 服务器载本(我使用电脑)
update 更新文件
File------->SourceController------->update

图片第3按钮,视图比按钮.

5、SVN用详解注意事项
①提交自代码
SVN更新原则要及更新及提交完功能能够通编译并且并且自测试尽量早提交保存历史版本必要候滚;始工作前update项目
②保持原提交(要经意间修改并提交别文件)
仅提交修改部要整项目提交;
完功能或文件提交我遇完某功能没提交做更改结代码现bug恢复代码
③要提交自文件
VisualStudio等发工具程产自文件.suo等配置文件Debug,Release,Obj等编译文件及其些自同编译代码关文件些文件提交候应该签入签入需要仓库删除
④要提交能通编译代码
代码提交前首先要确认自能够本编译进行SVN提交更新代码提交前已经通自测试
SVN用命令详解
1、文件checkout本目录
svn checkout path(path服务器目录)
例:svn checkout svn://192.168.1.1/pro/domain
2、往版本库添加新文件
svn add file
例:svn add test.php(添加test.php)
3、删除文件
svn delete path -m delete test fle
例:svn delete svn://192.168.1.1/pro/domain/test.php -m delete testfile
4、查看志
svn log path
5、比较差异
svn diff path(修改文件与基础版本比较)
6、两版本间差异合并前文件
svn merge -r m:n path
SVN使用
更新(update)经update没坏处特别项目每提交(commit)前进行更新(update)新版本svn提示前拷贝期需要更新
提交(commit)定要写提交内容摘要便于查阅
文件checkout本目录
svn checkout path(path服务器目录)
svn update命令自用服务器版本替换本版本控制文件

6、Xcode使用SVN问题及提交解决冲突问题
XcodeSVN功能Eclipsesubclipse或者windowstortoiseSVN比较起功能差
我索性用直接用命令行我看朋友用subclipse其实挺使用SVN功能要单独耗费资源Eclipse

论使用SVN工具都遇Xcode固问题即project.pbxproj文件提交冲突问题

project.pbxproj文件面包含构建程所需所文件项目目录增加新文件比没通Xcode该文件project.pbxproj文件app同理SVN更新其项目员增加文件没更新project.pbxproj文件(或者该员根本没提交文件)则现相同现象

项目员提交新project.pbxproj文件边没项目增加新文件直接svn update

7、Xcode更新代码项目文件打

若选择更新整项目经现冲突问题尤其project.pbxproj文件文件包含构建程所需所文件项目目录增加新文件没通Xcode
该文件project.pbxproj文件app同理SVN更新其项目员增加文件
没更新project.pbxproj文件(或者该员根本没提交文件)则现相同现象文件冲突直接导致项目文件打

解决更新代码打项目文件:
项目文件tobacco.xcodeproj打右键选择'显示包内容'看三文件project.pbxproj/user.modelv3/user.pbxuser
其project.pbxproj三版本解决普通svn文件冲突解决冲突即

8、SVN 更新 提交 合并 区别

本文件没改服务器文件改候更新服务器取文件覆盖前文件
本文件改服务器文件没改更新文件
本文件改服务器文件改改部冲突合并文件本冲突提示文件冲突需要自手修改传服务器
讲解合并:
服务器本同文件(所谓同文件应该SVN相路径相同文件名相同文件由SVN留本信息决定)已经修改且修改部重合重叠
满足面条件候再更新SVN自合并
SVN奥妙处于别提交修改文件再提交允许提交滴
>>>>
<<<
面标记冲突区域冲突区域删除掉能提交

解决办1:
删掉没解决冲突文件面几文件名相同缀同文件
知道用SVN解决冲突简单办
文件改名字文件所目录更新服务器文件自修改部添加更新文件面提交
解决办2:
文件面点击右键SVN菜单应该编辑冲突按钮选择现窗口边服务器版本边自修改版本

9、xcode自带svn使用
1、代码 某文件面 M 标记表示该文件已修改需要 commit.
(右键该文件 -> source control -> commit selected file...)
2、代码 某文件面 A 标记表示该文件新添加已受SVN管理需要 commit.
(右键该文件 -> source control -> commit selected file...)
3、代码 某文件面 ? 标记表示该文件新添加并且脱离SVN管理首先需要add commit.
(右键该文件 -> source control -> Add该文件标记变 A commit).
参考技术A 1、Xcode4中苹果有自带的SVN软件------>Organizer------>Repositories

2、SVN checkout到本地后,删除本地file,对服务器有影响吗?
不会影响服务器,当你执行“svn update”时会zai再次被自动下载;当删除后再执行“svn commit”就会在服务器上也对应删除。

3、连接服务器
点击file-》repositories-》点击坐下边的“+”-》然后名字及svn服务器的地址,还有type选中subversion然后next等等了。

4、Xcode4下,SVN中常用命令
Commit 提交
checkout 将服务器上下载到本地(我个正在使用的电脑)
update 更新文件
File------->SourceController------->update

图片中第3个按钮,是视图对比按钮.

5、SVN中用法详解和注意事项
①提交自己的代码
SVN更新的原则是要及时更新,及时提交。当完成了一个小功能,能够通过编译并且并且自己测试之后,尽量早的提交,这样也保存了历史版本,必要时候可以回滚;在开始一天的工作之前,最后update一下项目。
②保持原子提交(不要不经意间修改并提交了别人的文件)
仅提交你修改的部分,最好不要一下子将整个项目提交;
当完成一个功能或文件后,最好提交。我就遇到完成某个功能后,没有提交,后来又做了更改,结果代码出现bug,无法恢复到正常时的代码。
③不要提交自动生成的文件
VisualStudio等开发工具在生成过程中会产生很多自动文件,如.suo等配置文件,Debug,Release,Obj等编译文件,以及其他的一些自动生成,同编译代码无关的文件,这些文件在提交的时候不应该签入,如果不小心签入了,需要从仓库中删除。
④不要提交不能通过编译的代码
代码在提交之前,首先要确认自己能够在本地编译。进行SVN提交更新时最好是代码在提交前已经通过自己的测试。
SVN中常用命令详解
1、将文件checkout到本地目录
svn checkout path(path是服务器上的目录)
例如:svn checkout svn://192.168.1.1/pro/domain
2、往版本库中添加新的文件
svn add file
例如:svn add test.php(添加test.php)
3、删除文件
svn delete path -m “delete test fle“
例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete testfile”
4、查看日志
svn log path
5、比较差异
svn diff path(将修改的文件与基础版本比较)
6、将两个版本之间的差异合并到当前文件
svn merge -r m:n path
SVN使用方法
更新(update),经常地update没有坏处,特别是多人项目中。如果每次提交(commit)前不进行更新(update)的到最新的版本的话,svn会提示当前的拷贝过期,需要更新。
提交(commit),一定要写上这次提交的内容的摘要,便于以后查阅。
将文件checkout到本地目录
svn checkout path(path是服务器上的目录)
svn update命令自动用服务器上的版本替换本地版本控制的文件

6、Xcode中使用SVN问题以及提交解决冲突问题
Xcode的SVN功能,和Eclipse中的subclipse或者windows下的tortoiseSVN比较起来功能还差很多。
我是索性不用的,直接用命令行。我看有的朋友是用subclipse,其实也挺好,不过,为了使用SVN功能要单独开一个耗费资源的Eclipse。

但是,不论使用什么SVN工具,都会遇到Xcode固有的问题,即project.pbxproj文件的提交冲突问题。

project.pbxproj文件里面包含了构建过程所需的所有文件,如果你在项目目录下增加了新文件,比如没有通过Xcode,该文件就不在project.pbxproj文件中,就不会生成到app中。同理,如果你从SVN中更新到其他项目成员增加的文件,而没有更新project.pbxproj文件(或者该成员根本就没有提交这个文件),则也会出现相同的现象。

如果项目成员提交了新的project.pbxproj文件,你这边没有在项目中增加新的文件,直接svn update就可以了。

7、Xcode中更新代码后项目文件打不开

若选择更新整个项目经常会出现冲突问题,尤其是project.pbxproj文件。此文件包含了构建过程所需的所有文件,如果在项目目录下增加了新文件,但没有通过Xcode,
该文件就不在project.pbxproj文件中,就不会生成到app中。同理,如果从SVN中更新到其他项目成员增加的文件,
而没有更新project.pbxproj文件(或者该成员根本就没有提交这个文件),则也会出现相同的现象。这一文件冲突将直接导致项目文件打不开。

解决更新代码后打不开项目文件方法:
当项目文件如tobacco.xcodeproj打不开时可以右键选择'显示包内容',会看到有三个文件,project.pbxproj/user.modelv3/user.pbxuser。
其中project.pbxproj有三个版本,和解决普通svn文件冲突一样解决冲突即可。

Mac终端下的svn使用教程

1、将文件checkout到本地目录

1 svn checkout path(path是服务器上的目录)
2 例如:svn checkout svn://192.168.1.1/svn
3 简写:svn co

2、往版本库中添加新的文件

1 svn add file
2 例如:svn add test.php(添加test.php)
3 svn add *.php(添加当前目录下所有的php文件)
 

3、将改动的文件提交到版本库

1 svn commit -m “LogMessage“ [-N] [--no-unlock] PATH        (如果选择了保持锁,就使用–no-unlock开关)
2 例如:
  svn commit -m “add test file for my test“ test.php 3 简写:
  svn ci


4、加锁/解锁

1 svn lock -m “LockMessage“ [--force] PATH
2 例如:svn lock -m “lock test file“ test.php
3 svn unlock PATH

5、更新到某个版本

 
1 svn update -r m path
2 例如:
3 svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
4 svn update -r 200 test.php(将版本库中的文件test.php还原到版本200)
5 svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit)
6 简写:svn up

6、查看文件或者目录状态

 
1 svn status path(目录下的文件和子目录的状态,正常状态不显示)
2 【?:不在svn的控制中;M:内容被修改;C:发生冲突;A:预定加入到版本库;K:被锁定】
3 svn status -v path(显示文件和子目录状态)
4 第一列保持相同,第二列显示工作版本号,第三和第四列显示最后一次修改的版本号和修改人。
5 注:svn status、svn diff和 svn revert这三条命令在没有网络的情况下也可以执行的,原因是svn在本地的.svn中保留了本地版本的原始拷贝。
6 简写:svn st

7、删除文件

 
1 svn delete path -m “delete test fle“
2 例如:svn delete svn://192.168.1.1/pro/domain/test.php -m “delete test file”
3 或者直接svn delete test.php 然后再svn ci -m ‘delete test file‘,推荐使用这种
4 简写:svn (del, remove, rm)

8、查看日志

 

 
1 svn log path
2 例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化

 

9、查看文件详细信息

 

 
1 svn info path
2 例如:svn info test.php

 

10、比较差异

 

 
1 svn diff path(将修改的文件与基础版本比较)
2 例如:svn diff test.php
3 svn diff -r m:n path(对版本m和版本n比较差异)
4 例如:svn diff -r 200:201 test.php
5 简写:svn di

 

11、将两个版本之间的差异合并到当前文件

 

 
1 svn merge -r m:n path
2 例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)

 

12、SVN 帮助

 

 
1 svn help
2 svn help ci

13、版本库下的文件和目录列表

 
1 svn list path
2 显示path目录下的所有属于版本库的文件和目录
3 简写:svn ls

14、创建纳入版本控制下的新目录

 

1 svn mkdir: 创建纳入版本控制下的新目录。
2 用法: 1、mkdir PATH…
3 2、mkdir URL…
4 创建版本控制的目录。
5 1、每一个以工作副本 PATH 指定的目录,都会创建在本地端,并且加入新增
6 调度,以待下一次的提交。
7 2、每个以URL指定的目录,都会透过立即提交于仓库中创建。
8 在这两个情况下,所有的中间目录都必须事先存在

 

15、恢复本地修改

 

 
 svn revert: 恢复原始未改变的工作副本文件 (恢复大部份的本地修改)。revert:
2 用法: revert PATH…
3 注意: 本子命令不会存取网络,并且会解除冲突的状况。但是它不会恢复
4 被删除的目录

 

16、代码库URL变更

 

 1 svn switch (sw): 更新工作副本至不同的URL。
 2 用法: 1、switch URL [PATH]
 3 2、switch –relocate FROM TO [PATH...]
 4  
 5 1、更新你的工作副本,映射到一个新的URL,其行为跟“svn update”很像,也会将
 6 服务器上文件与本地文件合并。这是将工作副本对应到同一仓库中某个分支或者标记的
 7 方法。
 8 2、改写工作副本的URL元数据,以反映单纯的URL上的改变。当仓库的根URL变动
 9 (比如方案名或是主机名称变动),但是工作副本仍旧对映到同一仓库的同一目录时使用
10 这个命令更新工作副本与仓库的对应关系。

 

17、解决冲突

1 svn resolved: 移除工作副本的目录或文件的“冲突”状态。
2 用法: resolved PATH…
3 注意: 本子命令不会依语法来解决冲突或是移除冲突标记;它只是移除冲突的
4 相关文件,然后让 PATH 可以再次提交。




以上是关于mac下svn怎么checkout的主要内容,如果未能解决你的问题,请参考以下文章

如何在MAC环境下使用svn,以及新手在团队使用svn注意事项

Mac环境下svn的使用(转载)

SVN]Mac系统下SVN的基础配置

Mac环境下svn的使用

Mac环境svn的使用

SVN更改登录用户