Hi… I am well aware that this diff view is very suboptimal. It will be fixed when the refactored server comes along!
{group_,}index: Use name_desc_t
package main
import (
"net/http"
)
func handle_group_repos(w http.ResponseWriter, r *http.Request, params map[string]any) {
group_name := params["group_name"]
rows, err := database.Query(r.Context(), "SELECT r.name, COALESCE(r.description, '') FROM repos r JOIN groups g ON r.group_id = g.id WHERE g.name = $1;", group_name)
if err != nil {
http.Error(w, "Error getting groups: "+err.Error(), http.StatusInternalServerError)
return
}
defer rows.Close()
repos := []struct {
Name string
Description string
}{}
repos := []name_desc_t{}
for rows.Next() {
var repoName, repoDescription string
if err := rows.Scan(&repoName, &repoDescription); err != nil {
http.Error(w, "Error scanning repo: "+err.Error(), http.StatusInternalServerError)
return
}
repos = append(repos, struct {
Name string
Description string
}{repoName, repoDescription})
repos = append(repos, name_desc_t{repoName, repoDescription})
}
params["repos"] = repos
err = templates.ExecuteTemplate(w, "group_repos", params)
if err != nil {
http.Error(w, "Error rendering template: "+err.Error(), http.StatusInternalServerError)
return
}
}
package main
import (
"net/http"
)
func handle_index(w http.ResponseWriter, r *http.Request, params map[string]any) {
rows, err := database.Query(r.Context(), "SELECT name, COALESCE(description, '') FROM groups")
if err != nil {
http.Error(w, "Error querying groups: "+err.Error(), http.StatusInternalServerError)
return
}
defer rows.Close()
groups := []struct {
Name string
Description string
}{}
groups := []name_desc_t{}
for rows.Next() {
var groupName, groupDescription string
if err := rows.Scan(&groupName, &groupDescription); err != nil {
http.Error(w, "Error scanning group: "+err.Error(), http.StatusInternalServerError)
return
}
groups = append(groups, struct {
Name string
Description string
}{groupName, groupDescription})
groups = append(groups, name_desc_t{groupName, groupDescription})
}
if err := rows.Err(); err != nil {
http.Error(w, "Error iterating over rows: "+err.Error(), http.StatusInternalServerError)
return
}
params["groups"] = groups
err = templates.ExecuteTemplate(w, "index", params)
if err != nil {
http.Error(w, "Error rendering template: "+err.Error(), http.StatusInternalServerError)
return
}
}
package main
type name_desc_t struct {
Name string
Description string
}