p4:来年工作打算建议学,有什么建议

八 一 水 库 行(P4学习一张)|风光自然 - 九州新疆摄影论坛 - Powered by phpwind
查看完整版本: [--
&Pages: ( 2 total )
八 一 水 库 行(P4学习一张)
谢谢安德介绍的好地方。八一水库:
八一水库位于新疆生产建设兵团农六师102团团部以南1.5公里处,修建于1957年,是一座以灌溉为主的平原水库,设计库容量为3000万立方米,年均调水5000万立方米。
还有同行的孤旅天山
还有一位教育工作者
好的。再发!
好的。再发!
哈哈哈哈哈哈哈
好的。再发!
好的。再发!
谢谢大家。。。。。。完毕。我将继续练习。。。。。。
木子愚的弱光整的很有点味道哦学习了,有空教教我
精品一组,学习了!!!!
那里是个好地方,雨后背景的博格达也不错!
05年春节决堤的水库。
哈哈哈哈.快啊,这么多搞的我都不好意思发了。
版主您好:小弟有一感覺想說出供您參考.就是有關於後期方面.就以第一張來說明.小弟覺得整個片子的色溫感覺都一樣.是否可將一部分修改不同的色溫.另外再將焦點擺在一處讓觀賞者有焦點可注視.小弟不好意思擅自作主替您修改看看.若有不妥請刪除.謝謝若是需要說明如何修改的部分請告知. [attachment=49070]
牵手老师做的就是不一样,我想木子愚不会有意见的,应该希望多指点大家学习!
色温真的很神奇,要学的东西实在太多了。太阳还没落下就可以摇黑卡了吗?
子愚兄的功力见涨啊?
帮顶 ~~更欣赏牵手大师的后期 学习再学习~!
引用第19楼牽手.于 21:06发表的 :版主您好:小弟有一感覺想說出供您參考.就是有關於後期方面.就以第一張來說明.小弟覺得整個片子的色溫感覺都一樣.是否可將一部分修改不同的色溫.另外再將焦點擺在一處讓觀賞者有焦點可注視.小弟不好意思擅自作主替您修改看看.若有不妥請刪除.謝謝.......多谢!多谢!!这样画面显得生机活现,并多了些变化。感悟中。。。。。。感谢中。。。。。。记下了!请教牵手老师,你用的什么方法调整的?谢谢!
引用第21楼度秋于 23:20发表的 :色温真的很神奇,要学的东西实在太多了。太阳还没落下就可以摇黑卡了吗?可以,就是快门速度越快,难度越大。。。。。。
引用第14楼guqi于 19:17发表的 :木子愚的弱光整的很有点味道哦学习了,有空教教我谢谢,有机会一起进步。。。。。。
引用第15楼枣乡老人于 19:23发表的 :精品一组,学习了!!!!枣乡老人好!近来你们那里似乎不摇卡了。。。。。。家乡应该在夏天有这样的好色温的表现的吧。
引用第16楼北山羊于 20:30发表的 :那里是个好地方,雨后背景的博格达也不错!真的是,鸟多,水多,还有你说的博格达,是个出片的地方。
引用第17楼老黄羊于 20:36发表的 :05年春节决堤的水库。我查找资料的时候也查到了!谢谢老黄羊的关注!
引用第18楼安德于 20:49发表的 :哈哈哈哈.快啊,这么多搞的我都不好意思发了。不发怎么能行呢,不发怎能加快前进的步伐。。。。。。
引用第22楼黑米粥于 23:30发表的 :子愚兄的功力见涨啊?
帮顶 ~~更欣赏牵手大师的后期 学习再学习~!谢谢你了,你也是大山连着小河的跑呀,不停的体验,不停的出战利品!
哈 这里还有 漂亮~~
非常棒的一组,顶喽!加精支持!
引用第23楼木子愚于 23:51发表的 :多谢!多谢!!这样画面显得生机活现,并多了些变化。感悟中。。。。。。感谢中。。。。。。记下了!.......小弟使用後期軟件是photoshop.tl 操作如下1.打開檔案--->磁性套索工具選取地面(很容易選取的)---->功能表(影像)-(調整)-(色彩平衡)調整自己喜愛的色調但不要過於與周圍環境不協調.選取地方稍微曲線調整.最後選取地方稍微銳利化(濾鏡-銳利化--遮色片銳利化調整(強度使用0.2即可然後總量視銳利度決定.小弟是使用500).2.再使用photoimpact 12(此軟件只使用一個方法小弟很常用).功能表裡特效--光線--手電茼.此功能會使整個片子產生您所需要的焦點.您可想像用手電同照會如何現象.此方法若是不熟悉或是沒軟件可暫時先擱下.以上有些名詞可能與版主會有所不同.若是不清楚的地方請再告知.謝謝
漂亮, 继续学习!
哇,牵手是台湾朋友还是香港啊
真好,学习了,但不知怎么学。
漂亮的弱光
越摇越好啊
这家伙,弱光专业户了哈,漂亮,这简直让人有些嫉妒了么!那天领导的专门组织拍弱光了撒,你就把JJ放包里,手背上专门做指导就行喽,哈哈
太有趣味了,下次摇卡的时候吼一声观摩一下,片一很美
牵手一调后,层次的质感出来喽,效果更棒!子愚同学要好好滴学习后期哈.!!我也要学.......别不带我啊!
确实不错,学习。
离拍摄地点2公里处的八一路农贸市场内有一家凉皮店,凉皮,味道,份量绝对赛过川疆凉皮,昌吉凉皮,石河子凉皮,是我吃过的新疆最好的凉皮。
凉皮子~~~一听见就口水流的不行了。。。
好拍手!欣赏!学习!
引用第40楼戈壁沙滩于 22:58发表的 :牵手一调后,层次的质感出来喽,效果更棒!子愚同学要好好滴学习后期哈.!!我也要学.......别不带我啊!是的,后期确实重要。只是我懒惰,看过牵手大师的调整后,有种欲望,学习!一定要增长知识!
依据牵手老师的指导,学习处理了一张PP,拍摄于山东聊城——东昌湖。
引用第46楼木子愚于 13:27发表的 :依据牵手老师的指导,学习处理了一张PP,拍摄于山东聊城——东昌湖。学习.对焦点,手电筒什么的任然不明白
引用第47楼安德于 16:26发表的 :学习.对焦点,手电筒什么的任然不明白對焦點是讓觀賞者的眼睛看片子時第一眼看的地方.小弟對版主大作修改後左下角對觀賞者有一種焦點的感覺.原片整體就沒有明顯焦點的地方.修改後 [attachment=49617]版主原作 [attachment=49618] -----------------------------------------------------------------------何謂手電筒 [attachment=49619]謝謝
引用第48楼牽手.于 23:39发表的 對焦點Re:八 一 水 库 行(P4学习一张) :對焦點是讓觀賞者的眼睛看片子時第一眼看的地方.小弟對版主大作修改後左下角對觀賞者有一種焦點的感覺.原片整體就沒有明顯焦點的地方.修改後.......左下角焦點的感覺.偶没有明显的感觉啊牽手.老师请再示范下或圈住.
查看完整版本: [--
Powered by
Time 0.048866 second(s),query:2 Gzip disabled下次自动登录
现在的位置:
& 综合 & 正文
P4递交建议流程:
1. p4 sync
2. 覆盖或者改动local文件
3. p4 delete or 直接delete 废弃的文件
4. p4 add: 增加新文件到depot
5. p4 diff -se: 查看编辑过的文件
6. p4 diff -se | p4 -x - edit: 把所有改动过的文件置为open for submit, 对于覆盖的文件 or没有用p4 edit的文件,需要这个命令, 才能将文件置为open状态, 才能方便递交
7. p4 diff -sd: 查看删除的文件(未用p4 delete删除的)
8. p4 diff -sd | p4 -x - delete: 置删除的文件为opened状态, 方便递交
9. p4 submit -d 'xxx': 递交
P4可以差分递交, 只要别人的递交没有影响到你的递交, 任何时候都可递交, 这一点, 和svn相同, 和git不同。
可以用p4 edit -k file将file设为opened状态。
p4 revert -a (file 可选): revert所有打开的已经存在的文件
p4 revert file: revrt 已经打开的已经存在的文件或者新add的文件
p4 sync -f: 强行同步到head changelist, 如果有打开的文件, 需要先revert
下面是网上的资料, 通用但不实用:
export P4PASSWD=abcdefg
export P4CLIENT=xxx
//这个可以不设
export P4USER=yyy
export P4PORT=ip:port
1. p4 client #配置本地信息,文件下载在哪里在这里面配置,Root项
2、p4 sync
#从perforce 下载文件
3、p4 login #登陆perforce
4、p4 help
#显示关于命令的帮助
#显示关于p4的帮助
6、 p4 labels ...
#显示和这个目录相关的标签
7、p4 sync @label #同步标签label中的所有文件
8、p4 files @label #查看标签label所包含的文件列表
9、p4 revert
#恢复所有打开的文件
10、p4 revert -n ... #恢复所有打开却没提交的文件
11、p4 branch brach
12、p4 integrate -b
#合并分支brach中描述的文件
13、p4 opened #查看打开的文件
14、p4 help commands #查看p4所有命令的帮助
15、4 dirs -H .
#显示当前目录
16、p4 branches
#显示所有的分支
17、 p4 delete filename
#从p4删除文件
18、p4 changelists -L ...
#显示当前目录下面所有文件的修改注释
19、p4 label label
#新建标签 label,编辑标签
20、p4 tag -l label ... #把当前目录下面的所有文件添加到标签 label
21、p4 changes ...
#当前目录的changelist
22、 p4 sync @10931
#sync file @changelist
23、 p4 sync
#only sync
24、p4 help revisions
#查看关于文件范围的帮助
export好变量之后,然后用1进行配置,就可以用p4 sync进行下载了
如果commandbar是目录则后面要加上/...,如果是文件的话就不用
在虚拟机上使用p4
一共分为如下几步:
要在 Linux 上用 P4 ,就需要虚拟机能够访问外网
安装及配置 P4
下面具体介绍一下各个步骤:(我称我们的工作机本身为“主机”)
配置虚拟机访问外部网络。设置步骤如下
1) 共享主机网卡
本地连接 -》 属性 -》高级 -》选择允许其它网络通过本...,并选择家庭网络连接为 VMware Network Adapter VMnet1
2) 设置虚拟机 IP 信息
选择 Traditional ….
3) 设置静态 IP
192.168.0. xxx
Subnet mask 255.255.255.0
192.168.0.1(编辑/etc/reslove.conf)
Default Gateway 192.168.0.1
安装及配置 P4
下载客户端
我使用的是 The Perforce Command-Line Client (P4)
把客户端放在文件夹 /usr/local/bin 。 这样能在任何目录直接使用 p4 命令
配置客户端,在线帮助有很多种方式,我使用配置文件方式。步骤如下
在 /usr 下面新建一个文件夹 p4config ( 可以自定义 ) ,在文件夹里面新建文件 p4.configfile.
用 VI 打卡 p4.configfile, 输入如下配置
P4CLIENT= (定义你的工作空间,比如 ygxu_xms )
P4PASSWD= (你的密码)
P4PORT=10.12.33.133:1700
P4USER= (你的用户名)
保存退出。
配置环境变量。修改后需要重启这个才生效
用 vi 打开 /etc/profile , 末尾处加入
# pv4 config file path
if test -z "$P4CONFIG" ; then
export P4CONFIG=/usr/p4config/p4.configfile
测试环境配置是否成功
命令 p4 info , 如果显示了连接信息,则 OK ,否则会提示连接不上
配置源代码环境
使用命令 p4 client 会有如下信息显示
你 上面配置的工作空 间
你 的用 户 名
Description:
Created by ygxu.
/home/hammer
noallwrite noclobber nocompress unlocked nomodtime normdir
SubmitOptions: submitunchanged
//XMS/SS7_Mainline/... //Arthur_Xms/XMS/SS7_Mainline/...
两个地方需要修改:
a . Root . 这个决定你的代码会放在什么地方,如上,我的是 /home/hammer
b. View. 这个决定你需要取哪些代码下来,因为一般不会把全部代码取下来,在 Linux 上我们一般只需要 XMS 的 SS7_Mainline, 所以把其他的删掉,修改成上面这个样子
注意事项,一定要保证空间足够,建议先删掉原来的 SS7_Mainline ,使用 Shrink 工具回收空间之后再取代码。
好了,使用 p4 sync 命令吧,就可以继续工作了!
关于 p4 的使用命令,文档如下:
更详细的命令格式参考
p4客户端下载
*************************************************************************************************************************
快速上手perforce
是什么?参考
先说说概念吧,一般来说版本控制软件都会分client和server,server负责做一些管理代码和文档仓库,控制各个用户的权限,记录版本升级历史之类的事情,client使用某种客户端连入server来完成代码、文档的修改、提交等工作,perforce也不例外。在server端perforce做得很精简,没有太多的依赖,一个p4d搞定,配置起来也很简单,它的主要任务就是管理一个文件仓库depot。在client端有user和workspace两个概念,user顾名思义就是在server上登记的一个用户,每个user可以拥有零个或者多个workspace,甚至也可以switch到别人的workspace上去,只要有权限。简单的说workspace是depot到本地的一个映射,例如这样写
//depot/foo/...
//myspace/bar/...就把depot里面foo目录下面所有东西映射到本地bar目录里面去了,myspace是和特定的workspace相关的,在设置workspace的时候可以设置它的绝对路径。
[连接之前的配置]
首先我们需要一个用户,假设已存在一个用户test,没有密码。
$P4CONFIG=p4conf. export P4CONFIG
windows下使用
p4 set P4CONFIG=p4conf.conf
这个命令设置一个环境变量P4CONFIG,文件名可以自己定义,里面可以存放客户端的配置。在UNIX系统中配置信息都可以写道环境变量里,windows下可以都写到注册表里去,不过我更倾向于在某一个目录下面建立一个,这样可以很方便的切换不同的workspace。然后我们就可以开始编辑这个p4conf.conf配置文件,格式很简单都是 setting=value 形式的。
建立一个workspace目录,在里面新建一个p4conf.conf文件,内容如下:
P4PORT=192.168.0.1:1666
P4USER=test
P4CLIENT=test-client
这是一个最简单的配置文件,P4PORT指名了服务器的ip和端口,ip也可以用计算机名代替,例如
P4PORT=p4server:1666
如果留空 P4PORT=1666 这样代表默认连接本地的server,如同 P4PORT=127.0.0.1:1666一样。
P4USER是用户名,P4CLIENT是当前是用的workspace名字,这个名字可以任意取,仅仅是一个标识。
这时候就可以cd到这个目录运行一下
看看输出是什么,如果显示了如下内容
User name: test
Client name: test-client
Client host: computername
Client unknown.
Current directory: /home/test/workspace
Client address: 127.0.0.1:1508
Server address: 192.168.0.1:1666
Server root: .
Server date:
00:28:12 +0800 China Standard Time
Server version: P4D/NTX86/189 ()
Server license: none
就表示成功连上服务器了,如果出现像这样的错误,那就要检查一下P4PORT有没有设置正确
Perforce client error:
Conn check $P4PORT.
TCP connect to 1666 failed.
connect: 1666: WSAECONNREFUSED
到这儿,最基本的client配置已经完成,很简单吧:-) 在配置文件里还可以存放一些其他的设置,例如
P4EDITOR指定在编辑的时候默认使用这个vim编辑器,P4DIFF指定了比较文件的时候使用的工具,
P4PASSWD当用户需要密码的时候可以提供一个默认密码,其他还有一些可以参考官方文档 P4 User's Guide
[连接之后的配置]
之前的所有设置都是保存在环境变量,配置文件或者注册表里面的,这仅仅定义了一个客户端的行为,很大一部分事情例如追踪用户的修改、打开、提交的文件之类都是由服务器记录下来的,所以现在我们需要通过一些命令来配置一下服务器那头的用户信息。
这个命令的结果是p4使用一个默认的编辑器打开一个临时文件,文件中保存着用户的一些信息,例如用户名,Email,FullName之类,用户可以自己修改其中某些设置,保存以后它会自动提交到服务器上更新用户设置。这个过程中使用的编辑器可以在环境变量或者配置文件中指定(P4EDITOR)。
$p4 client
和上面一样,这个命令编辑一个client的配置文件。Root对应于workspace在本机上的绝对路径,Options定义了一些client的属性,例如unlocked值允许其他的用户switch到你的工作空间,其他的定义可以参考官方文档。View的配置比较重要,它定义了服务器上面的文件到workspace的映射。例如
//depot/... //test-client/...
左右分别代表源地址和目的地址,中间以空格隔开,它的意思是将服务器depot里面所有文件映射到我的工作目录(在这之前用Root参数指定的绝对路径)。映射可以有多行:
//depot/src/... //test-client/local-src/...
//depot/doc/... //test-client/local-doc/...
这样就将代码和文档分别映射到本地,而且不一定要和服务器上使用相同的名字。在这之中也许会有需要排出的一些文件或者目录,这时只需要在映射前面加上一个减号:
-//depot/doc/file1.txt //test-client/local-doc/file1.txt
这样就排除了一个文件。在这个过程中要留意出现冲突,如下:
//depot/src/... //test-client/src/...
//depot/doc/... //test-client/src/...
将服务器上两个目录都映射到本地同一个目录。
上面的过程中使用了一种通配符“...”它递归的匹配这个目录以及子目录下面的所有文件,另一种上面没有使用的 “*” 匹配单个目录下的文件,例如 //test-client/src/*.c 匹配 src目录下面所有以 .c 作为扩展名的文件。
上面说了,如果把服务器上的两个目录都映射到本地通一个目录会产生冲突,后者会把前者覆盖,但如果这样写:
//depot/src/... //test-client/local-src/...
+//depot/doc/... //test-client/local-src/...
就会产生不同的效果,两个目录里面的文件都会出现在local-src这个目录中,不过如果仍然有重名的文件则后者会把前者覆盖。
至此,client的配置基本上完成,可以 $p4 sync 一下把服务器上的东西抓下来看看:-)
另外,如果要删除这个cient的话很简单 $p4 client -d test-client 就可以了
[文件管理]
配置了这么半天,现在开始步入正题,文件的管理才是我们使用perforce的核心工作。简单的说,文件操作可以分成三类:往depot里面添加文件,修改并提交文件和删除文件。
在这之前最好保证workspace里面文件和服务器上的最新版本同步,使用命令:
$p4 sync ...
如果需要同步到某一个版本,在后面添上 #1 数字代表版本号;如果需要强制同步所有文件,可以加上 -f 参数。关于sync的具体用法可以用命令
$p4 help sync
btw: 可以试试看$p4 help help
添加文件:
$p4 add *.txt
将当前目录下所有扩展名为txt的文件添加到depot相应目录,注意在添加文件的时候不可以使用通配符 ... 因为 ... 有服务器负责解析,这时候服务器并不知道需要添加什么文件,但却可以使用 * ,它是由shell负责解析。
另外,所有修改在submit之前都不会提交到服务器。
修改文件:
$p4 edit //depot/src/a.c
这个文件执行以后在服务器上就会记录下当前的 client已经在编辑这个文件,在本地只有一个动作,就是将a.c文件的只读属性去掉,这时候我们就可以随便使用某种编辑器来编辑这个文件了,在这之前所有文件都是只读的,而且不要手动去掉只读属性来编辑,因为那样服务器跟踪不到client的修改记录。
删除文件:
$p4 delete //depot/doc/a.pdf
注意在submit之前这个文件在服务器上也是不会被删除的。
撤销修改:
$p4 revert *.txt
这会将之前所有添加的或者修改的,以txt作为扩展名的文件全部撤销到原先的状态,原先添加的文件会被删除,修改的文件被还原到执行p4 sync时候的版本。
最后我们可以将上面所有修改全部提交:
$p4 submit
这时候p4会调用默认的或者P4EDITOR所指定的编辑器来编辑一个配置文件,里面包含了提交者的信息,对这次提交的描述以及列举出涉及到的文件等,一般来说把Description一项填充完保存就可以了。然后会看到屏幕上哗啦哗啦的输出一堆东西,最后显示 Change xxxx submitted. 就表示这次提交成功了。如果出现错误,有可能是存在冲突或者别的情况,关于冲突的问题留着后面再说~~_~~
文件之间的diff:
$p4 diff file
$p4 diff2 file1 file2
前者在client端进行比较,使用client端配置的工具,相对于perforce自带的diff我还是更喜欢vimdiff :-)后者在server端比较,返回两个文件(也可能是很多文件)之间的比较结果。
离线工作:
在线工作的时候所有文件的修改都由服务器来记录,文件的读写权限设置也是和服务器上同步的,但是一但离线就需要用另一种方法来管理workspace里面的文件了。
首先需要对那些等待修改的文件手动去掉只读属性,然后可以开始修改,等到和服务器建立连接的时候需要做两件事情:
1 找到所有修改过的文件,open for edit
$p4 diff -se | p4 -x - edit
2 找到所有删除的文件, open for delete
$p4 diff -sd | p4 -x - delete
最后 submit 就可以
下面是perforce diff详述:
概述对一个客户工作区中的文件和一个版本库中的文件版本进行比较语法
p4 [g-opts] diff [-dflag -f -m max -sa -sb-sd -se -sr -sl -t] ...] 描述
p4 diff 命令在Perforce客户端上运行一个diff, 对客户工作区中的文件和版本库中的版本文件进行比较。这个命令需要一个包含版本标识符的文件参数。如果包含了一个版本标识符,在客户工作区的文件会与该指定的版本文件进行比较。如果没有包含版本标识符,那么客户工作区的文件会与当前被编辑的版本(通常是最新的版本)进行比较。在这两种情况中,客户的文件都必须被打开编辑,或比较必须是对客户文件最后一个同步版本不同的版本文件进行比较。如果文件名包括通配符,那么所有打开得匹配该模板的文件都会被比较。如果没有提供文件参数,那么所有打开的文件会与他们在版本库中的相应文件进行比较。缺省情况下,diff 程序使用的是内建在p4客户程序中的。如果要改变diff 程序去运行一个外部程序,那么设置P4DIFF 环境变量或注册一个变量来指向这个新的程序。选项
强制进行比较 (如果没有版本标识符,那么于最新版本比较),即使客户文件没有打开进行编辑
传递选项给后面的diff 程序 (阅读下面的使用提示)
-m max 限定输出显示diffs(or status) 的第一个max 文件
只显示那些打开的与版本库里版本文件不同或不存在的文件的名字
只显示打开得已解析过给集成的,但是在解析后背修改过的文件的名字
只显示那么没有打开得没有存在与客户工作区中,但是在版本库中存在的文件的名字。
只显示没有打开的在客户工作区中但是与版本库中版本不同的文件的名字
只显示那些在客户工作区中打开的用来标识版本库中版本的文件的名字。
-sl file...
所有打开的文件与版本库进行比较,然后显示三种状态 same, diff, 或 missing.中的一种
If you use the -f flag together with the-sl flag, files that are open for edit are also compared and their status islisted.
-t 比较甚至文件类型不是文本类型的文件的不同
g-opts 阅读 全局选项部分
Can File Arguments Use Revision Specifier?
Can File Arguments Use Revision Range?
Minimal Access Level Required
p4 diff 支持的diff 选项有: 选项名字
RCS输出格式,显示文件中增加的和删除的以及相关行的内容
-dc 文本输出格式,显示行编号范围和三行变更内容
-ds 总结输出格式,只显示总共增加,删除或修改的行数量
unifiedoutput format, showing added and deleted lines with sufficient context forcompatibility with the patch(1) utility.
ignoreline-ending (CR/LF) convention when finding diffs
ignorechanges ma this flag implies -dl.
ignorew this flag implies -dl. l为了传递超过一个的选项给diff程序,可以打包他们。例如:
p4 diff -dub file
specifies a unified diff that ignores changes in whitespace.l?
The header line of a unifieddiff produced with the -du option for use with patch(1) displays filenames inPerforce syntax, not local syntax.举例
p4 diff file#5
将客户工作区中的“file”与版本库中的第五版本进行比较
将客户工作区中所有打开得文件与版本库中May 22, 1999修改的版本进行比较.
p4 diff -du file 对file 进行比较,显示符合patch(1) utility格式的输出.
p4 diff -sr | p4 -x - revert 恢复所有打开得没有修改过的文件。
This differs from p4 revert -a ( revert allunchanged files, where resolving a file, even if no changes are made, counts asa change), in that it reverts files whose workspace content matches the depotcontent, including resolved files that happen to be identical
to those in thedepot. 第一个命令显示所有打开得没有修改过的文件。The second command (running p4 -x and taking arguments, one perline, from standard input, abbreviated as "-") reverts each file inthat list.
(This is the UNIX verit uses a pipe. Most operating systems have some equivalent way of performingthese operations in series).
p4关于 -x 选项的更多信息,阅读 全局选项 部分
相关命令比较两个版本库中的文件版本的不同
p4 diff2 查看一个文件的全部内容
************************************************************************************************************************************
Perforce使用中文教程: p4 diff2
Perforce命令: p4 diff2
概述比较版本库中文件的两个版本语法
p4 [g-opts] diff2 [-dflags -q -t -u]file1[rev] file2[rev]
p4 [g-opts] diff2 [-dflags -q -t -u] -bbranch [[fromfile[rev]] tofile[rev]] 描述
p4 diff2 命令使用Perforce服务器中内建的diff程序对版本库中的俩个文件版本进行比较。这些版本通常是指同一个文件的两个不同的版本,但是他们也可以是两个完全不同文件的版本。如果没有没有提供版本给文件参数,那么最新的版本被用来比较。
p4 diff2 不使用由环境变量P4DIFF定义的diff程序。p4 diff命令使用的diff在装有Perforce服务器机器上运行,而且一直使用服务器内建的diff程序你可以在指定文件参数的位置指定一个有(或没有)版本标识的文件模版;这样可以导致Perforce对那些匹配模版的成对文件执行diff命令。如果你调用使用文件模版的p4 diff2命令,使用引号或反斜线可以从OS外壳中退出文件模版,那么确定在两个模版中的通配符相匹配。
Perforce presents the diffs in UNIX diffformat, prepended with a header. 起始部分的格式如下:
==== file1 (filetype1) - file2 (filetype2)==== summary
summary 可能出现的值和意义如下:
content: 文件版本的不同内容
types: 内容完全相同, 但是文件类型不同
identical: 版本的内容和文件类型都相同 如果文件file1 或 file2在指定的版本中不存在,那么起始部分将显示summary 为 &none&. 选项
Quietdiff. 只显示表头部分,并且在文件版本内容和类型不同时也不显示内容
把标准的UNIX diff 选项之一作为参数运行diff程序。阅读后面的《使用提示》
-b branchname
fromfile[rev] tofile[rev] 使用一个分支的定义去比较在两个分支代码行里的文件。被比较的文件可以被文件模版中的 fromfile或 tofile 里的任意一个所限定
比较甚至文件类型不是文本类型的文件的不同
Generateunified output format, showing added and deleted lines with sufficient contextfor compatibility with the patch(1) utility. Only those files that differ areincluded. File names and dates remain in Perforce syntax.
g-opts 阅读全局选项 部分 使用提示
Can File Arguments Use Revision Specifier?
Can File Arguments Use Revision Range?
Minimal Access Level Required
readaccess necessary for both file revisions
The diff flagssupported by p4 diff2 are: 选项名称
RCS输出格式,显示文件中增加的和删除的以及相关行的内容
-dc 文本输出格式,显示行编号范围和三行变更内容
-ds 总结输出格式,只显示总共增加,删除或修改的行数量
unified输出格式 showing added and deleted lines with sufficient context forcompatibility with the patch(1) utility.
-db 忽略在空格中做的改变
-dw 忽略连在一起的空格 为了传递超过一个的选项给diff 程序,可以打包他们。例如
p4 diff2 -dub file1 file2
specifies a unified diff that ignoreschanges in whitespace.
The header lineof a unified diff produced with the -du option for patch(1) use displays thediffed files in Perforce syntax, not local syntax.
当 p4 diff2 命令被用来对比较二进制文件时,该行
... files differ ... 会被显示出来,如果他们没有被识别的话。选项 -b branch [[fromfile[rev]] tofile[rev] ] 在第一次看见是可能觉得不正确。Since the branch specification maps fromfiles to tofiles, why wouldyou specify both fromfile and tofile file patterns? You wouldn't,
but thissyntax allows you to specify a fromfile file pattern and a tofile revision, ora fromfile revision and a tofile file pattern. 举例
p4 diff2 -ds file#1 file
比较 file 文件的第二个版本和最新版本,并显示文件中内容被添加,更改或删除的信息
file@34 file@
Diff the revision of file that was in thedepot after
34 was submitted against the revision in the depot atmidnight on December 4, 1998.
//depot/rel1/... //depot/rel2/...#4
比较在版本库 //depot/rel1 中的所有最新文件与版本库 //depot/rel2 第四个版本文件
//depot/rel1/* //depot/rel2/...
不允许。每个文件的通配符模式必须匹配
-b branch2 //depot/rel2/...#2 @50
Compare the second revision of the filesin //depot/rel2/... to the files branched from it by branch specificationbranch2 at the revision they were at in changelist 50.相关命令比较客户工作区中文件与版本库中的版本文件
查看一个文件的全部内容
&&&&推荐文章:
【上篇】【下篇】

我要回帖

更多关于 来年工作打算建议 的文章

 

随机推荐