mirror of
https://shylinux.com/x/icebergs
synced 2025-04-26 09:34:05 +08:00
opt bash
This commit is contained in:
parent
7d16a8280d
commit
3dfc379d69
@ -59,7 +59,7 @@ func _space_dial(m *ice.Message, dev, name string, arg ...string) {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
ls := strings.Split(host, ":")
|
ls := strings.Split(host, ":")
|
||||||
msg.Cmd(tcp.CLIENT, tcp.DIAL, kit.MDB_TYPE, "wss", kit.MDB_NAME, dev, tcp.HOST, ls[0], tcp.PORT, ls[1])
|
msg.Cmd(tcp.CLIENT, tcp.DIAL, kit.MDB_TYPE, "wss", kit.MDB_NAME, dev, tcp.HOST, ls[0], tcp.PORT, kit.Select("443", ls, 1))
|
||||||
|
|
||||||
// 断线重连
|
// 断线重连
|
||||||
sleep := time.Duration(rand.Intn(kit.Int(redial["a"])*i+2)+kit.Int(redial["b"])) * time.Millisecond
|
sleep := time.Duration(rand.Intn(kit.Int(redial["a"])*i+2)+kit.Int(redial["b"])) * time.Millisecond
|
||||||
|
@ -16,6 +16,21 @@ import (
|
|||||||
kit "github.com/shylinux/toolkits"
|
kit "github.com/shylinux/toolkits"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type Buffer struct {
|
||||||
|
data []byte
|
||||||
|
m *ice.Message
|
||||||
|
n string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Buffer) Write(buf []byte) (int, error) {
|
||||||
|
b.data = append(b.data, buf...)
|
||||||
|
b.m.Cmd(web.SPACE, b.n, "grow", string(buf))
|
||||||
|
return len(buf), nil
|
||||||
|
}
|
||||||
|
func (b *Buffer) Close() error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
const PREPARE = "prepare"
|
const PREPARE = "prepare"
|
||||||
const INSTALL = "install"
|
const INSTALL = "install"
|
||||||
|
|
||||||
@ -31,47 +46,48 @@ func init() {
|
|||||||
web.DOWNLOAD: {Name: "download link", Help: "下载", Hand: func(m *ice.Message, arg ...string) {
|
web.DOWNLOAD: {Name: "download link", Help: "下载", Hand: func(m *ice.Message, arg ...string) {
|
||||||
link := m.Option(kit.MDB_LINK)
|
link := m.Option(kit.MDB_LINK)
|
||||||
name := path.Base(link)
|
name := path.Base(link)
|
||||||
p := path.Join(m.Conf(INSTALL, kit.META_PATH), name)
|
file := path.Join(m.Conf(INSTALL, kit.META_PATH), name)
|
||||||
|
|
||||||
m.Option(ice.MSG_PROCESS, ice.PROCESS_PROGRESS)
|
defer m.Cmdy(nfs.DIR, file)
|
||||||
m.Option(mdb.FIELDS, m.Conf(INSTALL, kit.META_FIELD))
|
if _, e := os.Stat(file); e == nil {
|
||||||
if m.Cmd(mdb.SELECT, INSTALL, "", mdb.HASH, kit.MDB_NAME, name).Table(func(index int, value map[string]string, head []string) {
|
return // 文件存在
|
||||||
if _, e := os.Stat(p); e == nil {
|
|
||||||
m.Push("", value, kit.Split(m.Option(mdb.FIELDS)))
|
|
||||||
}
|
|
||||||
}); len(m.Appendv(kit.MDB_NAME)) > 0 {
|
|
||||||
return // 已经下载
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 占位
|
// 文件占位
|
||||||
m.Cmd(nfs.SAVE, p, "")
|
m.Cmd(nfs.SAVE, file, "")
|
||||||
|
|
||||||
|
m.GoToast("download", func(toast func(string, int, int)) {
|
||||||
// 进度
|
// 进度
|
||||||
m.Cmd(mdb.INSERT, INSTALL, "", mdb.HASH, kit.MDB_NAME, name, kit.MDB_LINK, link)
|
m.Cmd(mdb.INSERT, INSTALL, "", mdb.HASH, kit.MDB_NAME, name, kit.MDB_LINK, link)
|
||||||
m.Richs(INSTALL, "", name, func(key string, value map[string]interface{}) {
|
m.Richs(INSTALL, "", name, func(key string, value map[string]interface{}) {
|
||||||
value = kit.GetMeta(value)
|
value = kit.GetMeta(value)
|
||||||
|
|
||||||
|
p := 0
|
||||||
m.Optionv(web.DOWNLOAD_CB, func(size int, total int) {
|
m.Optionv(web.DOWNLOAD_CB, func(size int, total int) {
|
||||||
s := size * 100 / total
|
if n := size * 100 / total; p != n {
|
||||||
if s != kit.Int(value[kit.SSH_STEP]) && s%10 == 0 {
|
value[kit.SSH_STEP], value[kit.MDB_SIZE], value[kit.MDB_TOTAL] = n, size, total
|
||||||
m.Log_IMPORT(kit.MDB_FILE, name, kit.SSH_STEP, s, kit.MDB_SIZE, kit.FmtSize(int64(size)), kit.MDB_TOTAL, kit.FmtSize(int64(total)))
|
toast(name, size, total)
|
||||||
|
p = n
|
||||||
}
|
}
|
||||||
value[kit.SSH_STEP], value[kit.MDB_SIZE], value[kit.MDB_TOTAL] = s, size, total
|
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
// 下载
|
// 下载
|
||||||
m.Go(func() {
|
|
||||||
os.MkdirAll(m.Option(cli.CMD_DIR, m.Conf(INSTALL, kit.META_PATH)), ice.MOD_DIR)
|
os.MkdirAll(m.Option(cli.CMD_DIR, m.Conf(INSTALL, kit.META_PATH)), ice.MOD_DIR)
|
||||||
msg := m.Cmd(web.SPIDE, web.SPIDE_DEV, web.SPIDE_CACHE, web.SPIDE_GET, link)
|
msg := m.Cmd(web.SPIDE, web.SPIDE_DEV, web.SPIDE_CACHE, web.SPIDE_GET, link)
|
||||||
|
|
||||||
m.Cmdy(nfs.LINK, p, msg.Append(kit.MDB_FILE))
|
// 解压
|
||||||
|
m.Cmdy(nfs.LINK, file, msg.Append(kit.MDB_FILE))
|
||||||
m.Cmd(cli.SYSTEM, "tar", "xvf", name)
|
m.Cmd(cli.SYSTEM, "tar", "xvf", name)
|
||||||
})
|
})
|
||||||
}},
|
}},
|
||||||
gdb.BUILD: {Name: "build link", Help: "构建", Hand: func(m *ice.Message, arg ...string) {
|
gdb.BUILD: {Name: "build link", Help: "构建", Hand: func(m *ice.Message, arg ...string) {
|
||||||
cli.Follow(m, gdb.BUILD, func() {
|
|
||||||
defer m.Cmdy(cli.OUTPUT, mdb.MODIFY, kit.MDB_STATUS, cli.Status.Stop)
|
m.Option(cli.CMD_OUTPUT, &Buffer{m: m, n: m.Option(ice.MSG_DAEMON)})
|
||||||
defer m.Option(kit.MDB_HASH, m.Option("cache.hash"))
|
defer func() {
|
||||||
|
m.Toast("success", "build")
|
||||||
|
m.ProcessHold()
|
||||||
|
}()
|
||||||
|
|
||||||
p := m.Option(cli.CMD_DIR, path.Join(m.Conf(INSTALL, kit.META_PATH), kit.TrimExt(m.Option(kit.MDB_LINK))))
|
p := m.Option(cli.CMD_DIR, path.Join(m.Conf(INSTALL, kit.META_PATH), kit.TrimExt(m.Option(kit.MDB_LINK))))
|
||||||
pp := kit.Path(path.Join(p, "_install"))
|
pp := kit.Path(path.Join(p, "_install"))
|
||||||
@ -79,18 +95,16 @@ func init() {
|
|||||||
case func(string):
|
case func(string):
|
||||||
cb(p)
|
cb(p)
|
||||||
default:
|
default:
|
||||||
if m.Cmdy(cli.SYSTEM, "./configure", "--prefix="+pp, arg[1:]); m.Append(cli.CMD_CODE) != "0" {
|
if m.Cmd(cli.SYSTEM, "./configure", "--prefix="+pp, arg[1:]).Append(cli.CMD_CODE) != "0" {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if m.Cmdy(cli.SYSTEM, "make", "-j8"); m.Append(cli.CMD_CODE) != "0" {
|
if m.Cmd(cli.SYSTEM, "make", "-j8"); m.Append(cli.CMD_CODE) != "0" {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
m.Cmdy(cli.SYSTEM, "make", "PREFIX="+pp, "install")
|
m.Cmd(cli.SYSTEM, "make", "PREFIX="+pp, "install")
|
||||||
|
|
||||||
})
|
|
||||||
}},
|
}},
|
||||||
gdb.SPAWN: {Name: "spawn link", Help: "新建", Hand: func(m *ice.Message, arg ...string) {
|
gdb.SPAWN: {Name: "spawn link", Help: "新建", Hand: func(m *ice.Message, arg ...string) {
|
||||||
port := m.Cmdx(tcp.PORT, aaa.RIGHT)
|
port := m.Cmdx(tcp.PORT, aaa.RIGHT)
|
||||||
|
4
misc.go
4
misc.go
@ -276,11 +276,11 @@ func (m *Message) Toast(content string, arg ...interface{}) {
|
|||||||
}
|
}
|
||||||
m.Cmd("web.space", m.Option("_daemon"), "toast", "", content, arg)
|
m.Cmd("web.space", m.Option("_daemon"), "toast", "", content, arg)
|
||||||
}
|
}
|
||||||
func (m *Message) GoToast(title string, cb func(func(string, int, int))) {
|
func (m *Message) GoToast(title string, cb func(toast func(string, int, int))) {
|
||||||
m.Go(func() {
|
m.Go(func() {
|
||||||
cb(func(name string, count, total int) {
|
cb(func(name string, count, total int) {
|
||||||
m.Toast(
|
m.Toast(
|
||||||
kit.Format("%s %d/%d", name, count, total),
|
kit.Format("%s %s/%s", name, strings.TrimSuffix(kit.FmtSize(int64(count)), "B"), strings.TrimSuffix(kit.FmtSize(int64(total)), "B")),
|
||||||
kit.Format("%s %d%%", title, count*100/total),
|
kit.Format("%s %d%%", title, count*100/total),
|
||||||
kit.Select("1000", "10000", count < total),
|
kit.Select("1000", "10000", count < total),
|
||||||
count*100/total,
|
count*100/total,
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
package bash
|
package bash
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"path"
|
||||||
|
|
||||||
ice "github.com/shylinux/icebergs"
|
ice "github.com/shylinux/icebergs"
|
||||||
"github.com/shylinux/icebergs/base/gdb"
|
"github.com/shylinux/icebergs/base/gdb"
|
||||||
"github.com/shylinux/icebergs/base/web"
|
"github.com/shylinux/icebergs/base/web"
|
||||||
"github.com/shylinux/icebergs/core/code"
|
"github.com/shylinux/icebergs/core/code"
|
||||||
kit "github.com/shylinux/toolkits"
|
kit "github.com/shylinux/toolkits"
|
||||||
|
|
||||||
"path"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const BASH = "bash"
|
const BASH = "bash"
|
||||||
@ -15,7 +15,7 @@ const BASH = "bash"
|
|||||||
var Index = &ice.Context{Name: BASH, Help: "命令行",
|
var Index = &ice.Context{Name: BASH, Help: "命令行",
|
||||||
Configs: map[string]*ice.Config{
|
Configs: map[string]*ice.Config{
|
||||||
BASH: {Name: BASH, Help: "命令行", Value: kit.Data(
|
BASH: {Name: BASH, Help: "命令行", Value: kit.Data(
|
||||||
"source", "http://mirrors.aliyun.com/gnu/bash/bash-4.2.53.tar.gz",
|
kit.SSH_SOURCE, "http://mirrors.aliyun.com/gnu/bash/bash-4.2.53.tar.gz",
|
||||||
)},
|
)},
|
||||||
},
|
},
|
||||||
Commands: map[string]*ice.Command{
|
Commands: map[string]*ice.Command{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user