Convenience facilities related to Python functions.
Project description
Convenience facilities related to Python functions.
Latest release 20240630: funcname: include the module name, handle functions with no module.
Function callif(doit, func, *a, **kw)
Call func(*a,**kw)
if doit
is true
otherwise just print it out.
The parameter func
may be preceeded optionally by a dict
containing modes. The current modes are:
'print'
: the print function, default the builtinprint
Function callmethod_if(o, method, default=None, a=None, kw=None)
Call the named method
on the object o
if it exists.
If it does not exist, return default
(which defaults to None).
Otherwise call getattr(o, method)(*a, **kw).
a
defaults to ().
kw
defaults to {}.
Function derived_from(property_name)
A property which must be recomputed if the revision of another property exceeds the snapshot revision.
Function derived_property(func, original_revision_name='_revision', lock_name='_lock', property_name=None, unset_object=None)
A property which must be recomputed if the reference revision (attached to self) exceeds the snapshot revision.
Function func_a_kw(func, *a, **kw)
Return a string representing a call to func(*a,**kw)
.
Function func_a_kw_fmt(func, *a, **kw)
Prepare a percent-format string and associated argument list
describing a call to func(*a,**kw)
.
Return format,args
.
The func
argument can also be a string,
typically a prepared description of func
such as funccite(func)
.
Note: the returned args
is a list
for easy incorporation
into further arguments. The %
operator requires a tuple
.
Function funccite(func)
Return a citation for a function (name and code location).
Function funcname(func)
Return a name for the supplied function func
.
Several objects do not have a name attribute, such as partials.
Function prop(func)
A substitute for the builtin @property.
The builtin @property decorator lets internal AttributeErrors escape. While that can support properties that appear to exist conditionally, in practice this is almost never what I want, and it masks deeper errors. Hence this wrapper for @property that transmutes internal AttributeErrors into RuntimeErrors.
Release Log
Release 20240630: funcname: include the module name, handle functions with no module.
Release 20230331: Drop @trace, moved to cs.debug.
Release 20230210: Drop the returns_* and yields_* decorators, these days type annotations and @typechecked are the go.
Release 20221207:
- @trace: trace exceptions by default, previously false.
- Late import of cs.fs.shortpath to avoid import loop.
- New func_a_kw(func,*a,**kw) returning the formatted form of func_a_kw_fmt(func,*a,**kw).
Release 20221118: @trace: add indenting.
Release 20220619: @trace: rename some parameters, add with_caller.
Release 20220311.1: New callif(doit[,modes],func,*a,**kw) to call or print a function, used in -n/--dry-run stuff sometimes.
Release 20220311:
- @trace: new pprint=False option to use pprint.pformat instead of repr for the return value.
- @trace: bugfix use of retval parameter.
Release 20210913: New func_a_kw_fmt(func,*a,**kw) imported from cs.pfx, hooked it into @trace.
Release 20210906: funcname: special case functools.partial, return concise name.
Release 20210717:
- Move @trace from debug to py.func, defer log call imports to avoid loops.
- Drop cs.pfx requirement, import opportunisticly with fallback.
Release 20200518:
funcname: prefer func.__qualname__
over func.__name__
Release 20190729: funccite: handle callables with no code attribute.
Release 20190108: Break import loop. Use cs.py3.raise_from for portability.
Release 20181231:
- Some type specific convenience wrappers for yields_type and returns_type.
- Bugfix for @prop.
Release 20170906.1: Minor tweaks.
Release 20170906: Bugfix for @prop.
Release 20170608: New decorator @prop which works just like the builtin @property, but transmutes internal AttributeError into RuntimeError, unmasking many bugs.
Release 20160828: Use "install_requires" instead of "requires" in DISTINFO.
Release 20150115: First PyPI release.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for cs.py.func-20240630-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ebcd26cf26d147385b3969b454dd9b8816936534c414b1dbd9679505fa7a5371 |
|
MD5 | 3a683f7e463a1226fd434f8dcd935d89 |
|
BLAKE2b-256 | c63e6e03bef1abf5ebe49371ae9250f0d40326e239b9bd7579d5e9e37a221670 |