mirror of
https://shylinux.com/x/ContextOS
synced 2025-04-26 09:14:06 +08:00
tce add nfs.View 添加了历史浏览
This commit is contained in:
parent
03b1438e0b
commit
d5935c615d
@ -161,9 +161,10 @@ func (cli *CLI) Begin(m *ctx.Message, arg ...string) ctx.Server { // {{{
|
|||||||
case "target":
|
case "target":
|
||||||
}
|
}
|
||||||
|
|
||||||
ps = append(ps, "\033[32m")
|
// ps = append(ps, "\033[32m")
|
||||||
ps = append(ps, cli.target.Name)
|
ps = append(ps, cli.target.Name)
|
||||||
ps = append(ps, "\033[0m> ")
|
ps = append(ps, "> ")
|
||||||
|
// ps = append(ps, "\033[0m> ")
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
ps = append(ps, "[")
|
ps = append(ps, "[")
|
||||||
@ -731,6 +732,11 @@ var Index = &ctx.Context{Name: "cli", Help: "管理中心",
|
|||||||
m.Put("append", "target", cli.target)
|
m.Put("append", "target", cli.target)
|
||||||
}
|
}
|
||||||
}},
|
}},
|
||||||
|
"seed": &ctx.Command{Name: "seed", Help: "函数调用, name: 函数名, arg: 参数", Hand: func(m *ctx.Message, c *ctx.Context, key string, arg ...string) {
|
||||||
|
for i := 0; i < 100; i++ {
|
||||||
|
m.Echo("%d\n", i)
|
||||||
|
}
|
||||||
|
}},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,9 +26,12 @@ type NFS struct {
|
|||||||
|
|
||||||
in *os.File
|
in *os.File
|
||||||
out *os.File
|
out *os.File
|
||||||
buf []string
|
|
||||||
cli *ctx.Message
|
cli *ctx.Message
|
||||||
x, y int
|
buf []string
|
||||||
|
pages []string
|
||||||
|
|
||||||
|
x, y, width, height int
|
||||||
|
|
||||||
*ctx.Message
|
*ctx.Message
|
||||||
*ctx.Context
|
*ctx.Context
|
||||||
@ -36,14 +39,43 @@ type NFS struct {
|
|||||||
|
|
||||||
func (nfs *NFS) print(str string, arg ...interface{}) bool { // {{{
|
func (nfs *NFS) print(str string, arg ...interface{}) bool { // {{{
|
||||||
switch {
|
switch {
|
||||||
|
case nfs.out != nil:
|
||||||
|
str := fmt.Sprintf(str, arg...)
|
||||||
|
fmt.Fprintf(nfs.out, "%s", str)
|
||||||
|
|
||||||
|
ls := strings.Split(str, "\n")
|
||||||
|
for i, l := range ls {
|
||||||
|
rest := ""
|
||||||
|
|
||||||
|
if len(nfs.pages) > 0 && !strings.HasSuffix(nfs.pages[len(nfs.pages)-1], "\n") {
|
||||||
|
rest = nfs.pages[len(nfs.pages)-1]
|
||||||
|
nfs.pages = nfs.pages[:len(nfs.pages)-1]
|
||||||
|
}
|
||||||
|
|
||||||
|
if i == len(ls)-1 {
|
||||||
|
nfs.pages = append(nfs.pages, rest+l)
|
||||||
|
} else {
|
||||||
|
nfs.pages = append(nfs.pages, rest+l+"\n")
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(l) > 0 && nfs.width > 0 {
|
||||||
|
nfs.y += len(l) / nfs.width
|
||||||
|
if len(l)%nfs.width == 0 && len(l) > 0 {
|
||||||
|
nfs.y--
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if nfs.y += len(ls) - 1; strings.HasSuffix(str, "\n") {
|
||||||
|
nfs.x = 0
|
||||||
|
} else {
|
||||||
|
nfs.x = len(ls[len(ls)-1])
|
||||||
|
}
|
||||||
|
|
||||||
case nfs.io != nil:
|
case nfs.io != nil:
|
||||||
str := fmt.Sprintf(str, arg...)
|
str := fmt.Sprintf(str, arg...)
|
||||||
nfs.y += strings.Count(str, "\n")
|
nfs.y += strings.Count(str, "\n")
|
||||||
fmt.Fprintf(nfs.in, "%s", str)
|
fmt.Fprintf(nfs.in, "%s", str)
|
||||||
case nfs.out != nil:
|
|
||||||
str := fmt.Sprintf(str, arg...)
|
|
||||||
nfs.y += strings.Count(str, "\n")
|
|
||||||
fmt.Fprintf(nfs.out, "%s", str)
|
|
||||||
default:
|
default:
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
@ -51,25 +83,120 @@ func (nfs *NFS) print(str string, arg ...interface{}) bool { // {{{
|
|||||||
}
|
}
|
||||||
|
|
||||||
// }}}
|
// }}}
|
||||||
func (nfs *NFS) clear(line string) {
|
func (nfs *NFS) clear(arg ...string) { // {{{
|
||||||
termbox.SetCursor(nfs.x, nfs.y)
|
line := ""
|
||||||
termbox.Flush()
|
rest := ""
|
||||||
nfs.print(" ")
|
if len(arg) > 0 {
|
||||||
|
line = arg[0]
|
||||||
termbox.SetCursor(nfs.x, nfs.y)
|
|
||||||
termbox.Flush()
|
|
||||||
|
|
||||||
nfs.print("%s%s", nfs.cli.Conf("PS1"), line)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
func (nfs *NFS) Read(p []byte) (n int, err error) {
|
if len(arg) > 1 {
|
||||||
|
rest = arg[1]
|
||||||
|
}
|
||||||
|
termbox.SetCursor(0, nfs.y)
|
||||||
|
termbox.Flush()
|
||||||
|
fmt.Fprintf(nfs.out, strings.Repeat(" ", nfs.width))
|
||||||
|
|
||||||
|
termbox.SetCursor(0, nfs.y)
|
||||||
|
termbox.Flush()
|
||||||
|
|
||||||
|
ps := nfs.cli.Conf("PS1")
|
||||||
|
|
||||||
|
fmt.Fprintf(nfs.out, "%s%s%s", ps, line, rest)
|
||||||
|
|
||||||
|
termbox.SetCursor(len(ps)+len(line), nfs.y)
|
||||||
|
termbox.Flush()
|
||||||
|
}
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
func (nfs *NFS) insert(rest []rune, letters []rune) []rune { // {{{
|
||||||
|
n := len(rest)
|
||||||
|
l := len(letters)
|
||||||
|
rest = append(rest, letters...)
|
||||||
|
for i := n - 1; i >= 0; i-- {
|
||||||
|
rest[i+l] = rest[i]
|
||||||
|
}
|
||||||
|
for i := 0; i < l; i++ {
|
||||||
|
rest[i] = letters[i]
|
||||||
|
}
|
||||||
|
return rest
|
||||||
|
}
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
|
||||||
|
func (nfs *NFS) page(buf []string, pos int) { // {{{
|
||||||
|
termbox.SetCursor(0, 0)
|
||||||
|
termbox.Sync()
|
||||||
|
begin := pos
|
||||||
|
|
||||||
|
for i := 0; i < nfs.height-1; i++ {
|
||||||
|
if pos < len(buf) && pos >= 0 {
|
||||||
|
if len(buf[pos]) > nfs.width {
|
||||||
|
fmt.Fprintf(nfs.out, "%s", buf[pos][:nfs.width])
|
||||||
|
} else {
|
||||||
|
fmt.Fprintf(nfs.out, "%s", buf[pos])
|
||||||
|
}
|
||||||
|
pos++
|
||||||
|
} else {
|
||||||
|
fmt.Fprintln(nfs.out)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fmt.Fprintf(nfs.out, "%d %d", len(nfs.pages), begin)
|
||||||
|
}
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
func (nfs *NFS) View() { // {{{
|
||||||
|
pos := len(nfs.pages) - nfs.height
|
||||||
|
nfs.page(nfs.pages, pos)
|
||||||
|
for {
|
||||||
|
switch ev := termbox.PollEvent(); ev.Type {
|
||||||
|
case termbox.EventKey:
|
||||||
|
switch ev.Key {
|
||||||
|
case termbox.KeyCtrlC:
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
switch ev.Ch {
|
||||||
|
case 'f':
|
||||||
|
if pos+nfs.height < len(nfs.pages) {
|
||||||
|
pos += nfs.height - 1
|
||||||
|
}
|
||||||
|
case 'b':
|
||||||
|
if pos-nfs.height > 0 {
|
||||||
|
pos -= nfs.height - 1
|
||||||
|
} else {
|
||||||
|
pos = 0
|
||||||
|
}
|
||||||
|
case 'j':
|
||||||
|
if pos+1 < len(nfs.pages) {
|
||||||
|
pos += 1
|
||||||
|
}
|
||||||
|
case 'k':
|
||||||
|
if pos-1 > 0 {
|
||||||
|
pos -= 1
|
||||||
|
} else {
|
||||||
|
pos = 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
nfs.page(nfs.pages, pos)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
func (nfs *NFS) Read(p []byte) (n int, err error) { // {{{
|
||||||
if nfs.Cap("stream") != "stdio" {
|
if nfs.Cap("stream") != "stdio" {
|
||||||
return nfs.in.Read(p)
|
return nfs.in.Read(p)
|
||||||
}
|
}
|
||||||
|
|
||||||
his := len(nfs.buf)
|
nfs.width, nfs.height = termbox.Size()
|
||||||
|
|
||||||
buf := make([]rune, 0, 1024)
|
buf := make([]rune, 0, 1024)
|
||||||
|
rest := make([]rune, 0, 1024)
|
||||||
|
|
||||||
back := buf
|
back := buf
|
||||||
|
|
||||||
|
his := len(nfs.buf) - 1
|
||||||
|
|
||||||
tab := []string{}
|
tab := []string{}
|
||||||
tabi := 0
|
tabi := 0
|
||||||
|
|
||||||
@ -77,70 +204,119 @@ func (nfs *NFS) Read(p []byte) (n int, err error) {
|
|||||||
switch ev := termbox.PollEvent(); ev.Type {
|
switch ev := termbox.PollEvent(); ev.Type {
|
||||||
case termbox.EventKey:
|
case termbox.EventKey:
|
||||||
switch ev.Key {
|
switch ev.Key {
|
||||||
case termbox.KeyCtrlC, termbox.KeyCtrlD:
|
case termbox.KeyCtrlC:
|
||||||
termbox.Close()
|
termbox.Close()
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
case termbox.KeyCtrlJ, termbox.KeyEnter:
|
|
||||||
|
case termbox.KeyCtrlV:
|
||||||
|
nfs.View()
|
||||||
|
|
||||||
|
case termbox.KeyCtrlL:
|
||||||
|
termbox.Sync()
|
||||||
|
nfs.y = 0
|
||||||
|
|
||||||
|
case termbox.KeyCtrlJ, termbox.KeyCtrlM:
|
||||||
tab = tab[:0]
|
tab = tab[:0]
|
||||||
|
|
||||||
|
buf = append(buf, rest...)
|
||||||
buf = append(buf, '\n')
|
buf = append(buf, '\n')
|
||||||
nfs.print("\n")
|
nfs.print("\n")
|
||||||
nfs.y++
|
|
||||||
|
|
||||||
b := []byte(string(buf[:len(buf)]))
|
b := []byte(string(buf[:len(buf)]))
|
||||||
n = len(b)
|
n = len(b)
|
||||||
copy(p, b)
|
copy(p, b)
|
||||||
nfs.Log("info", nil, "get %d %d %s", len(b), len(p), p)
|
|
||||||
return
|
return
|
||||||
|
|
||||||
case termbox.KeyCtrlP:
|
case termbox.KeyCtrlP:
|
||||||
|
for i := 0; i < len(nfs.buf); i++ {
|
||||||
his = (his + len(nfs.buf) - 1) % len(nfs.buf)
|
his = (his + len(nfs.buf) - 1) % len(nfs.buf)
|
||||||
b := nfs.buf[his]
|
if strings.HasPrefix(nfs.buf[his], string(buf)) {
|
||||||
buf = buf[:len(b)]
|
rest = rest[:0]
|
||||||
n := copy(buf, []rune(b))
|
rest = append(rest, []rune(nfs.buf[his][len(buf):])...)
|
||||||
buf = buf[:n]
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
nfs.clear(string(buf))
|
|
||||||
case termbox.KeyCtrlN:
|
case termbox.KeyCtrlN:
|
||||||
his = (his + len(nfs.buf) - 1) % len(nfs.buf)
|
for i := 0; i < len(nfs.buf); i++ {
|
||||||
b := nfs.buf[his]
|
his = (his + len(nfs.buf) + 1) % len(nfs.buf)
|
||||||
buf = buf[:len(b)]
|
if strings.HasPrefix(nfs.buf[his], string(buf)) {
|
||||||
n := copy(buf, []rune(b))
|
rest = rest[:0]
|
||||||
buf = buf[:n]
|
rest = append(rest, []rune(nfs.buf[his][len(buf):])...)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
nfs.clear(string(buf))
|
case termbox.KeyCtrlA:
|
||||||
case termbox.KeyCtrlH:
|
if len(buf) == 0 {
|
||||||
if len(buf) > 0 {
|
continue
|
||||||
|
}
|
||||||
|
rest = nfs.insert(rest, buf)
|
||||||
|
buf = buf[:0]
|
||||||
|
|
||||||
|
case termbox.KeyCtrlE:
|
||||||
|
if len(rest) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
buf = append(buf, rest...)
|
||||||
|
rest = rest[:0]
|
||||||
|
|
||||||
|
case termbox.KeyCtrlB:
|
||||||
|
if len(buf) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
rest = nfs.insert(rest, []rune{buf[len(buf)-1]})
|
||||||
buf = buf[:len(buf)-1]
|
buf = buf[:len(buf)-1]
|
||||||
nfs.clear(string(buf))
|
|
||||||
n--
|
case termbox.KeyCtrlF:
|
||||||
|
if len(rest) == 0 {
|
||||||
|
continue
|
||||||
}
|
}
|
||||||
case termbox.KeyCtrlL:
|
buf = append(buf, rest[0])
|
||||||
termbox.Sync()
|
rest = rest[1:]
|
||||||
nfs.y = 0
|
|
||||||
nfs.clear(string(buf))
|
case termbox.KeyCtrlH:
|
||||||
|
if len(buf) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
buf = buf[:len(buf)-1]
|
||||||
|
|
||||||
|
case termbox.KeyCtrlD:
|
||||||
|
if len(rest) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
rest = rest[1:]
|
||||||
|
|
||||||
case termbox.KeyCtrlU:
|
case termbox.KeyCtrlU:
|
||||||
tab = tab[:0]
|
|
||||||
nfs.clear("")
|
|
||||||
if len(buf) > 0 {
|
if len(buf) > 0 {
|
||||||
back = buf
|
back = back[:0]
|
||||||
|
back = append(back, buf...)
|
||||||
}
|
}
|
||||||
buf = make([]rune, 0, 1024)
|
|
||||||
n = 0
|
|
||||||
case termbox.KeyCtrlY:
|
|
||||||
buf = back
|
|
||||||
n = len(buf)
|
|
||||||
nfs.clear(string(buf))
|
|
||||||
case termbox.KeyTab:
|
|
||||||
if len(tab) == 0 {
|
|
||||||
tab = tab[:0]
|
tab = tab[:0]
|
||||||
|
|
||||||
|
buf = buf[:0]
|
||||||
|
|
||||||
|
case termbox.KeyCtrlK:
|
||||||
|
if len(rest) > 0 {
|
||||||
|
back = back[:0]
|
||||||
|
back = append(back, rest...)
|
||||||
|
}
|
||||||
|
rest = rest[:0]
|
||||||
|
|
||||||
|
case termbox.KeyCtrlY:
|
||||||
|
buf = append(buf, back...)
|
||||||
|
|
||||||
|
case termbox.KeyCtrlI:
|
||||||
|
if len(tab) == 0 {
|
||||||
tabi = 0
|
tabi = 0
|
||||||
|
prefix := string(buf)
|
||||||
msg := nfs.Message.Spawn(nfs.cli.Target())
|
msg := nfs.Message.Spawn(nfs.cli.Target())
|
||||||
target := msg.Cmd("target").Data["target"].(*ctx.Context)
|
target := msg.Cmd("target").Data["target"].(*ctx.Context)
|
||||||
msg.Spawn(target).BackTrace(func(msg *ctx.Message) bool {
|
msg.Spawn(target).BackTrace(func(msg *ctx.Message) bool {
|
||||||
for k, _ := range msg.Target().Commands {
|
for k, _ := range msg.Target().Commands {
|
||||||
if strings.HasPrefix(k, string(buf)) {
|
if strings.HasPrefix(k, prefix) {
|
||||||
tab = append(tab, k)
|
tab = append(tab, k[len(prefix):])
|
||||||
nfs.Log("info", nil, "add %s", k)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true
|
return true
|
||||||
@ -148,32 +324,36 @@ func (nfs *NFS) Read(p []byte) (n int, err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if tabi >= 0 && tabi < len(tab) {
|
if tabi >= 0 && tabi < len(tab) {
|
||||||
nfs.Log("info", nil, "get %d %d %s", len(tab), tabi, tab[tabi])
|
rest = rest[:0]
|
||||||
buf = buf[:len(tab[tabi])]
|
rest = append(rest, []rune(tab[tabi])...)
|
||||||
n := copy(buf, []rune(tab[tabi]))
|
|
||||||
buf = buf[:n]
|
|
||||||
nfs.clear(string(buf))
|
|
||||||
tabi = (tabi + 1) % len(tab)
|
tabi = (tabi + 1) % len(tab)
|
||||||
}
|
}
|
||||||
|
|
||||||
case termbox.KeySpace:
|
case termbox.KeySpace:
|
||||||
tab = tab[:0]
|
tab = tab[:0]
|
||||||
nfs.print(" ")
|
|
||||||
buf = append(buf, ' ')
|
buf = append(buf, ' ')
|
||||||
n++
|
|
||||||
|
if len(rest) == 0 {
|
||||||
|
nfs.print(" ")
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
tab = tab[:0]
|
tab = tab[:0]
|
||||||
nfs.Log("fuck", nil, "%v", ev.Ch)
|
|
||||||
nfs.print(string(ev.Ch))
|
|
||||||
buf = append(buf, ev.Ch)
|
buf = append(buf, ev.Ch)
|
||||||
n++
|
if len(rest) == 0 {
|
||||||
|
nfs.print(string(ev.Ch))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
nfs.clear(string(buf), string(rest))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// }}}
|
||||||
|
|
||||||
func (nfs *NFS) Spawn(m *ctx.Message, c *ctx.Context, arg ...string) ctx.Server { // {{{
|
func (nfs *NFS) Spawn(m *ctx.Message, c *ctx.Context, arg ...string) ctx.Server { // {{{
|
||||||
c.Caches = map[string]*ctx.Cache{
|
c.Caches = map[string]*ctx.Cache{
|
||||||
"pos": &ctx.Cache{Name: "读写位置", Value: "0", Help: "读写位置"},
|
"pos": &ctx.Cache{Name: "读写位置", Value: "0", Help: "读写位置"},
|
||||||
|
Loading…
x
Reference in New Issue
Block a user