Problem: AtCoder submit used a cookie fast-path that silently failed on stale sessions; `_LANGUAGE_ID_EXTENSION` only covered 2 of 116 languages; `LANGUAGE_VERSIONS` was incomplete for AtCoder, CF, and Kattis; AtCoder `prolog` and `racket` entries had wrong IDs. Raw `vim.notify` calls throughout bypassed `logger.log`, producing inconsistent or missing `[cp.nvim]:` prefixes. Solution: Remove cookie persistence from AtCoder login/submit — always use a fresh login within a single session. Increase `BROWSER_SUBMIT_NAV_TIMEOUT["atcoder"]` to 40s and switch to in-memory buffer upload with the correct per-language extension. Expand `LANGUAGE_VERSIONS` with all 116 AtCoder languages, 15 new CF languages with full version variants (java8/21, kotlin 1.7/1.9/2.2, rust 2021/2024, etc.), and 50+ Kattis languages. Fix AtCoder `prolog` ID (`6079`→`6081`, was Pony) and remove non-existent `racket` entry. Replace all raw `vim.notify` calls with `logger.log`.
54 lines
1.2 KiB
Lua
54 lines
1.2 KiB
Lua
local M = {}
|
|
|
|
local config_module = require('cp.config')
|
|
local helpers = require('cp.helpers')
|
|
local logger = require('cp.log')
|
|
|
|
M.helpers = helpers
|
|
|
|
if vim.fn.has('nvim-0.10.0') == 0 then
|
|
logger.log('Requires nvim-0.10.0+', { level = vim.log.levels.ERROR })
|
|
return {}
|
|
end
|
|
|
|
local initialized = false
|
|
|
|
local function ensure_initialized()
|
|
if initialized then
|
|
return true
|
|
end
|
|
local user_config = vim.g.cp or {}
|
|
local ok, result = pcall(config_module.setup, user_config)
|
|
if not ok then
|
|
local msg = tostring(result):gsub('^.+:%d+: ', '')
|
|
logger.log(msg, { level = vim.log.levels.ERROR, override = true, sync = true })
|
|
return false
|
|
end
|
|
config_module.set_current_config(result)
|
|
initialized = true
|
|
return true
|
|
end
|
|
|
|
---@return nil
|
|
function M.handle_command(opts)
|
|
if not ensure_initialized() then
|
|
return
|
|
end
|
|
local commands = require('cp.commands')
|
|
commands.handle_command(opts)
|
|
end
|
|
|
|
function M.is_initialized()
|
|
return initialized
|
|
end
|
|
|
|
---@deprecated Use `vim.g.cp` instead
|
|
function M.setup(user_config)
|
|
vim.deprecate('require("cp").setup()', 'vim.g.cp', 'v0.7.7', 'cp.nvim', false)
|
|
|
|
if user_config then
|
|
vim.g.cp = vim.tbl_deep_extend('force', vim.g.cp or {}, user_config)
|
|
end
|
|
end
|
|
|
|
return M
|