mirror of
https://shylinux.com/x/icebergs
synced 2025-04-28 18:22:02 +08:00
opt some
This commit is contained in:
parent
3f6358dd61
commit
4ad70dc778
@ -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() {
|
||||||
|
9
conf.go
9
conf.go
@ -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"
|
||||||
|
@ -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>
|
||||||
|
`,
|
||||||
|
)},
|
||||||
|
},
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user