diff options
author | cukmekerb <cukmekerb+git@gmail.com> | 2021-04-07 14:45:37 -0700 |
---|---|---|
committer | Francesco Abbate <francesco.bbt@gmail.com> | 2021-04-09 12:45:36 +0200 |
commit | b812cd913c94685411acfab7ddb07dfd10077d44 (patch) | |
tree | 70ee3b6e1809c86bd40ae463f4afeebb62477785 /plugins/autosave.lua | |
parent | 536a0ce054319d2ea92c665510afe8a388b043ca (diff) | |
download | lite-xl-plugins-b812cd913c94685411acfab7ddb07dfd10077d44.tar.gz lite-xl-plugins-b812cd913c94685411acfab7ddb07dfd10077d44.zip |
added autosave plugin
Diffstat (limited to 'plugins/autosave.lua')
-rw-r--r-- | plugins/autosave.lua | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/plugins/autosave.lua b/plugins/autosave.lua new file mode 100644 index 0000000..11337f7 --- /dev/null +++ b/plugins/autosave.lua @@ -0,0 +1,45 @@ +local core = require "core" +local config = require "core.config" +local Doc = require "core.doc" +local DocView = require "core.docview" +local command = require "core.command" +-- this is used to detect the wait time +local last_keypress = os.time() +-- this exists so that we don't end up with multiple copies of the loop running at once +local looping = false +local on_text_change = Doc.on_text_change +-- the approximate amount of time, in seconds, that it takes to trigger an autosave +config.autosave_timeout = 1 + + +local function loop_for_save() + if not looping then + looping = true + while looping do + if os.difftime(os.time(), last_keypress) >= config.autosave_timeout then + command.perform "doc:save" + -- stop loop + looping = false + end + -- dividing by five is completely arbitrary but it seemed to work well so idc + coroutine.yield(config.autosave_timeout) + end + end +end + + +local function updatepress() + -- set last keypress time to now + last_keypress = os.time() + -- put loop in coroutine so it doesn't lag out this script + core.add_thread(loop_for_save) +end + + +function Doc:on_text_change(type) + -- check if file is saved + if core.active_view:get_name() ~= "unsaved*" then + updatepress() + end + return on_text_change(type) +end |