local dap = require('dap') require("dapui").setup() vim.keymap.set('n', 'd', function() require("dapui").toggle() end) require("dap-vscode-js").setup({ debugger_path = os.getenv('HOME') .. '/projects/tools/vscode-js-debug/out/adapter.bundle.js', adapters = { 'pwa-node', 'node-terminal' }, }) dap.configurations.javascript = { { type = "pwa-node", request = "launch", name = "Launch file", program = "${file}", cwd = "${workspaceFolder}", }, { type = "pwa-node", request = "attach", name = "Attach", processId = require'dap.utils'.pick_process, cwd = "${workspaceFolder}", } } dap.adapters.firefox = { type = 'executable', command = 'node', args = {os.getenv('HOME') .. '/projects/tools/vscode-firefox-debug/dist/adapter.bundle.js'}, } dap.configurations.typescript = { { name = 'Debug with Firefox', type = 'firefox', request = 'launch', reAttach = true, url = 'http://localhost:3000', webRoot = '${workspaceFolder}', firefoxExecutable = '/Applications/Firefox Developer Edition.app/Contents/MacOS/firefox' } } dap.configurations.typescriptreact = { { name = 'Debug with Firefox', type = 'firefox', request = 'launch', reAttach = true, url = 'http://localhost:3000', webRoot = '${workspaceFolder}', firefoxExecutable = '/Applications/Firefox Developer Edition.app/Contents/MacOS/firefox' } } dap.adapters.python = function(cb, config) if config.request == 'attach' then ---@diagnostic disable-next-line: undefined-field local port = (config.connect or config).port ---@diagnostic disable-next-line: undefined-field local host = (config.connect or config).host or '127.0.0.1' cb({ type = 'server', port = assert(port, '`connect.port` is required for a python `attach` configuration'), host = host, options = { source_filetype = 'python', }, }) else cb({ type = 'executable', command = os.getenv('HOME') .. '/.asdf/shims/python', args = { '-m', 'debugpy.adapter' }, options = { source_filetype = 'python', }, }) end end dap.configurations.python = { { -- The first three options are required by nvim-dap type = 'python'; -- the type here established the link to the adapter definition: `dap.adapters.python` request = 'launch'; name = "Launch file"; -- Options below are for debugpy, see https://github.com/microsoft/debugpy/wiki/Debug-configuration-settings for supported options program = "${file}"; -- This configuration will launch the current file if used. pythonPath = function() -- debugpy supports launching an application with a different interpreter then the one used to launch debugpy itself. -- The code below looks for a `venv` or `.venv` folder in the current directly and uses the python within. -- You could adapt this - to for example use the `VIRTUAL_ENV` environment variable. local cwd = vim.fn.getcwd() if vim.fn.executable(cwd .. '/venv/bin/python') == 1 then return cwd .. '/venv/bin/python' elseif vim.fn.executable(cwd .. '/.venv/bin/python') == 1 then return cwd .. '/.venv/bin/python' else return os.getenv('HOME') .. '/.asdf/shims/python' end end; }, } require('neodev').setup({ library = { plugins = { "nvim-dap-ui" }, types = true } })