Я пытаюсь взять на себя команду HEAD с помощью JGit:
val builder = new FileRepositoryBuilder()
val repo = builder.setGitDir(new File("/www/test-repo"))
.readEnvironment()
.findGitDir()
.build()
val walk: RevWalk = new RevWalk(repo, 100)
val head: ObjectId = repo.resolve(Constants.HEAD)
val headCommit: RevCommit = walk.parseCommit(head)
Я обнаружил, что он открывает репо, но значение head
установлено на null
. Интересно, почему он не может найти HEAD?
Я читаю эту документацию: http://wiki.eclipse.org/JGit/User_Guide
Репозиторий построен так же, как говорит документ, и RevWalk
. Я использую последнюю версию JGit, которая 2.0.0.201206130900-r
из http://download.eclipse.org/jgit/maven.
Мой вопрос: что мне нужно изменить в моем коде, чтобы заставить JGit возвращать действительные экземпляры RevCommit
вместо null
, как это сейчас делает?
Обновление: Этот код:
val git = new Git(repo)
val logs: Iterable[RevCommit] = git.log().call().asInstanceOf[Iterable[RevCommit]]
Дает мне это исключение: No HEAD exists and no explicit starting revision was specified
Исключение является нечетным, потому что простой git rev-parse HEAD
сообщает мне 0b0e8bf2cae9201f30833d93cc248986276a4d75
, что означает, что в репозитории есть HEAD. Я пробовал разные репозитории, мои и других людей.