本文介紹了JGit創建新的本地分支并推送到遠程(遠程上不存在分支)的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我正在處理一個ant任務,該任務調用一些使用JGit在Git存儲庫上創建新分支并將其推送到Remote的Java。我正在使用JGit 2.1.0。
代碼如下:
CreateBranchCommand bcc;
CheckoutCommand checkout;
Git git;
try {
Repository repo = new FileRepositoryBuilder().readEnvironment().findGitDir(src).build();
git = new Git(repo);
bcc = git.branchCreate();
checkout = git.checkout();
} catch (IOException e) {
throw new BuildException("Could not access repository " + src, e);
}
try {
bcc.setName(branch)
.setUpstreamMode(SetupUpstreamMode.SET_UPSTREAM)
.setStartPoint("origin/" + branch)
.setForce(force)
.call();
checkout.setName(branch);
checkout.call();
}
} catch (Exception e) {
throw new BuildException("Could not checkout repository " + src, e);
}
src變量設置為git存儲庫(已克隆)的路徑。
分支變量設置為:Release_2_0_2
force變量設置為:True或False(兩者我都有此問題)。
之后有一個單獨的ANT任務來執行推送。
運行上述代碼時,在第二個捕獲中捕獲到異常:
org.eclipse.jgit.api.errors.RefNotFoundException: Ref origin/release_2_0_2 can not be resolved
問題似乎出在setStartPoint("origin/" + branch)
,如果我將其硬編碼為”起源/主控”,它就會起作用。新分支即被創建。我只是嘗試在本地創建一個新的分支,然后將其推送到遠程。我以https://stackoverflow.com/a/12928374/1860867為例。
可能我誤解了CreateBranchCommand應該如何使用,我看到的所有示例都將起點設置為"origin/" + branch
。
任何建議/澄清都會有所幫助。
推薦答案
使用setStartPoint()
指定新分支應基于什么。setStartPoint
點將成為新分支的初始提交的提交。
如果沒有明確指定起始點,則默認為HEAD
。有關更多詳細信息,請參閱Git文檔:https://git-scm.com/docs/git-branch
因此起始點必須存在,而您所指的遠程分支顯然不存在。
setUpstreamMode()
如果您要創建新分支,setUpstreamMode()
也沒有用。用于在為現有遠程分支創建本地分支時配置跟蹤。但由于您還沒有遠程分支,因此不需要調用setUpstreamMode
。
創建本地分支后,使用PushCommand
將其發布到遠程。
git.push()
.setRemote("origin")
.setRefSpecs(new RefSpec("release_2_0_2:release_2_0_2"))
.call();
以上行將release_2_0_2
分支推送到已知的遠程origin
(您從中克隆的那個)。
帖子How do I do git push with JGit?提供了有關如何使用JGit推送的更多詳細信息。
這篇關于JGit創建新的本地分支并推送到遠程(遠程上不存在分支)的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,