A fully-featured remote debugger for python
Project description
madbg
A fully-featured remote debugger for python.
- Provides a full remote tty, allowing sending keyboard signals to the debugger, tab completion, command history, line editing and more
- Runs the IPython debugger with all its capabilities
- Allows attaching to running programs preemptively (does not require gdb, unlike similar tools)
- Affects the debugged program minimally
- Provides TTY features even when debugged program is a deamon, or run outside a terminal.
Installation
pip install madbg
Usage
Madbg provide both a python API and a CLI.
Attaching to a running process
madbg attach <pid>
Or
import madbg
madbg.attach_to_process(pid)
Starting a debugger
Using the CLI
Run a python file with automatic post-mortem:
madbg run path_to_your_script.py <args_for_script ...>
Run a python module similarly to python -m
:
madbg run -m module.name <args_for_script ...>
Start a script, starting the debugger from the first line:
madbg run --use-set-trace script.py <args_for_script ...>
Using the API
Start a debugger in the next line:
madbg.set_trace()
Continue running the program until a client connects, then stop it and start a debugger:
madbg.set_trace_on_connect()
After an exception has occurred, or in an exception context, start a debugger in the frame the exception was raised from:
madbg.post_mortem()
Connecting to a debugger
Using the CLI
madbg connect
Using the API
madbg.connect_to_debugger()
Connection
All madbg API functions and CLI entry points allow using a custom IP and port (the default is 127.0.0.1:3513
), for example:
madbg.set_trace(ip='0.0.0.0', port=1337)
or
madbg connect 8.8.8.8 1337
Platforms
Madbg supports linux with python>=3.7.
Possible effects
What madbg does that might affect a debugged program:
- Changes the pgid and sid of the debugged process
- Changes the CTTY of the debugged process
- Affects child processes in unknown ways (Not tested yet)
What madbg doesn't do:
- Writes or reads from stdio
- Feeds your cat
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file madbg-1.1.2.zip
.
File metadata
- Download URL: madbg-1.1.2.zip
- Upload date:
- Size: 16.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/2.7.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c7ab7a0da2d09ed6faab212f9ef83daf7796f2c042af46c40eddca45b28369ef |
|
MD5 | 46d676d3d6bbb30c30e8bd71697e48a2 |
|
BLAKE2b-256 | 8edd42611dd7c40dd73652d36939ed1d8942ff11155ecef9e1c773841eed18eb |
File details
Details for the file madbg-1.1.2-py3-none-any.whl
.
File metadata
- Download URL: madbg-1.1.2-py3-none-any.whl
- Upload date:
- Size: 12.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.15.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/44.1.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/2.7.17
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 77516a65b52f038e5f5afdd020a7d12b30b1fad7289d4084778882cd60a199eb |
|
MD5 | 4b7963c27da845bd1c09c0ebb9139f97 |
|
BLAKE2b-256 | 0b708d0911676ec75bf3b1b302994978dd70a719c114caa4986ef0689f81aeb0 |