Changelog¶
2.2.1 (2019-01-19)¶
- Fixed a link in changelog.
- Fixed some issues in the Travis configuration.
2.2.0 (2019-01-19)¶
- Added
Frompredicate for tracing from a specific point. It stop after returning back to the same call depth with a configurable offset. - Fixed
PYTHONHUNTERCONFIGnot working in some situations (config values were resolved at the wrong time). - Made tests in CI test the wheel that will eventually be published to PyPI (tox-wheel).
- Made
event.stdlibmore reliable:pkg_resourcesis considered part of stdlib and few more paths will be considered as stdlib. - Dumbed down the
get_peercredcheck that is done when attaching withhunter-traceCLI (viahunter.remote.install()). It will be slightly insecure but will work on OSX. - Added OSX in the Travis test grid.
2.1.0 (2018-11-17)¶
- Made
threading_supporton by default but output automatic (also, now1or0allowed). - Added
pid_alignmentandforce_pidaction options to show a pid prefix. - Fixed some bugs around
__eq__in various classes. - Dropped Python 3.3 support.
- Dropped dependency on fields.
- Actions now repr using a simplified implementation that tries to avoid calling
__repr__on user classes in order to avoid creating side-effects while tracing. - Added support for the
PYTHONHUNTERCONFIGenvironment variable (stores defaults and doesn’t activate hunter).
2.0.2 (2017-11-24)¶
- Fixed indentation in
CallPrinteraction (shoudln’t deindent on exception). - Fixed option filtering in Cython Query implementation (filtering on
tracerwas allowed by mistake). - Various fixes to docstrings and docs.
2.0.1 (2017-09-09)¶
- Now
Py_AddPendingCallis used instead of acquiring the GIL (when using GDB).
2.0.0 (2017-09-02)¶
- Added the
Event.countandEvent.callsattributes. - Added the
lt/lte/gt/gtelookups. - Added convenience aliases for
startswith(sw),endswith(ew),contains(has) andregex(rx). - Added a convenience
hunter.wrapdecorator to start tracing around a function. - Added support for remote tracing (with two backends: manhole and GDB) via
the
hunter-tracebin. Note: Windows is NOT SUPPORTED. - Changed the default action to
CallPrinter. You’ll need to useaction=CodePrinterif you want the old output.
1.4.1 (2016-09-24)¶
- Fix support for getting sources for Cython module (it was broken on Windows and Python3.5+).
1.4.0 (2016-09-24)¶
- Added support for tracing Cython modules (#30). A # cython: linetrace=True stanza or equivalent is required in Cython modules for this to work.
1.3.0 (2016-04-14)¶
- Added
Event.thread. - Added
Event.threadidandEvent.threadname(available for filtering withQobjects). - Added
threading_supportargument tohunter.trace: makes new threads be traced and changes action output to include threadname. - Added support for using pdb++ in the
Debuggeraction. - Added support for using manhole via a new
Manholeaction. - Made the
handlera public but readonly property ofTracerobjects.
1.2.2 (2016-01-28)¶
- Fix broken import. Require fields>=4.0.
- Simplify a string check in Cython code.
1.2.1 (2016-01-27)¶
- Fix “KeyError: ‘normal’” bug in
CallPrinter. Create the NO_COLORS dict from the COLOR dicts. Some keys were missing.
1.2.0 (2016-01-24)¶
- Fixed printouts of objects that return very large string in
__repr__(). Trimmed to 512. Configurable in actions with therepr_limitoption. - Improved validation of
VarsPrinter’s initializer. - Added a
CallPrinteraction.
1.1.0 (2016-01-21)¶
- Implemented a destructor (
__dealloc__) for the Cython tracer. - Improved the restoring of the previous tracer in the Cython tracer (use
PyEval_SetTrace) directly. - Removed
traceras an allowed filtering argument inhunter.Query. - Add basic validation (must be callable) for positional arguments and actions passed into
hunter.Q. Closes #23. - Fixed
stdlibchecks (wasn’t very reliable). Closes #24.
1.0.2 (2016-01-05)¶
- Fixed missing import in
setup.py.
1.0.1 (2015-12-24)¶
- Fix a compile issue with the MSVC compiler (seems it don’t like the inline option on the
fast_When_call).
1.0.0 (2015-12-24)¶
Implemented fast tracer and query objects in Cython. MAY BE BACKWARDS INCOMPATIBLE
To force using the old pure-python implementation set the
PUREPYTHONHUNTERenvironment variable to non-empty value.Added filtering operators:
contains,startswith,endswithandin. Examples:Q(module_startswith='foo'will match events fromfoo,foo.barandfoobar.Q(module_startswith=['foo', 'bar']will match events fromfoo,foo.bar,foobar,bar,bar.fooandbaroo.Q(module_endswith='bar'will match events fromfoo.barandfoobar.Q(module_contains='ip'will match events fromlipsum.Q(module_in=['foo', 'bar']will match events fromfooandbar.Q(module_regex=r"(re|sre.*)\b") will match events from ``re,re.foobar,srefoobarbut not fromrepr.
Removed the
mergeoption. Now when you callhunter.trace(...)multiple times only the last one is active. BACKWARDS INCOMPATIBLERemove the previous_tracer handling. Now when you call
hunter.trace(...)the previous tracer (whatever was insys.gettrace()) is disabled and restored whenhunter.stop()is called. BACKWARDS INCOMPATIBLEFixed
CodePrinterto show module name if it fails to get any sources.
0.6.0 (2015-10-10)¶
- Added a
clear_env_varoption on the tracer (disables tracing in subprocess). - Added
force_colorsoption onVarsPrinterandCodePrinter. - Allowed setting the stream to a file name (option on
VarsPrinterandCodePrinter). - Bumped up the filename alignment to 40 cols.
- If not merging then self is not kept as a previous tracer anymore. Closes #16.
- Fixed handling in VarsPrinter: properly print eval errors and don’t try to show anything if there’s an AttributeError. Closes #18.
- Added a
stdlibboolean flag (for filtering purposes). Closes #15. - Fixed broken frames that have “None” for filename or module (so they can still be treated as strings).
- Corrected output files in the
install_libcommand so that pip can uninstall the pth file. This only works when it’s installed with pip (sadly,setup.py install/developandpip install -ewill still leave pth garbage onpip uninstall hunter).
0.5.1 (2015-04-15)¶
- Fixed
Event.globalsto actually be the dict of global vars (it was just the locals).
0.5.0 (2015-04-06)¶
- Fixed
AndandOr“single argument unwrapping”. - Implemented predicate compression. Example:
Or(Or(a, b), c)is converted toOr(a, b, c). - Renamed the
Event.sourcetoEvent.fullsource. - Added
Event.sourcethat doesn’t do any fancy sourcecode tokenization. - Fixed
Event.fullsourcereturn value for situations where the tokenizer would fail. - Made the print function available in the
PYTHONHUNTERenv var payload. - Added a __repr__ for
Event.
0.4.0 (2015-03-29)¶
- Disabled colors for Jython (contributed by Claudiu Popa in #12).
- Test suite fixes for Windows (contributed by Claudiu Popa in #11).
- Added an introduction section in the docs.
- Implemented a prettier fallback for when no sources are available for that frame.
- Implemented fixups in cases where you use action classes as a predicates.
0.3.1 (2015-03-29)¶
- Forgot to merge some commits …
0.3.0 (2015-03-29)¶
- Added handling for internal repr failures.
- Fixed issues with displaying code that has non-ascii characters.
- Implemented better display for
callframes so that when a function has decorators the function definition is shown (instead of just the first decorator). See: #8.
0.2.1 (2015-03-28)¶
- Added missing color entry for exception events.
- Added
Event.lineproperty. It returns the source code for the line being run.
0.2.0 (2015-03-27)¶
- Added color support (and
coloramaas dependency). - Added support for expressions in
VarsPrinter. - Breaking changes:
- Renamed
FtoQ. AndQis now just a convenience wrapper forQuery. - Renamed the
PYTHON_HUNTERenv variable toPYTHONHUNTER. - Changed
Whento take positional arguments. - Changed output to show 2 path components (still not configurable).
- Changed
VarsPrinterto take positional arguments for the names.
- Renamed
- Improved error reporting for env variable activation (
PYTHONHUNTER). - Fixed env var activator (the
.pthfile) installation withsetup.py install(the “egg installs”) andsetup.py develop/pip install -e(the “egg links”).
0.1.0 (2015-03-22)¶
- First release on PyPI.