An implementation of the Debug Adapter Protocol for Python https://pypi.org/project/debugpy/
Find a file
2019-10-01 10:31:15 -07:00
.github Add CODEOWNERS. 2019-07-22 17:01:53 -07:00
.vscode Refactor tests.debug to accommodate ptvsd.server spawning the adapter, and remove the need for "custom_client" and "custom_server" start methods. 2019-09-26 13:20:26 -07:00
coverage Add code coverage for tests (excluding ptvsd.server and pydevd). 2019-09-18 21:42:51 -07:00
packaging Fix windows build path 2019-08-14 01:27:02 -07:00
src/ptvsd Fix adapter timing out in wait-on-exit scenarios. 2019-09-30 22:01:27 -07:00
tests Disable test_wait_on_abnormal_exit_enabled due to #1819. 2019-09-30 22:01:27 -07:00
.coveragerc Add code coverage for tests (excluding ptvsd.server and pydevd). 2019-09-18 21:42:51 -07:00
.env Enable discovery of ptvsd tests in VSCode. 2019-02-25 16:35:46 -08:00
.flake8 Fix #1488: Handling launch (spawn ptvsd) (#1647) 2019-07-31 13:05:06 -07:00
.gitattributes Set up versioneer to auto-generate version numbers from git. 2018-04-11 14:00:48 -07:00
.gitignore Add code coverage for tests (excluding ptvsd.server and pydevd). 2019-09-18 21:42:51 -07:00
.pylintrc Test & infrastructure cleanup, stage 1 (#850) 2018-09-27 00:36:48 -07:00
.travis.yml Fix remaining tests to reflect the debug adapter refactoring changes. 2019-07-11 16:19:06 -07:00
clean.cmd Refactor tests.debug to accommodate ptvsd.server spawning the adapter, and remove the need for "custom_client" and "custom_server" start methods. 2019-09-26 13:20:26 -07:00
CODE_OF_CONDUCT.md Updating contribution details (#860) 2018-10-01 18:16:04 -07:00
CONTRIBUTING.md Reorganize source code to reflect the split between the adapter proper and the debug server. 2019-05-23 15:14:50 -07:00
DESCRIPTION.md Update pypi info (#480) 2018-06-15 12:59:01 -07:00
LICENSE Updates LICENSE file with correct text and includes it in distributions 2018-02-21 16:10:22 -08:00
MANIFEST.in Fixes issue with building windows wheels (#1098) 2019-01-18 10:26:55 -08:00
ptvsd.code-workspace Bunch of minor test fixes (#1726) 2019-08-29 00:19:50 -07:00
pyproject.toml Test refactoring migrated to new api (#1544) 2019-06-28 16:27:38 -07:00
pytest.ini Fix remaining tests to reflect the debug adapter refactoring changes. 2019-07-11 16:19:06 -07:00
README.md Add coverage badge 2019-10-01 10:31:15 -07:00
setup.cfg Fixes issue with building windows wheels (#1098) 2019-01-18 10:26:55 -08:00
setup.py Fix #1695: Handle IDE, launcher, debug server, and no-debug disconnect 2019-09-10 15:12:23 -07:00
sonar-project.properties Add sonar file. (#1800) 2019-09-30 23:32:27 -07:00
tox.ini Add code coverage for tests (excluding ptvsd.server and pydevd). 2019-09-18 21:42:51 -07:00
TROUBLESHOOTING.md Minor improvements to troubleshooting instructions (#1395) 2019-05-01 18:27:56 -07:00
versioneer.py Disable 'dirty' flag for version numbers. 2018-04-19 16:45:20 -07:00

Python Tools for Visual Studio debug server

Build Status Build Status Coverage GitHub PyPI PyPI

This debugger is based on the Debug Adapter Protocol for VS Code: debugProtocol.json

ptvsd CLI Usage

Debugging a script file

To run a script file with debugging enabled, but without waiting for the debugger to attach (i.e. code starts executing immediately):

-m ptvsd --host localhost --port 5678 myfile.py

To wait until the debugger attaches before running your code, use the --wait switch.

-m ptvsd --host localhost  --port 5678 --wait myfile.py

The --host option specifies the interface on which the debug server is listening for connections. To be able to attach from another machine, make sure that the server is listening on a public interface - using 0.0.0.0 will make it listen on all available interfaces:

-m ptvsd --host 0.0.0.0 --port 5678 myfile.py

This should only be done on secure networks, since anyone who can connect to the specified port can then execute arbitrary code within the debugged process.

To pass arguments to the script, just specify them after the filename. This works the same as with Python itself - everything up to the filename is processed by ptvsd, but everything after that becomes sys.argv of the running process.

Debugging a module

To run a module, use the -m switch instead of filename:

-m ptvsd --host localhost --port 5678 -m mymodule

Same as with scripts, command line arguments can be passed to the module by specifying them after the module name. All other ptvsd switches work identically in this mode; in particular, --wait can be used to block execution until the debugger attaches.

Attaching to a running process by ID

The following command injects the debugger into a process with a given PID that is running Python code. Once the command returns, a ptvsd server is running within the process, as if that process was launched via -m ptvsd itself.

-m ptvsd --host localhost --port 5678 --pid 12345

ptvsd Import usage

Enabling debugging

At the beginning of your script, import ptvsd, and call ptvsd.enable_attach() to start the debug server. The default hostname is 0.0.0.0, and the default port is 5678; these can be overridden by passing a (host, port) tuple as the first argument of enable_attach().

import ptvsd
ptvsd.enable_attach()
...

Waiting for the debugger to attach

Use the ptvsd.wait_for_attach() function to block program execution until the debugger is attached.

import ptvsd
ptvsd.enable_attach()
ptvsd.wait_for_attach()  # blocks execution until debugger is attached
...

breakpoint() function

In Python 3.7 and above, ptvsd supports the standard breakpoint() function. Use ptvsd.break_into_debugger() function for similar behavior and compatibility with older versions of Python (3.6 and below). If the debugger is attached when either of these functions is invoked, it will pause execution on the calling line, as if it had a breakpoint set. If there's no debugger attached, the functions do nothing, and the code continues to execute normally.

import ptvsd
ptvsd.enable_attach()

while True:
    ...
    breakpoint() # or ptvsd.break_into_debugger() on <3.7
    ...

Custom Protocol arguments

Launch request arguments

{
    "debugOptions":  [
            "RedirectOutput",       // Whether to redirect stdout and stderr (see pydevd_comm.CMD_REDIRECT_OUTPUT)
            "WaitOnNormalExit",     // Wait for user input after user code exits normally
            "WaitOnAbnormalExit",   // Wait for user input after user code exits with error
            "Django",               // Enables Django Template debugging
            "Jinja",                // Enables Jinja (Flask) Template debugging
            "FixFilePathCase",      // See FIX_FILE_PATH_CASE in wrapper.py
            "DebugStdLib",          // Whether to enable debugging of standard library functions
            "StopOnEntry",          // Whether to stop at first line of user code
            "ShowReturnValue",      // Show return values of functions
    ]
}

Attach request arguments

{
    "debugOptions":  [
            "RedirectOutput",       // Whether to redirect stdout and stderr (see pydevd_comm.CMD_REDIRECT_OUTPUT)
            "Django",               // Enables Django Template debugging
            "Jinja",                // Enables Jinja (Flask) Template debugging
            "FixFilePathCase",      // See FIX_FILE_PATH_CASE in wrapper.py
            "DebugStdLib",          // Whether to enable debugging of standard library functions
            "WindowsClient",        // Whether client OS is Windows
            "UnixClient",           // Whether client OS is Unix
            "ShowReturnValue",      // Show return values of functions
    ],
    "pathMappings": [
        {
            "localRoot": "C:\\Project\\src",   // Local root  (where source and debugger running)
            "remoteRoot": "/home/smith/proj"   // Remote root (where remote code is running)
        },
        // Add more path mappings
    ]
}

Debugger logging

To enable debugger internal logging via CLI, the --log-dir switch can be used:

-m ptvsd --log-dir path/to/logs ...

When using enable_attach, the same can be done with log_dir argument:

ptvsd.enable_attach(log_dir='path/to/logs')

In both cases, the environment variable PTVSD_LOG_DIR can also be set to the same effect.

When logging is enabled, ptvsd will create a log file with a name ptvsd-<pid>.log in the specified directory, where <pid> is the ID of the process being debugged. When subprocess debugging is enabled, a separate log is created for every subprocess.