Skip to main content

Convenience facilities related to Python functions.

Project description

Convenience facilities related to Python functions.

Latest release 20230210: Drop the returns_* and yields_* decorators, these days type annotations and @typechecked are the go.

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 builtin print

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.

Function trace(*da, **dkw)

Decorator to report the call and return of a function.

Release Log

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cs.py.func-20230210.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cs.py.func-20230210-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file cs.py.func-20230210.tar.gz.

File metadata

  • Download URL: cs.py.func-20230210.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for cs.py.func-20230210.tar.gz
Algorithm Hash digest
SHA256 9ee6ad2f58fca7c014096dbda7bdb48fe560a5b37cb263d316737a3a80d12ea2
MD5 42c8a367c74730cfc9cd17bec8bd87d2
BLAKE2b-256 c6b629375d85df8ec4e3d13b2652aeb8fec33d48e5adbfb8bfb89c2e367f91f2

See more details on using hashes here.

File details

Details for the file cs.py.func-20230210-py3-none-any.whl.

File metadata

  • Download URL: cs.py.func-20230210-py3-none-any.whl
  • Upload date:
  • Size: 5.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.13

File hashes

Hashes for cs.py.func-20230210-py3-none-any.whl
Algorithm Hash digest
SHA256 e774a0cf06ccaf59542a2a53f4838db5d25c4289eb7c69c754568ed02a1dbe2a
MD5 46cc4fbaa36707dd460617b4641242cd
BLAKE2b-256 4d37454e1fbb9d198566e3b9d27a51a95585bce8238ddb2f8b01da13f13fe078

See more details on using hashes here.

Supported by

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