Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gaogaotiantian/progshot
progshot is a debugging tool to provide offline-debugging experience
https://github.com/gaogaotiantian/progshot
Last synced: 2 months ago
JSON representation
progshot is a debugging tool to provide offline-debugging experience
- Host: GitHub
- URL: https://github.com/gaogaotiantian/progshot
- Owner: gaogaotiantian
- License: apache-2.0
- Created: 2021-04-24T17:32:36.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2021-06-25T05:24:28.000Z (over 3 years ago)
- Last Synced: 2024-11-28T23:41:10.516Z (3 months ago)
- Language: Python
- Homepage:
- Size: 984 KB
- Stars: 15
- Watchers: 3
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# progshot
[](https://github.com/gaogaotiantian/progshot/actions?query=workflow%3Abuild) [](https://github.com/gaogaotiantian/progshot/actions?query=workflow%3ALint) [](https://codecov.io/gh/gaogaotiantian/progshot) [](https://pypi.org/project/progshot/) [](https://img.shields.io/pypi/pyversions/progshot) [](https://github.com/gaogaotiantian/progshot/blob/master/LICENSE)progshot is a debugging tool that enables "offline-debugging" for your python program.
[](https://github.com/gaogaotiantian/progshot/blob/master/img/example.png)
## Install
```
pip install progshot
```## Usage
### Trace
To capture a continuous run and be able to offline debug it like a real debugger, use ``@trace``
```python
from progshot import tracedef swap(arr, i, j):
arr[i], arr[j] = arr[j], arr[i]@trace
def bubble_sort(arr):
n = len(arr)
for i in range(n - 1):
for j in range(n - i - 1):
if arr[j] > arr[j + 1]:
swap(arr, j, j + 1)
`````@trace`` will record every line executed in the decorated function and generated a ``out.pshot`` file when the program exits. With ``psviewer``, you can enjoy a debugger-like environment offline, where you can not only go forward, but go backward as well.
Each capture is called a **film**, which contains all the frames the local variables in them.
Or you can use ``with`` to capture statements
```python
from progshot import shoot # As in shoot a moviewith shoot(depth=3):
# some code here
```By default,
@trace
is not recursive, but you can set thedepth
of@trace
```python
from progshot import tracedef swap(arr, i, j):
# Now this function will be recorded as well
arr[i], arr[j] = arr[j], arr[i]@trace(depth=2)
def bubble_sort(arr):
n = len(arr)
for i in range(n - 1):
for j in range(n - i - 1):
if arr[j] > arr[j + 1]:
swap(arr, j, j + 1)
```You can also manually dump to a file in your program
```python
from progshot import dump
for i in range(3):
arr = [random.randint(0, 100) for _ in range(10)]
bubble_sort(arr)
dump(filename=f"sort_{i}.pshot")
```By default, ``dump`` will clear the current data after dumping, you can pass ``clear_data=False`` as an argument to prevent that.
### View
To view the report, you can use Web interface or CLI.
#### Web
```
psview out.pshot
```#### CLI
```
psview-cli out.pshot
```Web interface also provides a terminal which behaves like the CLI.
The CLI interface is similar to pdb. You can use commands that have the similar meanings in pdb, except
that you have a set of "backward debugging" commands.psview commands
* p _expression_ - print eval of expression
* pp _expression_ - pretty print eval of expression with `objprint`
* w(here) - show stack trace
* u(p) [_count_] - move the current frame _count_ levels up (to older frame)
* d(own) [_count_] - move the current frame _count_ levels down (to later frame)
* n(ext) - go to next line in current function if possible, otherwise next film
* b(ack) - go to previous line in current function if possible, otherwise previous film
* s(tep) - go to next film
* s(tep)b(ack) - go to previous film
* r(eturn) - go to the next film when the current function returns
* r(eturn)b(ack) - go to the previous film before the current function enters
* unt(il) [_lineno_] - go forward until the line with a number that's >= _lineno_ is reached
* unt(il)b(ack) [_lineno_] - go backward until the line with a number that's <= _lineno_ is reached
* g(oto) [_bookmark_] - goto _bookmark_ film. _bookmark_ can be film index or film name
* l(ist) [_lineno_] - show source code around _lineno_
* ll - show full source code of existing frame### Single Capture
You can also use ``capture`` function to do a single capture.
```python
from progshot import capturedef add(a, b):
capture()
return a + b
```You can give a name(bookmark) for the capture to switch to the film quickly
Do not use space in ``name``
```python
from progshot import capturedef add(a, b):
capture(name="cap_in_add")
return a + b
```### Config
There are some global configs that you can change through ``config``.
```python
from progshot import config# Change the default dump file name
config(filename="other.pshot")# Do not auto-save when the program exits
config(save_at_exit=False)# Change default trace depth to 10
config(depth=10)
```## Bugs/Requests
Please send bug reports and feature requests through [github issue tracker](https://github.com/gaogaotiantian/progshot/issues).
## License
Copyright Tian Gao, Mengjia Zhao, 2021.
Distributed under the terms of the [Apache 2.0 license](https://github.com/gaogaotiantian/progshot/blob/master/LICENSE).