mirror of
https://shylinux.com/x/icebergs
synced 2025-04-28 10:12:02 +08:00
opt some
This commit is contained in:
parent
604213d2f0
commit
7505c4f55f
@ -174,7 +174,7 @@ const (
|
|||||||
const HASH = "hash"
|
const HASH = "hash"
|
||||||
|
|
||||||
func HashAction(args ...Any) ice.Actions {
|
func HashAction(args ...Any) ice.Actions {
|
||||||
return ice.Actions{ice.CTX_INIT: AutoConfig(args...),
|
return ice.Actions{ice.CTX_INIT: AutoConfig(args...), ice.CTX_EXIT: {Hand: func(m *ice.Message, arg ...string) { HashSelectClose(m) }},
|
||||||
INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) { HashInputs(m, arg) }},
|
INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) { HashInputs(m, arg) }},
|
||||||
CREATE: {Name: "create", Help: "创建", Hand: func(m *ice.Message, arg ...string) { HashCreate(m, arg) }},
|
CREATE: {Name: "create", Help: "创建", Hand: func(m *ice.Message, arg ...string) { HashCreate(m, arg) }},
|
||||||
REMOVE: {Name: "remove", Help: "删除", Hand: func(m *ice.Message, arg ...string) { HashRemove(m, arg) }},
|
REMOVE: {Name: "remove", Help: "删除", Hand: func(m *ice.Message, arg ...string) { HashRemove(m, arg) }},
|
||||||
@ -334,11 +334,13 @@ func HashSelectValue(m *ice.Message, cb Any) *ice.Message {
|
|||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
func HashSelectClose(m *ice.Message) *ice.Message {
|
func HashSelectClose(m *ice.Message) *ice.Message {
|
||||||
HashSelectValue(m, func(target ice.Any) {
|
HashSelectValue(m, func(value ice.Map) {
|
||||||
|
target := value[TARGET]
|
||||||
if c, ok := target.(io.Closer); ok {
|
if c, ok := target.(io.Closer); ok {
|
||||||
m.Logs(DELETE, TARGET, m.PrefixKey())
|
m.Logs(DELETE, TARGET, m.PrefixKey())
|
||||||
c.Close()
|
c.Close()
|
||||||
}
|
}
|
||||||
|
delete(value, TARGET)
|
||||||
})
|
})
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
@ -94,8 +94,8 @@ const (
|
|||||||
COMMENT = "comment"
|
COMMENT = "comment"
|
||||||
KEYWORD = "keyword"
|
KEYWORD = "keyword"
|
||||||
CONSTANT = "constant"
|
CONSTANT = "constant"
|
||||||
FUNCTION = "function"
|
|
||||||
DATATYPE = "datatype"
|
DATATYPE = "datatype"
|
||||||
|
FUNCTION = "function"
|
||||||
)
|
)
|
||||||
const (
|
const (
|
||||||
SPLIT = "split"
|
SPLIT = "split"
|
||||||
|
@ -2,7 +2,6 @@ package code
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"io"
|
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"path"
|
"path"
|
||||||
@ -18,7 +17,14 @@ import (
|
|||||||
kit "shylinux.com/x/toolkits"
|
kit "shylinux.com/x/toolkits"
|
||||||
)
|
)
|
||||||
|
|
||||||
func _xterm_get(m *ice.Message, h string) *os.File {
|
type _xterm struct {
|
||||||
|
*exec.Cmd
|
||||||
|
*os.File
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s _xterm) Close() error { s.Cmd.Process.Kill(); return nil }
|
||||||
|
|
||||||
|
func _xterm_get(m *ice.Message, h string) _xterm {
|
||||||
t := mdb.HashSelectField(m, m.Option(mdb.HASH, h), mdb.TYPE)
|
t := mdb.HashSelectField(m, m.Option(mdb.HASH, h), mdb.TYPE)
|
||||||
mdb.HashModify(m, mdb.TEXT, m.Option(ice.MSG_DAEMON))
|
mdb.HashModify(m, mdb.TEXT, m.Option(ice.MSG_DAEMON))
|
||||||
return mdb.HashTarget(m, h, func() ice.Any {
|
return mdb.HashTarget(m, h, func() ice.Any {
|
||||||
@ -30,20 +36,10 @@ func _xterm_get(m *ice.Message, h string) *os.File {
|
|||||||
m.Assert(err)
|
m.Assert(err)
|
||||||
|
|
||||||
m.Go(func() {
|
m.Go(func() {
|
||||||
m.Logs(cli.DAEMON, ice.CMD, ls)
|
|
||||||
defer web.PushNoticeGrow(m, ice.EXIT)
|
|
||||||
mdb.HashSelectUpdate(m, h, func(value ice.Map) {
|
|
||||||
value["_cmd"] = nfs.NewCloser(func() error {
|
|
||||||
m.Option(ice.MSG_DAEMON, mdb.HashSelectField(m, h, mdb.TEXT))
|
|
||||||
web.PushNoticeGrow(m, ice.EXIT)
|
|
||||||
return cmd.Process.Kill()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
m.Option("log.disable", ice.TRUE)
|
m.Option("log.disable", ice.TRUE)
|
||||||
buf := make([]byte, ice.MOD_BUFS)
|
buf := make([]byte, ice.MOD_BUFS)
|
||||||
for {
|
for {
|
||||||
if n, e := tty.Read(buf); !m.Warn(e) {
|
if n, e := tty.Read(buf); !m.Warn(e) && e == nil {
|
||||||
m.Option(ice.MSG_DAEMON, mdb.HashSelectField(m, h, mdb.TEXT))
|
m.Option(ice.MSG_DAEMON, mdb.HashSelectField(m, h, mdb.TEXT))
|
||||||
m.Option(mdb.TEXT, string(buf[:n]))
|
m.Option(mdb.TEXT, string(buf[:n]))
|
||||||
web.PushNoticeGrow(m)
|
web.PushNoticeGrow(m)
|
||||||
@ -52,8 +48,8 @@ func _xterm_get(m *ice.Message, h string) *os.File {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
return tty
|
return _xterm{cmd, tty}
|
||||||
}).(*os.File)
|
}).(_xterm)
|
||||||
}
|
}
|
||||||
|
|
||||||
const XTERM = "xterm"
|
const XTERM = "xterm"
|
||||||
@ -61,13 +57,6 @@ const XTERM = "xterm"
|
|||||||
func init() {
|
func init() {
|
||||||
Index.MergeCommands(ice.Commands{
|
Index.MergeCommands(ice.Commands{
|
||||||
XTERM: {Name: "xterm hash auto", Help: "终端", Actions: ice.MergeActions(ice.Actions{
|
XTERM: {Name: "xterm hash auto", Help: "终端", Actions: ice.MergeActions(ice.Actions{
|
||||||
ice.CTX_EXIT: {Hand: func(m *ice.Message, arg ...string) {
|
|
||||||
mdb.HashSelectValue(m, func(value ice.Map) {
|
|
||||||
if c, ok := value["_cmd"].(io.Closer); ok {
|
|
||||||
c.Close()
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}},
|
|
||||||
mdb.INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) {
|
mdb.INPUTS: {Name: "inputs", Help: "补全", Hand: func(m *ice.Message, arg ...string) {
|
||||||
switch mdb.HashInputs(m, arg); arg[0] {
|
switch mdb.HashInputs(m, arg); arg[0] {
|
||||||
case mdb.TYPE:
|
case mdb.TYPE:
|
||||||
@ -76,17 +65,9 @@ func init() {
|
|||||||
m.Push(arg[0], path.Base(m.Option(mdb.TYPE)))
|
m.Push(arg[0], path.Base(m.Option(mdb.TYPE)))
|
||||||
}
|
}
|
||||||
}},
|
}},
|
||||||
mdb.CREATE: {Name: "create type name background", Help: "创建"},
|
mdb.CREATE: {Name: "create type=sh name=xterm", Help: "创建"},
|
||||||
mdb.REMOVE: {Name: "remove", Help: "删除", Hand: func(m *ice.Message, arg ...string) {
|
|
||||||
mdb.HashSelectDetail(m, m.Option(mdb.HASH), func(value ice.Map) {
|
|
||||||
if c, ok := value["_cmd"].(io.Closer); ok {
|
|
||||||
c.Close()
|
|
||||||
}
|
|
||||||
})
|
|
||||||
mdb.HashRemove(m)
|
|
||||||
}},
|
|
||||||
"resize": {Name: "resize", Help: "大小", Hand: func(m *ice.Message, arg ...string) {
|
"resize": {Name: "resize", Help: "大小", Hand: func(m *ice.Message, arg ...string) {
|
||||||
pty.Setsize(_xterm_get(m, m.Option(mdb.HASH)), &pty.Winsize{Rows: uint16(kit.Int(m.Option("rows"))), Cols: uint16(kit.Int(m.Option("cols")))})
|
pty.Setsize(_xterm_get(m, m.Option(mdb.HASH)).File, &pty.Winsize{Rows: uint16(kit.Int(m.Option("rows"))), Cols: uint16(kit.Int(m.Option("cols")))})
|
||||||
}},
|
}},
|
||||||
"input": {Name: "input", Help: "输入", Hand: func(m *ice.Message, arg ...string) {
|
"input": {Name: "input", Help: "输入", Hand: func(m *ice.Message, arg ...string) {
|
||||||
if b, e := base64.StdEncoding.DecodeString(strings.Join(arg, "")); !m.Warn(e) {
|
if b, e := base64.StdEncoding.DecodeString(strings.Join(arg, "")); !m.Warn(e) {
|
||||||
@ -97,7 +78,7 @@ func init() {
|
|||||||
_xterm_get(m, kit.Select(m.Option(mdb.HASH), arg, 0)).Write([]byte(m.Cmdx(PUBLISH, ice.CONTEXTS, INSTALL) + ice.NL))
|
_xterm_get(m, kit.Select(m.Option(mdb.HASH), arg, 0)).Write([]byte(m.Cmdx(PUBLISH, ice.CONTEXTS, INSTALL) + ice.NL))
|
||||||
m.ProcessHold()
|
m.ProcessHold()
|
||||||
}},
|
}},
|
||||||
}, mdb.HashAction(mdb.FIELD, "time,hash,type,name,text"), ctx.CmdAction()), Hand: func(m *ice.Message, arg ...string) {
|
}, mdb.HashAction(mdb.FIELD, "time,hash,type,name,text")), Hand: func(m *ice.Message, arg ...string) {
|
||||||
if mdb.HashSelect(m, arg...); len(arg) == 0 {
|
if mdb.HashSelect(m, arg...); len(arg) == 0 {
|
||||||
m.Action(mdb.CREATE, mdb.PRUNES)
|
m.Action(mdb.CREATE, mdb.PRUNES)
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user