aboutsummaryrefslogtreecommitdiff
path: root/ref.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-02-11 23:13:04 +0800
committerRunxi Yu <me@runxiyu.org>2025-02-11 23:15:51 +0800
commitb288beea9ddc5709769997a9101f25a78e286b89 (patch)
treedb548c0ca63f180b25acb6f9822ab38bc41c15d0 /ref.go
parentstyle.css: Fix file content background (diff)
downloadforge-b288beea9ddc5709769997a9101f25a78e286b89.tar.gz
forge-b288beea9ddc5709769997a9101f25a78e286b89.tar.zst
forge-b288beea9ddc5709769997a9101f25a78e286b89.zip
*: Use URL params to specify commits/branches/tags
Diffstat (limited to '')
-rw-r--r--ref.go46
1 files changed, 46 insertions, 0 deletions
diff --git a/ref.go b/ref.go
new file mode 100644
index 0000000..19856e7
--- /dev/null
+++ b/ref.go
@@ -0,0 +1,46 @@
+package main
+
+import (
+ "errors"
+
+ "github.com/go-git/go-git/v5"
+ "github.com/go-git/go-git/v5/plumbing"
+ "go.lindenii.runxiyu.org/lindenii-common/misc"
+)
+
+var (
+ err_getting_tag_reference = errors.New("Error getting tag reference")
+ err_getting_branch_reference = errors.New("Error getting branch reference")
+ err_getting_head = errors.New("Error getting HEAD")
+)
+
+func get_ref_hash_from_type_and_name(repo *git.Repository, ref_type, ref_name string) (ref_hash plumbing.Hash, ret_err error) {
+ switch ref_type {
+ case "head":
+ head, err := repo.Head()
+ if err != nil {
+ ret_err = misc.Wrap_one_error(err_getting_head, err)
+ return
+ }
+ ref_hash = head.Hash()
+ case "commit":
+ ref_hash = plumbing.NewHash(ref_name)
+ case "branch":
+ ref, err := repo.Reference(plumbing.NewBranchReferenceName(ref_name), true)
+ if err != nil {
+ ret_err = misc.Wrap_one_error(err_getting_branch_reference, err)
+ return
+ }
+ ref_hash = ref.Hash()
+ case "tag":
+ ref, err := repo.Reference(plumbing.NewTagReferenceName(ref_name), true)
+ if err != nil {
+ ret_err = misc.Wrap_one_error(err_getting_tag_reference, err)
+ return
+ }
+ ref_hash = ref.Hash()
+ default:
+ panic("Invalid ref type " + ref_type)
+ }
+ return
+}