Recent Releases of hunter
hunter - v3.3.6
- Fixed regression from 3.3.4:
stdlibfilter was broken. - Improved the pth file (
PYTHONHUNTERenvironment variable activation) to use a clean eval environment. No bogus variables likeline(from thesite.pymachinery) will be available anymore. - Fixed a bug in
VarsSnooperthat would make it fail in rare situation where a doublereturnevent is emitted.
- Python
Published by ionelmc over 3 years ago
hunter - v3.4.0
Switched CI to GitHub Actions, this has a couple consequences:
- Support for Python 2.7 is dropped. You can still install it there but it's not tested anymore and Python 2 specific handling will be removed at some point.
- Linux wheels are now provided in
musllinuxandmanylinux2014variants.
Extension building is now completely skipped on PyPy.
A pure but tagged as platform specific wheel is now provided for PyPy (to have fast installs there as well).
- Python
Published by ionelmc over 3 years ago
hunter -
Fixed tracer still being active for other threads after it was stopped.
Python unfortunately only allows removing the trace function for the current thread - now
hunter.tracer.Tracerwill uninstall itself if it's marked as stopped.This fixes bogus errors that appear when using
ipdbwith thehunter.actions.Debuggeraction while thread support is enabled (the default).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Changed CI to build Python 3.9 wheels. Python 3.5 no longer tested and wheels no longer built to keep things simple.
- Documentation improvements.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed CI/test issues that prevented all of 21 wheels being published.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed handling so that
hunter.event.Event.moduleis always the"?"string instead ofNone. Previously it wasNonewhen tracing particularly broken code and broke various predicates. - Similarly
hunter.event.Event.filenameis now"?"if there's no filename available. - Building on the previous changes the actions have simpler code for displaying missing module/filenames.
- Changed
hunter.actions.CallPrinterso that trace events for builtin functions are displayed differently. These events appear when using profile mode (eg:trace(profile=True)). - Fixed failure that could occur if
hunter.event.Event.moduleis an unicode string. Now it's always a regular string. Only applies to Python 2. - Fixed argument display when tracing functions with tuple arguments. Closes #88. Only applies to Python 2.
- Improved error reporting when internal failures occur. Now some details about the triggering event are logged.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed oversight over what value is in
hunter.event.Event.builtin. Now it's always a boolean, and can be used consistently in filters (eg:builtin=True,function='getattr').
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added support for regex, date and datetime in
safe_repr. - Fixed call argument display when positional and keyword arguments are used in
hunter.actions.CallPrinter.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Implemented the
hunter.actions.StackPrinteraction. - Implemented the
hunter.predicates.Backlogpredicate. Contributed by Dan Ailenei in #81. - Improved contributing section in docs a bit. Contributed by Tom Schraitle in #85.
- Improved filtering performance by avoiding a lot of unnecessary
PyObject_GetAttrcalls in the Cython implementation ofhunter.predicates.Backlog. - Implemented the
hunter.actions.ErrorSnooperaction. - Added support for profiling mode (eg:
trace(profile=True)). This mode will usesetprofileinstead ofsettrace. - Added ARM64 wheels and CI.
- Added
hunter.event.Event.instructionandhunter.event.Event.builtin(usable in profile mode). - Added more cookbook entries.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Improved again the stdlib check to handle certain paths better.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Really fixed the
<frozen importlib.somethingstdlib check.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Marked all the
<frozen importlib.somethingfiles as part of stdlib.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added
hunter.actions.ErrorSnooper- an action that detects silenced exceptions. - Added
hunter.load_configand fixed issues with configuration being loaded too late from thePYTHONHUNTERCONFIGenvironment variable. - Changed
hunter.Fromhelper to automatically movedepthandcallsfilters to the predicate (so they filter afterhunter.predicates.Fromactivates). - Changed
hunter.predicates.Fromto pass a copy of event to the predicate. The copy will have thedepthandcallsattributes adjusted to the point wherehunter.predicates.Fromactivated. - Fixed a bunch of inconsistencies and bugs when using
&and|operators with predicates. - Fixed a bunch of broken fields on detached events from
hunter.event.Event.detach(hunter.event.Event.function_objectandhunter.event.Event.arg). - Improved docstrings in various and added a configuration doc section.
- Improved testing (more coverage).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Really fixed
safe_reprso it doesn't cause side-effects (now isinstance/issubclass are avoided - they can cause side-effects in code that abuses descriptors in special attributes/methods).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Really fixed
streamsetup in actions (usingforce_colorswithout anystreamwas broken). See:hunter.actions.ColorStreamAction. - Fixed
__repr__for thehunter.predicates.Frompredicate to includewatermark. - Added binary wheels for Python 3.8.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed
safe_repron pypy so it's safer on method objects. See:hunter.actions.ColorStreamAction.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed setting
streamfromPYTHONHUNTERCONFIGenvironment variable. See:hunter.actions.ColorStreamAction. - Fixed a couple minor documentation issues.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed issue with coloring missing source message (coloring leaked into next line).
- Python
Published by ionelmc almost 5 years ago
hunter -
The package now uses setuptools-scm for development builds (available at https://test.pypi.org/project/hunter/). As a consequence installing the sdist will download setuptools-scm.
Recompiled cython modules with latest Cython. Hunter can be installed without any Cython, as before.
Refactored some of the cython modules to have more typing information and not use deprecated property syntax.
Replaced
unsafe_reproption withrepr_func. Now you can use your custom repr function in the builtin actions. BACKWARDS INCOMPATIBLEFixed buggy filename handling when using Hunter in ipython/jupyter. Source code should be properly displayed now.
Removed
globalsoption fromVarsPrinteraction. Globals are now always looked up. BACKWARDS INCOMPATIBLEAdded support for locals in
VarsPrinteraction. Now you can doVarsPrinter('len(foobar)').Always pass module_globals dict to linecache methods. Source code from PEP-302 loaders is now printed properly. Contributed by Mikhail Borisov in #65.
Various code cleanup, style and docstring fixing.
Added
hunter.Fromhelper to allow passing in filters directly as keyword arguments.Added
hunter.event.Event.detachfor storing events without leaks or side-effects (due to prolonged references to Frame objects, local or global variables).Refactored the internals of actions for easier subclassing.
Added the
filename_prefix,output,pid_prefix,thread_prefix,try_reprandtry_sourcemethods to thehunter.actions.ColorStreamActionbaseclass.Added
hunter.actions.VarsSnooper- a PySnooper-inspired variant ofhunter.actions.VarsPrinter. It will record and show variable changes, with the risk of leaking or using too much memory of course :)Fixed tracers to log error and automatically stop if there's an internal failure. Previously error may have been silently dropped in some situations.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed a link in changelog.
- Fixed some issues in the Travis configuration.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added
hunter.predicates.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.
- Python
Published by ionelmc almost 5 years ago
hunter -
- 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).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed indentation in
hunter.actions.CallPrinteraction (shouldn't deindent on exception). - Fixed option filtering in Cython Query implementation (filtering on
tracerwas allowed by mistake). - Various fixes to docstrings and docs.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Now
Py_AddPendingCallis used instead of acquiring the GIL (when using GDB).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added the
hunter.event.Event.countandhunter.event.Event.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
hunter.actions.CallPrinter. You'll need to useaction=CodePrinterif you want the old output.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fix support for getting sources for Cython module (it was broken on Windows and Python3.5+).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added
hunter.event.Event.thread. - Added
hunter.event.Event.threadidandhunter.event.Event.threadname(available for filtering withhunter.Q). - Added
hunter.event.Event.threading_supportargument tohunter.trace. It makes new threads be traced and changes action output to include thread name. - Added support for using pdb++ in the
hunter.actions.Debuggeraction. - Added support for using manhole via a new
hunter.actions.Manholeaction. - Made the
hunter.event.Event.handlera public but readonly property.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fix broken import. Require
fields>=4.0. - Simplify a string check in Cython code.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fix "KeyError: 'normal'" bug in
hunter.actions.CallPrinter. Create the NO_COLORS dict from the COLOR dicts. Some keys were missing.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed printouts of objects that return very large string in
__repr__(). Trimmed to 512. Configurable in actions with therepr_limitoption. - Improved validation of
hunter.actions.VarsPrinter's initializer. - Added a
hunter.actions.CallPrinteraction.
- Python
Published by ionelmc almost 5 years ago
hunter -
- 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.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fix a compile issue with the MSVC compiler (seems it don't like the inline option on the
fast_When_call).
- Python
Published by ionelmc almost 5 years ago
hunter -
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 fromre,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_tracerhandling. Now when you callhunter.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.
- Python
Published by ionelmc almost 5 years ago
hunter -
- Added a
clear_env_varoption on the tracer (disables tracing in subprocess). - Added
force_colorsoption onhunter.actions.VarsPrinterandhunter.actions.CodePrinter. - Allowed setting the stream to a file name (option on
hunter.actions.VarsPrinterandhunter.actions.CodePrinter). - Bumped up the filename alignment to 40 cols.
- If not merging then
selfis 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).
- Python
Published by ionelmc almost 5 years ago
hunter -
- Fixed
hunter.event.Event.globalsto actually be the dict of global vars (it was just the locals).
- Python
Published by ionelmc almost 5 years ago
hunter -
- 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 PYTHONHUNTER env var payload.
- Added a
__repr__forEvent.
- Python
Published by ionelmc almost 11 years ago
hunter -
- 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.
- Python
Published by ionelmc almost 11 years ago
hunter -
- 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.
- Python
Published by ionelmc almost 11 years ago
hunter -
- Added missing color entry for exception events.
- Added
Event.lineproperty. It returns the source code for the line being run.
- Python
Published by ionelmc almost 11 years ago
hunter -
Changes
- 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 :class:
Whento take positional arguments. - Changed output to show 2 path components (still not configurable).
- Changed :class:
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").
Installation
pip install hunter==0.2.0
- Python
Published by ionelmc almost 11 years ago