Я хочу отправлять команды экземпляру neovim из расширения lldb (gdb) python. Хотя это работает без проблем с GDB, я получаю исключение python в lldb.
Минимальный пример:
(gdb) source test.py #works
(lldb) command script import test.py #raises an exception
test.py
import pynvim
pynvim.attach('socket', path='/tmp/nvimsocket')
исключение :
error: module importing failed: signal handler must be signal.SIG_IGN, signal.SIG_DFL, or a callable object
File "temp.py", line 1, in <module>
File "/opt/repos/nvim/test.py", line 5, in <module>
pynvim.attach('socket', path='/tmp/nvimsocket2')
File "/usr/lib/python3.8/site-packages/pynvim/__init__.py", line 122, in attach
return Nvim.from_session(session).with_decode(decode)
File "/usr/lib/python3.8/site-packages/pynvim/api/nvim.py", line 80, in from_session
channel_id, metadata = session.request(b'nvim_get_api_info')
File "/usr/lib/python3.8/site-packages/pynvim/msgpack_rpc/session.py", line 95, in request
v = self._blocking_request(method, args)
File "/usr/lib/python3.8/site-packages/pynvim/msgpack_rpc/session.py", line 174, in _blocking_request
self._async_session.run(self._enqueue_request,
File "/usr/lib/python3.8/site-packages/pynvim/msgpack_rpc/async_session.py", line 66, in run
self._msgpack_stream.run(self._on_message)
File "/usr/lib/python3.8/site-packages/pynvim/msgpack_rpc/msgpack_stream.py", line 43, in run
self.loop.run(self._on_data)
File "/usr/lib/python3.8/site-packages/pynvim/msgpack_rpc/event_loop/base.py", line 148, in run
signal.signal(signal.SIGINT, default_int_handler)
File "/usr/lib/python3.8/signal.py", line 47, in signal
handler = _signal.signal(_enum_to_int(signalnum), _enum_to_int(handler))
Это, похоже, проблема сигнального модуля и влияет на другие проекты: https://github.com/python/asyncio/issues/396
Возможно отладить python скрипт, который запускается внутри виртуального python env внутри lldb?
Редактировать:
Если я пытаюсь импортировать pdb и установить точку останова с помощью
pdb.set_trace()
(без nvim) это исключение возникает:
error: module importing failed: Traceback (most recent call last):
File "<string>", line 1, in <module>
File "/home/test/python_debug/test.py", line 8, in <module>
a()
File "/home/test/python_debug/test.py", line 5, in a
pdb.set_trace()
File "/usr/lib/python3.8/pdb.py", line 1609, in set_trace
pdb = Pdb()
File "/usr/lib/python3.8/pdb.py", line 158, in __init__
readline.set_completer_delims(' \t\n`@#$%^&*()=+[{]}\\|;:\'",<>?')
AttributeError: module 'lldb_editline' has no attribute 'set_completer_delims'
Я собрал lldb из источника, есть два флага:
LLDB_ENABLE_LIBEDIT
LLDB_ENABLE_CURSES
https://lldb.llvm.org/resources/build.html libedit установлен, как я могу убедиться, что он активирован? Есть что-то вроде lldb --build-flags?