From d4ecc5aa67b6cfc9fd5aa70a1013e0349f4c9b4e Mon Sep 17 00:00:00 2001 From: Chris Date: Mon, 8 Sep 2025 09:19:08 +0100 Subject: [PATCH] Improve debugging --- lua/plugins/debug.lua | 12 ++-- lua/plugins/suda.lua | 6 ++ lua/snippets/php.lua | 152 +++++++++++++++++++++++++----------------- 3 files changed, 102 insertions(+), 68 deletions(-) create mode 100644 lua/plugins/suda.lua diff --git a/lua/plugins/debug.lua b/lua/plugins/debug.lua index 38cbc07..43ff6ea 100644 --- a/lua/plugins/debug.lua +++ b/lua/plugins/debug.lua @@ -121,7 +121,9 @@ return { dap.adapters.php = { type = 'executable', command = 'node', - args = { '/Users/chris/.local/src/vscode-php-debug/out/phpDebug.js' }, + args = { + vim.fn.expand '$MASON/packages/php-debug-adapter/extension/out/phpDebug.js', + }, } dap.configurations.php = { @@ -160,10 +162,10 @@ return { }, element_mappings = { stacks = { - open = "", - expand = "o", - } - } + open = '', + expand = 'o', + }, + }, } -- Change breakpoint icons diff --git a/lua/plugins/suda.lua b/lua/plugins/suda.lua new file mode 100644 index 0000000..9e8cae2 --- /dev/null +++ b/lua/plugins/suda.lua @@ -0,0 +1,6 @@ +return { + 'lambdalisue/vim-suda', + config = function() + vim.g.suda_smart_edit = 1 + end, +} diff --git a/lua/snippets/php.lua b/lua/snippets/php.lua index bf871b3..77f087f 100644 --- a/lua/snippets/php.lua +++ b/lua/snippets/php.lua @@ -1,84 +1,110 @@ -local ls = require("luasnip") +local ls = require 'luasnip' local s = ls.snippet local t = ls.text_node local i = ls.insert_node local f = ls.function_node +local function get_psr4_root() + local handle = io.popen [[php -r "echo array_keys(json_decode(file_get_contents('composer.json'), true)['autoload']['psr-4'])[0];"]] + local ns_root = handle and handle:read '*a' or '' + if handle then + handle:close() + end + ns_root = ns_root:gsub('\\$', '') -- Remove trailing backslash + return ns_root +end + local function psr_namespace(args, snip) - local path = snip.env.TM_FILENAME_FULL or "" - local root = "/src/" - local ns = path:match(root .. "(.*)/[^/]+%.php$") + local path = snip.env.TM_FILENAME_FULL or '' + local composer_root = get_psr4_root() + -- Find the directory mapped by composer.json + local root_dir = composer_root:gsub('\\', '/') + local ns = path:match(root_dir .. '/(.*)/[^/]+%.php$') if ns then - return ns:gsub("/", "\\") + return composer_root .. '\\' .. ns:gsub('/', '\\') else - return "App" + return composer_root ~= '' and composer_root or 'App' end end local function class_name(args, snip) - local filename = snip.env.TM_FILENAME or "" - return filename:match("([^%.]+)") or "ClassName" + local filename = snip.env.TM_FILENAME or '' + return filename:match '([^%.]+)' or 'ClassName' end return { - s("du", { t("dump("), i(1), t(");") }), - s("dt", { t("\\PhpStan\\dumpType("), i(1), t(");") }), - s("ql", { - t("\\Illuminate\\Support\\Facades\\DB::listen(function (\\Illuminate\\Database\\Events\\QueryExecuted $e) {"), - t({"", " dump($e->sql, $e->bindings);"}), - t({"", "});"}) + s('du', { t 'dump(', i(1), t ');' }), + s('dt', { t '\\PhpStan\\dumpType(', i(1), t ');' }), + s('ql', { + t '\\Illuminate\\Support\\Facades\\DB::listen(function (\\Illuminate\\Database\\Events\\QueryExecuted $e) {', + t { '', ' dump($e->sql, $e->bindings);' }, + t { '', '});' }, }), - s("test", { - t("test("), i(1), t(", function () {"), - t({"", " "}), i(2), - t({"", ");"}) - }), - s("/**", { - t("/**"), - t({"", " * "}), i(1), - t({"", " */"}) - }), - s("@p", { t("@property "), i(1), t(" $"), i(2) }), - s("@pb", { t("@property bool $"), i(1) }), - s("@ps", { t("@property string $"), i(1) }), - s("@pi", { t("@property int $"), i(1) }), - s("@pc", { t("@property \\Illuminate\\Support\\Collection $"), i(2) }), - s("@pd", { t("@property \\Illuminate\\Support\\Carbon $"), i(1) }), - s("@pp", { - t("/**"), - t({"", " * @property int $id"}), - t({"", " * "}), i(1), - t({"", " * @property \\Illuminate\\Support\\Carbon $created_at"}), - t({"", " * @property \\Illuminate\\Support\\Carbon $updated_at"}), - t({"", " *", " * Relationships"}), - t({"", " * "}), i(2), - t({"", " */"}) - }), - s("php", { - t(" $', i(2) }), + s('@pd', { t '@property \\Illuminate\\Support\\Carbon $', i(1) }), + s('@pp', { + t '/**', + t { '', ' * @property int $id' }, + t { '', ' * ' }, + i(1), + t { '', ' * @property \\Illuminate\\Support\\Carbon $created_at' }, + t { '', ' * @property \\Illuminate\\Support\\Carbon $updated_at' }, + t { '', ' *', ' * Relationships' }, + t { '', ' * ' }, + i(2), + t { '', ' */' }, + }), + s('php', { + t '