diff options
author | Runxi Yu <me@runxiyu.org> | 2025-02-13 00:31:48 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-02-13 00:32:01 +0800 |
commit | d87f80d3e14990e5d9fc83990ff04e29affa3a94 (patch) | |
tree | 5df543f16b96388c1dc7c6456c24d8b0d66b9d5d /handle_repo_tree.go | |
parent | README.md: Add a bit of detail (diff) | |
download | forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.gz forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.zst forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.zip |
*.go: Mass rename files for clarity
Diffstat (limited to 'handle_repo_tree.go')
-rw-r--r-- | handle_repo_tree.go | 115 |
1 files changed, 0 insertions, 115 deletions
diff --git a/handle_repo_tree.go b/handle_repo_tree.go deleted file mode 100644 index 1dc06a8..0000000 --- a/handle_repo_tree.go +++ /dev/null @@ -1,115 +0,0 @@ -package main - -import ( - "bytes" - "errors" - "html/template" - "net/http" - "path" - "strings" - - chroma_formatters_html "github.com/alecthomas/chroma/v2/formatters/html" - chroma_lexers "github.com/alecthomas/chroma/v2/lexers" - chroma_styles "github.com/alecthomas/chroma/v2/styles" - "github.com/go-git/go-git/v5/plumbing/object" -) - -func handle_repo_tree(w http.ResponseWriter, r *http.Request, params map[string]string) { - data := make(map[string]any) - data["global"] = global_data - raw_path_spec := params["rest"] - group_name, repo_name, path_spec := params["group_name"], params["repo_name"], strings.TrimSuffix(raw_path_spec, "/") - ref_type, ref_name, err := get_param_ref_and_type(r) - if err != nil { - if errors.Is(err, err_no_ref_spec) { - ref_type = "head" - } else { - _, _ = w.Write([]byte("Error querying ref type: " + err.Error())) - return - } - } - data["ref_type"], data["ref"], data["group_name"], data["repo_name"], data["path_spec"] = ref_type, ref_name, group_name, repo_name, path_spec - repo, err := open_git_repo(r.Context(), group_name, repo_name) - if err != nil { - _, _ = w.Write([]byte("Error opening repo: " + err.Error())) - return - } - ref_hash, err := get_ref_hash_from_type_and_name(repo, ref_type, ref_name) - if err != nil { - _, _ = w.Write([]byte("Error getting ref hash: " + err.Error())) - return - } - commit_object, err := repo.CommitObject(ref_hash) - if err != nil { - _, _ = w.Write([]byte("Error getting commit object: " + err.Error())) - return - } - tree, err := commit_object.Tree() - if err != nil { - _, _ = w.Write([]byte("Error getting file tree: " + err.Error())) - return - } - - var target *object.Tree - if path_spec == "" { - target = tree - } else { - target, err = tree.Tree(path_spec) - if err != nil { - file, err := tree.File(path_spec) - if err != nil { - _, _ = w.Write([]byte("Error retrieving path: " + err.Error())) - return - } - if len(raw_path_spec) != 0 && raw_path_spec[len(raw_path_spec)-1] == '/' { - http.Redirect(w, r, "../"+path_spec, http.StatusSeeOther) - return - } - file_contents, err := file.Contents() - if err != nil { - _, _ = w.Write([]byte("Error reading file: " + err.Error())) - return - } - lexer := chroma_lexers.Match(path_spec) - if lexer == nil { - lexer = chroma_lexers.Fallback - } - iterator, err := lexer.Tokenise(nil, file_contents) - if err != nil { - _, _ = w.Write([]byte("Error tokenizing code: " + err.Error())) - return - } - var formatted_unencapsulated bytes.Buffer - style := chroma_styles.Get("autumn") - formatter := chroma_formatters_html.New(chroma_formatters_html.WithClasses(true), chroma_formatters_html.TabWidth(8)) - err = formatter.Format(&formatted_unencapsulated, style, iterator) - if err != nil { - _, _ = w.Write([]byte("Error formatting code: " + err.Error())) - return - } - formatted_encapsulated := template.HTML(formatted_unencapsulated.Bytes()) - data["file_contents"] = formatted_encapsulated - - err = templates.ExecuteTemplate(w, "repo_tree_file", data) - if err != nil { - _, _ = w.Write([]byte("Error rendering template: " + err.Error())) - return - } - return - } - } - - if len(raw_path_spec) != 0 && raw_path_spec[len(raw_path_spec)-1] != '/' { - http.Redirect(w, r, path.Base(path_spec)+"/", http.StatusSeeOther) - return - } - - data["readme_filename"], data["readme"] = render_readme_at_tree(target) - data["files"] = build_display_git_tree(target) - - err = templates.ExecuteTemplate(w, "repo_tree_dir", data) - if err != nil { - _, _ = w.Write([]byte("Error rendering template: " + err.Error())) - return - } -} |