Hi… I am well aware that this diff view is very suboptimal. It will be fixed when the refactored server comes along!
{main,resources}.go: Serve static/ properly
package main
import (
	"flag"
	"net"
	"net/http"
	"go.lindenii.runxiyu.org/lindenii-common/clog"
)
func main() {
	config_path := flag.String(
		"config",
		"/etc/lindenii/forge.scfg",
		"path to configuration file",
	)
	flag.Parse()
	err := load_config(*config_path)
	if err != nil {
		clog.Fatal(1, "Loading configuration: "+err.Error())
	}
	err = load_templates()
	if err != nil {
		clog.Fatal(1, "Loading templates: "+err.Error())
	}
	
	err = serve_static()
	if err != nil {
		clog.Fatal(1, "Serving static: "+err.Error())
	}
	http.HandleFunc("/{$}", handle_index)
	http.HandleFunc("/{project_name}/repos/{repo_name}/", handle_repo_index)
	listener, err := net.Listen(config.HTTP.Net, config.HTTP.Addr)
	if err != nil {
		clog.Fatal(1, "Listening: "+err.Error())
	}
	http.Serve(listener, nil)
}
package main
import (
	"embed"
	"html/template"
	"io/fs"
	"net/http"
)
//go:embed templates/* static/*
var resources_fs embed.FS
var templates *template.Template
func load_templates() (err error) {
	templates, err = template.ParseFS(resources_fs, "templates/*")
	return err
}
func serve_static() (err error) {
	static_fs, err := fs.Sub(resources_fs, "static")
	if err != nil {
		return err
	}
	http.Handle("/static/",
	http.Handle("/static/{name}",
http.StripPrefix( "/static/", http.FileServer(http.FS(static_fs)), ), ) return nil }