1
0
mirror of https://shylinux.com/x/icebergs synced 2025-04-28 18:22:02 +08:00
This commit is contained in:
harveyshao 2021-08-02 22:50:17 +08:00
parent 3f6358dd61
commit 4ad70dc778
4 changed files with 48 additions and 18 deletions

View File

@ -35,6 +35,14 @@ func _cat_show(m *ice.Message, name string) {
defer f.Close() defer f.Close()
switch cb := m.Optionv(kit.Keycb(CAT)).(type) { switch cb := m.Optionv(kit.Keycb(CAT)).(type) {
case func(string, int) string:
list := []string{}
bio := bufio.NewScanner(f)
for i := 0; bio.Scan(); i++ {
list = append(list, cb(bio.Text(), i))
}
m.Echo(strings.Join(list, "\n") + "\n")
case func(string, int): case func(string, int):
bio := bufio.NewScanner(f) bio := bufio.NewScanner(f)
for i := 0; bio.Scan(); i++ { for i := 0; bio.Scan(); i++ {
@ -72,6 +80,10 @@ func _cat_show(m *ice.Message, name string) {
} }
} }
const (
PATH = "path"
SIZE = "size"
)
const CAT = "cat" const CAT = "cat"
func init() { func init() {

View File

@ -143,10 +143,11 @@ const ( // RENDER
RENDER_REDIRECT = "_redirect" RENDER_REDIRECT = "_redirect"
) )
const ( // PROCESS const ( // PROCESS
PROCESS_REFRESH = "_refresh" PROCESS_LOCATION = "_location"
PROCESS_REWRITE = "_rewrite" PROCESS_REFRESH = "_refresh"
PROCESS_FIELD = "_field" PROCESS_REWRITE = "_rewrite"
PROCESS_INNER = "_inner" PROCESS_FIELD = "_field"
PROCESS_INNER = "_inner"
PROCESS_HOLD = "_hold" PROCESS_HOLD = "_hold"
PROCESS_BACK = "_back" PROCESS_BACK = "_back"

View File

@ -16,14 +16,11 @@ const CMD = "cmd"
func init() { func init() {
Index.Merge(&ice.Context{ Index.Merge(&ice.Context{
Configs: map[string]*ice.Config{
CMD: {Name: CMD, Help: "命令", Value: kit.Data(kit.MDB_PATH, "./")},
},
Commands: map[string]*ice.Command{ Commands: map[string]*ice.Command{
"/cmd/": {Name: "/cmd/", Help: "命令", Action: map[string]*ice.Action{ "/cmd/": {Name: "/cmd/", Help: "命令", Action: map[string]*ice.Action{
ctx.COMMAND: {Name: "command", Help: "命令", Hand: func(m *ice.Message, arg ...string) { ctx.COMMAND: {Name: "command", Help: "命令", Hand: func(m *ice.Message, arg ...string) {
if len(arg) == 0 { if len(arg) == 0 {
m.Push("index", "cmd") m.Push("index", CMD)
m.Push("args", "") m.Push("args", "")
return return
} }
@ -34,30 +31,48 @@ func init() {
}}, }},
}, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) { }, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
if strings.HasSuffix(m.R.URL.Path, "/") { if strings.HasSuffix(m.R.URL.Path, "/") {
m.RenderDownload(path.Join(m.Conf(web.SERVE, kit.Keym(ice.VOLCANOS, kit.MDB_PATH)), "page/cmd.html")) m.RenderDownload(path.Join(m.Conf(web.SERVE, kit.Keym(ice.VOLCANOS, kit.MDB_PATH)), m.Conf(CMD, kit.Keym(kit.MDB_INDEX))))
return return
} }
m.RenderDownload(path.Join(m.Conf(CMD, kit.META_PATH), path.Join(arg...)))
switch p := path.Join(m.Conf(CMD, kit.META_PATH), path.Join(arg...)); kit.Ext(p) {
case "shy":
list := []interface{}{kit.Dict("index", "web.wiki.word", "args", []interface{}{p})}
m.RenderResult(kit.Format(m.Conf(CMD, kit.Keym(kit.MDB_TEMPLATE)), kit.Format(list)))
default:
m.RenderDownload(p)
}
}}, }},
"cmd": {Name: "cmd path auto up", Help: "命令", Action: map[string]*ice.Action{ CMD: {Name: "cmd path auto up", Help: "命令", Action: map[string]*ice.Action{
"up": {Name: "up", Help: "上一级", Hand: func(m *ice.Message, arg ...string) { "up": {Name: "up", Help: "上一级", Hand: func(m *ice.Message, arg ...string) {
if strings.TrimPrefix(m.R.URL.Path, "/cmd") == "/" { if strings.TrimPrefix(m.R.URL.Path, "/cmd") == "/" {
m.Cmdy("cmd") m.Cmdy(CMD)
return return
} }
if strings.HasSuffix(m.R.URL.Path, "/") { if strings.HasSuffix(m.R.URL.Path, "/") {
m.Process("_location", "../") m.ProcessLocation("../")
} else { } else {
m.Process("_location", "./") m.ProcessLocation("./")
} }
}}, }},
}, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) { }, Hand: func(m *ice.Message, c *ice.Context, cmd string, arg ...string) {
if len(arg) > 0 { if len(arg) > 0 {
m.Process("_location", arg[0]) m.ProcessLocation(arg[0])
return return
} }
m.Option(nfs.DIR_ROOT, path.Join(m.Conf(CMD, kit.META_PATH), strings.TrimPrefix(path.Dir(m.R.URL.Path), "/cmd"))) m.Option(nfs.DIR_ROOT, path.Join(m.Conf(CMD, kit.META_PATH), strings.TrimPrefix(path.Dir(m.R.URL.Path), "/cmd")))
m.Cmdy(nfs.DIR, arg) m.Cmdy(nfs.DIR, arg)
}}, }},
}}) },
Configs: map[string]*ice.Config{
CMD: {Name: CMD, Help: "命令", Value: kit.Data(
kit.MDB_PATH, "./", kit.MDB_INDEX, "page/cmd.html", kit.MDB_TEMPLATE, `
<!DOCTYPE html>
<body><script src="/page/can.js"></script>
<script>app("/chat/", %s)</script>
</body>
`,
)},
},
})
} }

View File

@ -140,9 +140,11 @@ func (m *Message) Process(action string, arg ...interface{}) {
m.Option(MSG_PROCESS, action) m.Option(MSG_PROCESS, action)
m.Option("_arg", arg...) m.Option("_arg", arg...)
} }
func (m *Message) ProcessLocation(arg ...interface{}) {
m.Process(PROCESS_LOCATION, arg...)
}
func (m *Message) ProcessRewrite(arg ...interface{}) { func (m *Message) ProcessRewrite(arg ...interface{}) {
m.Process(PROCESS_REWRITE) m.Process(PROCESS_REWRITE, arg...)
m.Option("_arg", arg...)
} }
func (m *Message) ProcessRefresh(delay string) { func (m *Message) ProcessRefresh(delay string) {
if d, e := time.ParseDuration(delay); e == nil { if d, e := time.ParseDuration(delay); e == nil {