使用 git2go 添加和提交新文件
Adding and committing a new file with git2go
我目前正在努力将文件暂存并提交到内存中的 git 存储库(即不将文件写入磁盘、添加和提交)
这是我的代码的简化版本;它 几乎 有效
package main
import (
"fmt"
"gopkg.in/libgit2/git2go.v25"
"time"
)
func main() {
sig := &git.Signature{
Name: "Some Person",
Email: "somebody@something.org",
When: time.Now(),
}
repo, err := git.OpenRepository("./repo")
check(err)
defer repo.Free()
content := []byte("hello world")
index, err := repo.Index()
check(err)
oid, err := repo.CreateBlobFromBuffer(content)
check(err)
ie := git.IndexEntry{
Mode: git.FilemodeBlob,
Id: oid,
Path: "documents/document_9.md",
}
err = index.Add(&ie)
check(err)
treeId, err := index.WriteTree()
check(err)
tree, err := repo.LookupTree(treeId)
check(err)
index.Write()
currentBranch, err := repo.Head()
check(err)
currentTip, err := repo.LookupCommit(currentBranch.Target())
check(err)
commitId, err := repo.CreateCommit("HEAD", sig, sig, "A new commit", tree, currentTip)
check(err)
fmt.Println(commitId)
}
func check(err error) {
if err != nil {
panic(err)
}
}
但是,当我 运行 它并查看 ./repo
时,有些地方不太对劲。从 git status
中可以看出,新的 document_9.md
文件被标记为已删除(即 git 知道它但不存在)
❯ git status
On branch master
Changes not staged for commit:
(use "git add/rm <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
deleted: documents/document_9.md
查看日志,确认提交确实有效:
❯ git log --patch
commit a609b43e6a3f7da7d0589971ab0f64f3f432e76c
Author: Some Person <somebody@something.org>
Date: Thu Mar 23 19:43:56 2017 +0000
a new commit
diff --git a/documents/document_9.md b/documents/document_9.md
new file mode 100644
index 0000000..95d09f2
--- /dev/null
+++ b/documents/document_9.md
@@ -0,0 +1 @@
+hello world
\ No newline at end of file
commit 668762279b51483c05dbdedcf3c599a1b41c203b
Author: Original Committer <someguy@something.com>
Date: Thu Mar 23 19:42:52 2017 +0000
First commit
diff --git a/documents/docment_1.md b/documents/docment_1.md
new file mode 100644
index 0000000..2965834
--- /dev/null
+++ b/documents/docment_1.md
@@ -0,0 +1 @@
+# Hello World
我认为我错过了一步。我需要以某种方式确保我的提交是 'synced' 文件系统。我 认为 (根据文档),这是由 index.Write()
和 index.WriteTree()
实现的,但我无法让它工作。
任何正确方向的推动都将不胜感激。
如果您希望工作目录与新 HEAD 提交的状态相匹配,那么您需要检查它(例如,使用相当于 git_checkout_head
的 go)。
git_index_write_tree
将树对象写入对象数据库,git_index_write
将索引的内存表示写入磁盘。都不影响工作目录。
我目前正在努力将文件暂存并提交到内存中的 git 存储库(即不将文件写入磁盘、添加和提交)
这是我的代码的简化版本;它 几乎 有效
package main
import (
"fmt"
"gopkg.in/libgit2/git2go.v25"
"time"
)
func main() {
sig := &git.Signature{
Name: "Some Person",
Email: "somebody@something.org",
When: time.Now(),
}
repo, err := git.OpenRepository("./repo")
check(err)
defer repo.Free()
content := []byte("hello world")
index, err := repo.Index()
check(err)
oid, err := repo.CreateBlobFromBuffer(content)
check(err)
ie := git.IndexEntry{
Mode: git.FilemodeBlob,
Id: oid,
Path: "documents/document_9.md",
}
err = index.Add(&ie)
check(err)
treeId, err := index.WriteTree()
check(err)
tree, err := repo.LookupTree(treeId)
check(err)
index.Write()
currentBranch, err := repo.Head()
check(err)
currentTip, err := repo.LookupCommit(currentBranch.Target())
check(err)
commitId, err := repo.CreateCommit("HEAD", sig, sig, "A new commit", tree, currentTip)
check(err)
fmt.Println(commitId)
}
func check(err error) {
if err != nil {
panic(err)
}
}
但是,当我 运行 它并查看 ./repo
时,有些地方不太对劲。从 git status
中可以看出,新的 document_9.md
文件被标记为已删除(即 git 知道它但不存在)
❯ git status
On branch master
Changes not staged for commit:
(use "git add/rm <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
deleted: documents/document_9.md
查看日志,确认提交确实有效:
❯ git log --patch
commit a609b43e6a3f7da7d0589971ab0f64f3f432e76c
Author: Some Person <somebody@something.org>
Date: Thu Mar 23 19:43:56 2017 +0000
a new commit
diff --git a/documents/document_9.md b/documents/document_9.md
new file mode 100644
index 0000000..95d09f2
--- /dev/null
+++ b/documents/document_9.md
@@ -0,0 +1 @@
+hello world
\ No newline at end of file
commit 668762279b51483c05dbdedcf3c599a1b41c203b
Author: Original Committer <someguy@something.com>
Date: Thu Mar 23 19:42:52 2017 +0000
First commit
diff --git a/documents/docment_1.md b/documents/docment_1.md
new file mode 100644
index 0000000..2965834
--- /dev/null
+++ b/documents/docment_1.md
@@ -0,0 +1 @@
+# Hello World
我认为我错过了一步。我需要以某种方式确保我的提交是 'synced' 文件系统。我 认为 (根据文档),这是由 index.Write()
和 index.WriteTree()
实现的,但我无法让它工作。
任何正确方向的推动都将不胜感激。
如果您希望工作目录与新 HEAD 提交的状态相匹配,那么您需要检查它(例如,使用相当于 git_checkout_head
的 go)。
git_index_write_tree
将树对象写入对象数据库,git_index_write
将索引的内存表示写入磁盘。都不影响工作目录。