commit
98507facfe
@ -1,7 +1,7 @@
|
|||||||
local Trans = require 'Trans'
|
local Trans = require 'Trans'
|
||||||
|
|
||||||
local db = require 'sqlite.db'
|
local db = require 'sqlite.db'
|
||||||
local path = Trans.conf.dir .. Trans.separator .. 'ultimate.db'
|
local path = Trans.conf.dir .. '/ultimate.db'
|
||||||
local dict = db:open(path)
|
local dict = db:open(path)
|
||||||
local db_name = 'stardict'
|
local db_name = 'stardict'
|
||||||
vim.api.nvim_create_autocmd('VimLeavePre', {
|
vim.api.nvim_create_autocmd('VimLeavePre', {
|
||||||
|
@ -5,7 +5,7 @@ return function()
|
|||||||
local fn = vim.fn
|
local fn = vim.fn
|
||||||
-- INFO :Check ultimate.db exists
|
-- INFO :Check ultimate.db exists
|
||||||
local dir = Trans.conf.dir
|
local dir = Trans.conf.dir
|
||||||
local path = dir .. 'ultimate.db'
|
local path = dir .. '/ultimate.db'
|
||||||
|
|
||||||
if fn.isdirectory(dir) == 0 then
|
if fn.isdirectory(dir) == 0 then
|
||||||
fn.mkdir(dir, 'p')
|
fn.mkdir(dir, 'p')
|
||||||
@ -18,16 +18,15 @@ return function()
|
|||||||
|
|
||||||
-- INFO :Download ultimate.db
|
-- INFO :Download ultimate.db
|
||||||
local uri = 'https://github.com/skywind3000/ECDICT-ultimate/releases/download/1.0.0/ecdict-ultimate-sqlite.zip'
|
local uri = 'https://github.com/skywind3000/ECDICT-ultimate/releases/download/1.0.0/ecdict-ultimate-sqlite.zip'
|
||||||
local zip = dir .. 'ultimate.zip'
|
local zip = dir .. '/ultimate.zip'
|
||||||
local continue = fn.filereadable(zip) == 1
|
local continue = fn.filereadable(zip) == 1
|
||||||
local handle = function(output)
|
local handle = function(output)
|
||||||
if output.exit == 0 and fn.filereadable(zip) then
|
if output.exit == 0 and fn.filereadable(zip) then
|
||||||
if fn.executable 'unzip' == 0 then
|
local cmd =
|
||||||
vim.notify('unzip not found, Please unzip ' .. zip .. 'manually', vim.log.ERROR)
|
Trans.system == 'win' and
|
||||||
return
|
string.format('powershell.exe -Command "Expand-Archive -Force %s %s"', zip, dir) or
|
||||||
end
|
fn.executable('unzip') == 1 and string.format('unzip %s -d %s', zip, dir) or
|
||||||
|
error('unzip not found, Please unzip ' .. zip .. ' manually')
|
||||||
local cmd = string.format('unzip %s -d %s', zip, dir)
|
|
||||||
local status = os.execute(cmd)
|
local status = os.execute(cmd)
|
||||||
os.remove(zip)
|
os.remove(zip)
|
||||||
if status == 0 then
|
if status == 0 then
|
||||||
|
@ -57,7 +57,7 @@ local function check_binary_dependencies()
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function check_database()
|
local function check_database()
|
||||||
local db_path = Trans.conf.dir .. Trans.separator .. 'ultimate.db'
|
local db_path = Trans.conf.dir .. '/ultimate.db'
|
||||||
if fn.filereadable(db_path) == 1 then
|
if fn.filereadable(db_path) == 1 then
|
||||||
ok [[ultimate database found ]]
|
ok [[ultimate database found ]]
|
||||||
else
|
else
|
||||||
@ -69,7 +69,7 @@ local function check_database()
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function check_configure_file()
|
local function check_configure_file()
|
||||||
local path = fn.expand(Trans.conf.dir .. Trans.separator .. 'Trans.json')
|
local path = fn.expand(Trans.conf.dir .. '/Trans.json')
|
||||||
if not fn.filereadable(path) then
|
if not fn.filereadable(path) then
|
||||||
warn 'Backend configuration file[%s] not found'
|
warn 'Backend configuration file[%s] not found'
|
||||||
end
|
end
|
||||||
|
@ -25,29 +25,18 @@ local system =
|
|||||||
uname == 'Linux' and (vim.fn.executable 'termux-api-start' == 1 and 'termux' or 'linux') or
|
uname == 'Linux' and (vim.fn.executable 'termux-api-start' == 1 and 'termux' or 'linux') or
|
||||||
error 'Unknown System, Please Report Issue'
|
error 'Unknown System, Please Report Issue'
|
||||||
|
|
||||||
local sep = system == 'win' and '\\\\' or '/'
|
|
||||||
---@class Trans
|
---@class Trans
|
||||||
---@field style table @Style module
|
---@field style table @Style module
|
||||||
---@field cache table<string, TransData> @Cache for translated data object
|
---@field cache table<string, TransData> @Cache for translated data object
|
||||||
---@field plugin_dir string @Plugin directory
|
---@field plugin_dir string @Plugin directory
|
||||||
---@field separator string @Path separator
|
---@field system 'mac'|'win'|'termux'|'linux' @Operating system
|
||||||
---@field system 'mac'|'win'|'termux'|'linux' @Path separator
|
|
||||||
local M = metatable('core', {
|
local M = metatable('core', {
|
||||||
cache = {},
|
cache = {},
|
||||||
style = metatable 'style',
|
style = metatable 'style',
|
||||||
separator = sep,
|
|
||||||
system = system,
|
system = system,
|
||||||
plugin_dir = debug.getinfo(1, 'S').source:sub(2):match('(.-)lua' .. sep .. 'Trans'),
|
plugin_dir = vim.fn.fnamemodify(debug.getinfo(1, 'S').source:sub(2), ':p:h:h:h'),
|
||||||
})
|
})
|
||||||
|
|
||||||
M.metatable = metatable
|
M.metatable = metatable
|
||||||
|
|
||||||
---Get abs_path of file
|
|
||||||
---@param path string[]
|
|
||||||
---@param is_dir boolean?
|
|
||||||
---@return string
|
|
||||||
function M.relative_path(path, is_dir)
|
|
||||||
return M.plugin_dir .. table.concat(path, sep) .. (is_dir and sep or '')
|
|
||||||
end
|
|
||||||
|
|
||||||
return M
|
return M
|
||||||
|
Loading…
x
Reference in New Issue
Block a user