您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“Rugged::Reference和Rugged::Branch類(lèi)怎么用”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Rugged::Reference和Rugged::Branch類(lèi)怎么用”吧!
Rugged::Reference類(lèi)
Reference可以是Branch,Remote Branch, Tag, AnnotationTag或者指向其他Reference, 每個(gè)Reference都指向一個(gè)target,該target可以是一個(gè)Reference,或者AnnotationTag,此時(shí)Reference.type=:symbolic, 如果target是一個(gè)Commit,則Reference.type = :direct
a)獲取Rugged::Reference對(duì)象
refs = repo.references#Rugged::ReferenceCollection ref = refs["ref_name"] refs.each#迭代 refs.each_name#按名字迭代 refs.exist?(name)#是否存在 refs.exists?(name)#是否存在
b)基本方法
valid_name?(ref_name) -> true or false
檢查reference name 是否well-formed(良構(gòu))
peel -> oid
??
name canonical_name
獲取reference的名稱(chēng)
type -> :symbolic or :direct
獲取reference的類(lèi)型
target ref1.type #=> :symbolic ref.1.target => #<Rugged::Reference ...> ref1.target_id #=> "refs/heads/master" ref2.type #=> :direct ref2.target #=> #<Rugged::Commit ...> ref2.target_id #=> "de5ba987198bcf2518885f0fc1350e5172cded78"
獲獲取指向的target和target_id。如果reference是一個(gè)symbolic reference,則返回target reference對(duì)象。如果reference是一個(gè)直接的reference,則target對(duì)象。
resolve -> peeled_ref r1.type #=> :symbolic r1.name #=> 'HEAD' r1.target #=> 'refs/heads/master' r2 = r1.resolve #=> #<Rugged::Reference:0x401b3948> r2.target #=> '9d09060c850defbc7711d08b57def0d14e742f4e'
獲取symbolic reference指向的target reference
branch?-> true or false
判斷當(dāng)前reference是否為本地的分支
remote? -> true or false
判斷當(dāng)前reference是否是遠(yuǎn)程分支
tag? -> true or false
判斷當(dāng)前reference是否為標(biāo)簽
log log? -> true or false --是否有reflog reference.log #=> [ # { # :id_old => nil, --改變之前的oid # :id_new => '9d09060c850defbc7711d08b57def0d14e742f4e', --新oid # :committer => {:name => 'Vicent Marti', :email => {'vicent@github.com'}}, # :message => 'created reference' # }, ... ]
2. Rugged::Branch類(lèi)(繼承Rugged::Reference)
a)獲取Rugged::Branch對(duì)象
branches = repo.branches #Rugged::BranchCollection branch = branches["branch_name"] branch.each brach.each_name
b)基本方法
==(other)
判斷兩個(gè)分支是否相等
head? → true or false
是否HEAD指向當(dāng)前分支
name → string
獲取分支名
remote_name → string
獲取分支所屬的遠(yuǎn)程名
remote()
獲取當(dāng)前分支的所屬遠(yuǎn)程
upstream → branch upstream = branch
獲取和設(shè)置遠(yuǎn)程的跟蹤branch, 參數(shù)branch為Rugged::Branch或這Rugged::Reference
3. Rugged::Tag類(lèi)(繼承Rugged::Reference)
a)獲取Rugged::Tag對(duì)象
tags = repo.tags #Rugged::TagCollection tag = tags["tag_name"] tags.each tags.each_name
b)基本方法
message #=> "Release v0.16.0, codename 'broken stuff'"
獲取tag的message
name #=> "v0.16.0"
獲取tag名
tagger #=> {:email=>"tanoku@gmail.com", :time=>Tue Jan 24 05:42:45 UTC 2012, :name=>"Vicent Mart\303\255"}
獲取tag的author signature(簽名)
target_oid #=> "2cb831a8aea28b2c1b9c63385585b864e4d3bad1" target_id #=> "2cb831a8aea28b2c1b9c63385585b864e4d3bad1"
獲取指向?qū)ο蟮膐id
type #=>:blob,:commit,:tree,:tag
獲取指向?qū)ο蟮念?lèi)型
target -> git_object
獲取tag指向的target
到此,相信大家對(duì)“Rugged::Reference和Rugged::Branch類(lèi)怎么用”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。