allow defining a custom rename command
This commit is contained in:
parent
bfd01e5ed8
commit
9f661344ed
@ -42,9 +42,9 @@ cmd open ${{
|
|||||||
esac
|
esac
|
||||||
}}
|
}}
|
||||||
|
|
||||||
# rename current file without overwrite
|
# define a custom 'rename' command without prompt for overwrite
|
||||||
cmd rename %[ -e $1 ] && printf "file exists" || mv $f $1
|
# cmd rename %[ -e $1 ] && printf "file exists" || mv $f $1
|
||||||
map r push :rename<space>
|
# map r push :rename<space>
|
||||||
|
|
||||||
# make sure trash folder exists
|
# make sure trash folder exists
|
||||||
# %mkdir -p ~/.trash
|
# %mkdir -p ~/.trash
|
||||||
|
35
eval.go
35
eval.go
@ -470,7 +470,10 @@ func insert(app *app, arg string) {
|
|||||||
app.nav.unselect()
|
app.nav.unselect()
|
||||||
if err := remote("send load"); err != nil {
|
if err := remote("send load"); err != nil {
|
||||||
app.ui.echoerrf("delete: %s", err)
|
app.ui.echoerrf("delete: %s", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
app.ui.loadFile(app.nav)
|
||||||
|
app.ui.loadFileInfo(app.nav)
|
||||||
}
|
}
|
||||||
case strings.HasPrefix(app.ui.cmdPrefix, "replace") ||
|
case strings.HasPrefix(app.ui.cmdPrefix, "replace") ||
|
||||||
strings.HasPrefix(app.ui.cmdPrefix, "create path"):
|
strings.HasPrefix(app.ui.cmdPrefix, "create path"):
|
||||||
@ -481,8 +484,13 @@ func insert(app *app, arg string) {
|
|||||||
app.ui.echoerrf("rename: %s", err)
|
app.ui.echoerrf("rename: %s", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
if err := remote("send load"); err != nil {
|
||||||
|
app.ui.echoerrf("rename: %s", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
app.ui.loadFile(app.nav)
|
||||||
|
app.ui.loadFileInfo(app.nav)
|
||||||
}
|
}
|
||||||
|
|
||||||
case app.ui.cmdPrefix == "mark-save: ":
|
case app.ui.cmdPrefix == "mark-save: ":
|
||||||
normal(app)
|
normal(app)
|
||||||
|
|
||||||
@ -829,14 +837,23 @@ func (e *callExpr) eval(app *app, args []string) {
|
|||||||
app.ui.menuBuf = listMarks(app.nav.marks)
|
app.ui.menuBuf = listMarks(app.nav.marks)
|
||||||
app.ui.cmdPrefix = "mark-remove: "
|
app.ui.cmdPrefix = "mark-remove: "
|
||||||
case "rename":
|
case "rename":
|
||||||
if curr, err := app.nav.currFile(); err != nil {
|
if cmd, ok := gOpts.cmds["rename"]; ok {
|
||||||
app.ui.echoerrf("rename: %s:", err)
|
cmd.eval(app, e.args)
|
||||||
return
|
if err := remote("send load"); err != nil {
|
||||||
|
app.ui.echoerrf("rename: %s", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
curr, err := app.nav.currFile()
|
||||||
|
if err != nil {
|
||||||
|
app.ui.echoerrf("rename: %s:", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
app.ui.cmdPrefix = "rename: "
|
app.ui.cmdPrefix = "rename: "
|
||||||
app.ui.cmdAccLeft = append(app.ui.cmdAccLeft, []rune(curr.Name())...)
|
app.ui.cmdAccLeft = append(app.ui.cmdAccLeft, []rune(curr.Name())...)
|
||||||
}
|
}
|
||||||
|
app.ui.loadFile(app.nav)
|
||||||
|
app.ui.loadFileInfo(app.nav)
|
||||||
case "sync":
|
case "sync":
|
||||||
if err := app.nav.sync(); err != nil {
|
if err := app.nav.sync(); err != nil {
|
||||||
app.ui.echoerrf("sync: %s", err)
|
app.ui.echoerrf("sync: %s", err)
|
||||||
@ -1076,8 +1093,16 @@ func (e *callExpr) eval(app *app, args []string) {
|
|||||||
|
|
||||||
if err := app.nav.rename(app.ui); err != nil {
|
if err := app.nav.rename(app.ui); err != nil {
|
||||||
app.ui.echoerrf("rename: %s", err)
|
app.ui.echoerrf("rename: %s", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := remote("send load"); err != nil {
|
||||||
|
app.ui.echoerrf("rename: %s", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
app.ui.loadFile(app.nav)
|
||||||
|
app.ui.loadFileInfo(app.nav)
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
log.Printf("entering unknown execution prefix: %q", app.ui.cmdPrefix)
|
log.Printf("entering unknown execution prefix: %q", app.ui.cmdPrefix)
|
||||||
|
6
nav.go
6
nav.go
@ -751,16 +751,16 @@ func (nav *nav) rename(ui *ui) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := os.Rename(oldPath, newPath); err != nil {
|
if err := os.Rename(oldPath, newPath); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
nav.renew()
|
|
||||||
// TODO: change selection
|
// TODO: change selection
|
||||||
if err := nav.sel(newPath); err != nil {
|
if err := nav.sel(newPath); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
ui.loadFile(nav)
|
|
||||||
ui.loadFileInfo(nav)
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user