Merge pull request #869 from jgmdev/fix-loading-order

Initialization: load core views before user plugins
This commit is contained in:
Jefferson González 2022-03-06 21:22:53 -04:00 committed by GitHub
commit 6386bac4e5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 36 additions and 31 deletions

View File

@ -238,11 +238,11 @@ local function refresh_directory(topdir, target, expanded)
-- If we're expecting to keep track of everything, go through the list and iteratively deal with directories. -- If we're expecting to keep track of everything, go through the list and iteratively deal with directories.
files = dirwatch.get_directory_files(topdir, topdir.name, directory, {}, 0, function() return false end) files = dirwatch.get_directory_files(topdir, topdir.name, directory, {}, 0, function() return false end)
end end
local new_idx, old_idx = 1, index local new_idx, old_idx = 1, index
local new_directories = {} local new_directories = {}
local last_dir = nil local last_dir = nil
while old_idx <= n or new_idx <= #files do while old_idx <= n or new_idx <= #files do
local old_info, new_info = topdir.files[old_idx], files[new_idx] local old_info, new_info = topdir.files[old_idx], files[new_idx]
if not new_info or not old_info or not last_dir or old_info.filename:sub(1, #last_dir + 1) ~= last_dir .. "/" then if not new_info or not old_info or not last_dir or old_info.filename:sub(1, #last_dir + 1) ~= last_dir .. "/" then
if not new_info or not old_info or not files_info_equal(new_info, old_info) then if not new_info or not old_info or not files_info_equal(new_info, old_info) then
@ -282,7 +282,7 @@ local function refresh_directory(topdir, target, expanded)
if change then if change then
core.redraw = true core.redraw = true
topdir.is_dirty = true topdir.is_dirty = true
end end
return change return change
end end
end end
@ -301,8 +301,8 @@ function core.add_project_directory(path)
watch_thread = nil, watch_thread = nil,
watch = dirwatch.new() watch = dirwatch.new()
} }
table.insert(core.project_directories, topdir) table.insert(core.project_directories, topdir)
local fstype = PLATFORM == "Linux" and system.get_fs_type(topdir.name) or "unknown" local fstype = PLATFORM == "Linux" and system.get_fs_type(topdir.name) or "unknown"
topdir.force_scans = (fstype == "nfs" or fstype == "fuse") topdir.force_scans = (fstype == "nfs" or fstype == "fuse")
local t, complete, entries_count = dirwatch.get_directory_files(topdir, topdir.name, "", {}, 0, timed_max_files_pred) local t, complete, entries_count = dirwatch.get_directory_files(topdir, topdir.name, "", {}, 0, timed_max_files_pred)
@ -320,13 +320,13 @@ function core.add_project_directory(path)
topdir.watch:watch(topdir.name) topdir.watch:watch(topdir.name)
-- each top level directory gets a watch thread. if the project is small, or -- each top level directory gets a watch thread. if the project is small, or
-- if the ablity to use directory watches hasn't been compromised in some way -- if the ablity to use directory watches hasn't been compromised in some way
-- either through error, or amount of files, then this should be incredibly -- either through error, or amount of files, then this should be incredibly
-- quick; essentially one syscall per check. Otherwise, this may take a bit of -- quick; essentially one syscall per check. Otherwise, this may take a bit of
-- time; the watch will yield in this coroutine after 0.01 second, for 0.1 seconds. -- time; the watch will yield in this coroutine after 0.01 second, for 0.1 seconds.
topdir.watch_thread = core.add_thread(function() topdir.watch_thread = core.add_thread(function()
while true do while true do
topdir.watch:check(function(target) topdir.watch:check(function(target)
if target == topdir.name then return refresh_directory(topdir, "", true) end if target == topdir.name then return refresh_directory(topdir, "", true) end
local dirpath = target:sub(#topdir.name + 2) local dirpath = target:sub(#topdir.name + 2)
local abs_dirpath = topdir.name .. PATHSEP .. dirpath local abs_dirpath = topdir.name .. PATHSEP .. dirpath
if dirpath then if dirpath then
@ -339,7 +339,7 @@ function core.add_project_directory(path)
coroutine.yield(0.05) coroutine.yield(0.05)
end end
end) end)
if path == core.project_dir then if path == core.project_dir then
core.project_files = topdir.files core.project_files = topdir.files
end end
@ -719,7 +719,32 @@ function core.init()
core.threads = setmetatable({}, { __mode = "k" }) core.threads = setmetatable({}, { __mode = "k" })
core.blink_start = system.get_time() core.blink_start = system.get_time()
core.blink_timer = core.blink_start core.blink_timer = core.blink_start
core.redraw = true
core.visited_files = {}
core.restart_request = false
core.quit_request = false
-- We load core views before plugins that may need them.
core.root_view = RootView()
core.command_view = CommandView()
core.status_view = StatusView()
core.nag_view = NagView()
core.title_view = TitleView()
-- Some plugins (eg: console) require the nodes to be initialized to defaults
local cur_node = core.root_view.root_node
cur_node.is_primary_node = true
cur_node:split("up", core.title_view, {y = true})
cur_node = cur_node.b
cur_node:split("up", core.nag_view, {y = true})
cur_node = cur_node.b
cur_node = cur_node:split("down", core.command_view, {y = true})
cur_node = cur_node:split("down", core.status_view, {y = true})
-- Load defaiult commands first so plugins can override them
command.add_defaults()
-- Load user module, plugins and project module
local got_user_error, got_project_error = not core.load_user_directory() local got_user_error, got_project_error = not core.load_user_directory()
local project_dir_abs = system.absolute_path(project_dir) local project_dir_abs = system.absolute_path(project_dir)
@ -736,7 +761,7 @@ function core.init()
update_recents_project("remove", project_dir) update_recents_project("remove", project_dir)
end end
project_dir_abs = system.absolute_path(".") project_dir_abs = system.absolute_path(".")
if not core.set_project_dir(project_dir_abs, function() if not core.set_project_dir(project_dir_abs, function()
got_project_error = not core.load_project_module() got_project_error = not core.load_project_module()
end) then end) then
system.show_fatal_error("Lite XL internal error", "cannot set project directory to cwd") system.show_fatal_error("Lite XL internal error", "cannot set project directory to cwd")
@ -744,27 +769,7 @@ function core.init()
end end
end end
core.redraw = true -- Load core plugins after user ones to let the user override them
core.visited_files = {}
core.restart_request = false
core.quit_request = false
core.root_view = RootView()
core.command_view = CommandView()
core.status_view = StatusView()
core.nag_view = NagView()
core.title_view = TitleView()
local cur_node = core.root_view.root_node
cur_node.is_primary_node = true
cur_node:split("up", core.title_view, {y = true})
cur_node = cur_node.b
cur_node:split("up", core.nag_view, {y = true})
cur_node = cur_node.b
cur_node = cur_node:split("down", core.command_view, {y = true})
cur_node = cur_node:split("down", core.status_view, {y = true})
command.add_defaults()
local plugins_success, plugins_refuse_list = core.load_plugins() local plugins_success, plugins_refuse_list = core.load_plugins()
do do