Skip to main content

Fritter, the Frame-Rate IndependenT TimEr tRee.

Project description

FRITTer

Frame-Rate IndependenT TimEr tRee

Welcome to Fritter, a generalized Python library for interacting with work that needs to occur over time, whether physical time (i.e. numbers of seconds) or civil time (i.e. numbers of days, weeks, months, or years).

Get It Now

What Is It, and Why Do I Need It?

Fritter is a one-stop clock shop, allowing you to schedule over very short or very long periods of time. Wherever you need something to happen in the future, Fritter has something for you. Here are just some of the use-cases:

  • If you have an algorithm that processes work over time and you want a unified interface to be able to deploy it across a variety of event loops, take a look at fritter.drivers, where you will find drivers that support Twisted, asyncio, as well as ones for scheduled events executing in batch scripts or CLI tools that don't need an event loop at all, supplying a small wrapper around time.sleep.

  • Do you want to write fast, deterministic tests for that code, without pulling in any of those frameworks or calling sleep? Fritter comes with a robust in-memory driver perfect for unit testing, or for any scenario where you need precise control.

  • Do you have a demanding application with large numbers of timers that is straining the naive implementation of your favorite library? Fritter allows you to bring your own custom priority queue implementation for these high-performance edge cases.

  • Do you need to schedule a very high-frequency timer, whose rate is measured in Hz, to update a system that needs to stay synchronized with real time, such as an interactive animation, real-time simulation, or delivery of samples to an audio device? fritter.repeat has got you covered, with an interface that allows you to achieve its titular frame-rate independence.

  • Do you need to schedule a very low-frequency timer, whose rate is measured in weeks or months, something that runs so infrequently or so far in the future that the current process will almost certainly no longer be running? Schedule your timer in terms of datetime-ish objects, then serialize it with fritter.persistent.json to load it again when your process restarts. fritter.persistent is careful to supply an interface using IANA identifiers to maintain correctness in the face of future DST changes, and other things that can start to complicate the use of time over longer periods.

  • Do you need to manage groups of related timers, sometimes pausing some groups while allowing others to continue, while all running on the same loop; like how the "pause" button on a video game stops the action but doesn't stop the UI? fritter.tree will allow you to nest your groups arbitrarily deeply.

If any of these sound interesting, pip install fritter to try it out today!

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

fritter-0.0.8.tar.gz (58.7 kB view details)

Uploaded Source

Built Distribution

fritter-0.0.8-py3-none-any.whl (44.4 kB view details)

Uploaded Python 3

File details

Details for the file fritter-0.0.8.tar.gz.

File metadata

  • Download URL: fritter-0.0.8.tar.gz
  • Upload date:
  • Size: 58.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for fritter-0.0.8.tar.gz
Algorithm Hash digest
SHA256 65bb0b30f10116943f96ef659b3395faf34fff9a77f9d4ff91d78f5d41eda7d4
MD5 ad310e561b359f306062b994fd056cf2
BLAKE2b-256 bff6364fb3d58be38f030621c7d2232f3f7703cec46f2dd788a0ef71b8f25704

See more details on using hashes here.

File details

Details for the file fritter-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: fritter-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 44.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for fritter-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 bba709aa5dda2ef154990823e71e6c7352f95b4598c6942cea6249542d1e1503
MD5 94c8caf28a7321d0f7b6dcfa1193056b
BLAKE2b-256 9d9b6480e62d493c9396b556a6c966549126483667537e3af62fb1ba28dd71f2

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