kyra/tool.go

56 lines
1.1 KiB
Go
Raw Normal View History

2024-06-09 16:26:31 +03:00
package tht
2024-06-09 15:16:38 +03:00
import (
"github.com/d5/tengo/v2"
2024-06-09 16:26:31 +03:00
"surdeus.su/util/tht/mdx"
2024-06-09 15:16:38 +03:00
"surdeus.su/core/cli/mtool"
"net/http"
"log"
)
// Simple PHP-like server implementation.
var Tool = mtool.T("tht").Func(func(flags *mtool.Flags) {
var (
addr, ext, src, mod, index string
2024-06-09 16:26:31 +03:00
noLog bool
2024-06-09 15:16:38 +03:00
)
flags.StringVar(&addr, "addr", ":3000", "address to serve at")
flags.StringVar(&mod, "mod", "./mod", "path to store Tengo modules")
flags.StringVar(&src, "src", "./src", "directory with source files")
flags.StringVar(&ext, "ext", ".tpp", "extension for TPP files")
flags.StringVar(&index, "index", "index.htm", "index file name")
2024-06-09 16:26:31 +03:00
flags.BoolVar(
&noLog,
"no-log",
false,
"disable logging",
)
2024-06-09 15:16:38 +03:00
flags.Parse()
2024-06-09 16:26:31 +03:00
handler := &LoggerMiddle{
After: NewHandler(
2024-06-09 15:16:38 +03:00
DefaultPP(mod),
src, ext, index,
map[string] tengo.Object{},
).SetMD(mdx.MakeDefaultMarkdown()),
}
2024-06-09 16:26:31 +03:00
if !noLog {
handler.Logger = log.Default()
}
srv := &http.Server{
Addr: addr,
Handler: handler,
}
2024-06-09 15:16:38 +03:00
log.Printf("Listening on %q\n", addr)
err := srv.ListenAndServe()
if err != nil {
log.Printf("Error: srv.ListenAndServe(...): %s\n", err)
}
})