Merge remote-tracking branch 'lenormf/rc/autorestore.kak'
This commit is contained in:
commit
6827662b27
|
@ -1,15 +1,20 @@
|
||||||
## If set to true, backups will be removed as soon as they have been restored
|
## If set to true, backups will be removed as soon as they have been restored
|
||||||
decl bool autorestore_purge_restored true
|
decl bool autorestore_purge_restored true
|
||||||
|
|
||||||
def -hidden _autorestore-restore-buffer %{
|
## Insert the content of the backup file into the current buffer, if a suitable one is found
|
||||||
nop %sh{
|
def autorestore-restore-buffer -docstring "Restore the backup for the current file if it exists" %{
|
||||||
|
%sh{
|
||||||
buffer_basename="${kak_bufname##*/}"
|
buffer_basename="${kak_bufname##*/}"
|
||||||
buffer_dirname=$(dirname "${kak_bufname}")
|
buffer_dirname=$(dirname "${kak_bufname}")
|
||||||
|
|
||||||
## Find the name of the latest backup created for the buffer that was open
|
## Find the name of the latest backup created for the buffer that was open
|
||||||
latest_backup_path=$(find "${buffer_dirname}" -maxdepth 1 -type f -readable -name "\.${buffer_basename}\.kak\.*" -printf '%A@/%p\n' 2>/dev/null \
|
## The backup file has to have been last modified more recently than the file we are editing
|
||||||
| sort -n -t. -k1 | sed -nr 's/^.+\///;$p')
|
latest_backup_path=$(find "${buffer_dirname}" -maxdepth 1 -type f -readable -newer "${kak_bufname}" -name "\.${buffer_basename}\.kak\.*" -printf '%A@/%p\n' 2>/dev/null \
|
||||||
test ! -z "${latest_backup_path}" || exit
|
| sort -n -t. -k1 | sed -nr 's/^[^\/]+\///;$p')
|
||||||
|
test ! -z "${latest_backup_path}" || {
|
||||||
|
echo "eval -draft %{ autorestore-purge-backups }";
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
## Replace the content of the buffer with the content of the backup file
|
## Replace the content of the buffer with the content of the backup file
|
||||||
echo "
|
echo "
|
||||||
|
@ -24,7 +29,6 @@ def -hidden _autorestore-restore-buffer %{
|
||||||
echo "
|
echo "
|
||||||
hook -group autorestore global BufWritePost (.+/)?${kak_bufname} %{
|
hook -group autorestore global BufWritePost (.+/)?${kak_bufname} %{
|
||||||
nop %sh{
|
nop %sh{
|
||||||
echo \"\${kak_opt_autorestore_purge_restored}\" > /tmp/out
|
|
||||||
if [ \"\${kak_opt_autorestore_purge_restored,,}\" = yes \
|
if [ \"\${kak_opt_autorestore_purge_restored,,}\" = yes \
|
||||||
-o \"\${kak_opt_autorestore_purge_restored,,}\" = true ]; then
|
-o \"\${kak_opt_autorestore_purge_restored,,}\" = true ]; then
|
||||||
rm -f '${latest_backup_path}'
|
rm -f '${latest_backup_path}'
|
||||||
|
@ -36,18 +40,19 @@ def -hidden _autorestore-restore-buffer %{
|
||||||
}
|
}
|
||||||
|
|
||||||
## Remove all the backups that have been created for the current buffer
|
## Remove all the backups that have been created for the current buffer
|
||||||
def autorestore-purge-backups %{
|
def autorestore-purge-backups -docstring "Remove all the backups of the current buffer" %{
|
||||||
nop %sh{
|
nop %sh{
|
||||||
buffer_basename="${kak_bufname##*/}"
|
buffer_basename="${kak_bufname##*/}"
|
||||||
buffer_dirname=$(dirname "${kak_bufname}")
|
buffer_dirname=$(dirname "${kak_bufname}")
|
||||||
|
|
||||||
find "${buffer_dirname}" -type f -readable -name ".${buffer_basename}.kak.*" -delete 2>/dev/null
|
find "${buffer_dirname}" -type f -readable -name "\.${buffer_basename}\.kak\.*" -delete 2>/dev/null
|
||||||
}
|
}
|
||||||
|
echo -color 'Information Backup files removed'
|
||||||
}
|
}
|
||||||
|
|
||||||
## If for some reason, backup files need to be ignored
|
## If for some reason, backup files need to be ignored
|
||||||
def autorestore-disable %{
|
def autorestore-disable -docstring "Disable automatic backup recovering" %{
|
||||||
rmhooks global autorestore
|
rmhooks global autorestore
|
||||||
}
|
}
|
||||||
|
|
||||||
hook -group autorestore global BufCreate .* %{ _autorestore-restore-buffer }
|
hook -group autorestore global BufCreate .* %{ autorestore-restore-buffer }
|
||||||
|
|
Loading…
Reference in New Issue
Block a user