Skip to main content

Mixing breakpoints with print debugging.

Project description

breakword

breakword is a small debugging utility that combines print debugging with breakpoint debugging. It aims to facilitate debugging the kind of problem where you might use print statements to quickly spot where something seems to be off, and then switch to a step by step debugger.

breakword normally requires running your program twice and will only work properly if it is deterministic.

How to use

  1. Set the PYTHONBREAKPOINT environment variable to breakword.breakpoint.

  2. Use breakpoint like a print statement:

for i in range(10):
    breakpoint(i)

This will print out something like this:

$ python example.py
⏎ standard 0
⏎ sound 1
⏎ character 2
⏎ thank 3
⏎ play 4
⏎ however 5
⏎ fish 6
⏎ cultural 7
⏎ either 8
⏎ and 9
  1. Use the BREAKWORD environment variable to set a breakpoint to what you want to investigate further. For instance, if you want to stop when i == 6 in the above program, you can run the following command:
$ env BREAKWORD=fish python example.py
⏎ standard 0
⏎ sound 1
⏎ character 2
⏎ thank 3
⏎ play 4
⏎ however 5
⏎ fish 6
> example.py(2)<module>()
-> for i in range(10):
(Pdb) i
6

You can also give a comma-separated list of words, e.g. BREAKWORD=sound,fish.

Note: breakpoint() with no arguments retains the normal behavior.

demo

More functions

  • breakword.log(*things, **config): Print a word and optionally other things after it.

  • breakword.brk(watch=None, **config): Sets a breakpoint to trigger after log printed out the given word. If watch is None or not given, the BREAKWORD environment variable is consulted. If the variable is not set, nothing will happen.

    • This is equivalent to breakword.after(word).breakpoint().
  • breakword.after(watch=None, **config): Returns an object that evaluates to True right after log printed out the given watch word. As with brk, if watch is None or not given, the BREAKWORD environment variable is consulted.

  • breakword.word(**config): Returns the next word as a string. You can print it yourself, in which case it's basically like log, or you can store it in an object.

  • breakword.logbrk(**config): Calls log and then brk.

  • breakword.wordbrk(**config): Calls word and then brk. The word is returned.

  • breakword.set_default_logger(logger): Set the logging function to use (defaults to print)

Tracking objects

  • breakword.track(obj, all=False) will set the breakword attribute in the object to the next word in the list. By setting the BREAKWORD environment variable, you will set a breakpoint to the corresponding call to track. Set the all argument to True and the attribute will contain a list. Note: this will not work if obj is an integer or string, in those cases track will print a warning.

  • breakword.track_creation(*classes) will set the breakword attribute on all instances of the given classes, when they are created. That way, you can set a breakpoint back to the creation of some object of interest.

Groups

Use breakword.groups.<name> to get a "word group" with the given name. Each group generates words independently and will therefore not interfere with each other. They have log, brk, after, word, etc. as methods. The default group is groups[""].

from breakword import groups

assert groups.aardvark == groups["aardvark"]

# Log "a" in the aardvark group
groups.aardvark.log("a")

# Log "b" in the pelican group
groups.pelican.log("b")

# Get the next word in the pelican group
word = groups.pelican.word()

# Conditional behavior to perform only after the word "cherry"
if groups.pelican.after("cherry"):
    print("blah")

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

breakword-0.3.2.tar.gz (532.6 kB view details)

Uploaded Source

Built Distribution

breakword-0.3.2-py3-none-any.whl (10.2 kB view details)

Uploaded Python 3

File details

Details for the file breakword-0.3.2.tar.gz.

File metadata

  • Download URL: breakword-0.3.2.tar.gz
  • Upload date:
  • Size: 532.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for breakword-0.3.2.tar.gz
Algorithm Hash digest
SHA256 38404e7189d8bfe5a910c31333671b171dc49c95a9b139d62a9feaf72df20b5a
MD5 22a06cd43cd716759385ceab81b0bbfa
BLAKE2b-256 4f0568b629182345322908240eadfd0a5bd83dc306b9e2a8f568983dfbf2bb7d

See more details on using hashes here.

File details

Details for the file breakword-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: breakword-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 10.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.2

File hashes

Hashes for breakword-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fa6431e68be3fc6e668f288341dc81b804c14ca3a70c7a0c9bb487310c177ad3
MD5 d9001c0334e4a87986bb07922d19279b
BLAKE2b-256 3a9e1350806e403a60373c442d1e32a77688a563817097e6aeda16f3d3b5112d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page