Skip to main content

Decorators for sound reproduction.

Project description

PyPI version Documentation Status Build Status Coverage Status License: MIT Python 3.6+


Logo

SnakeJazz

Decorators for sound reproduction
Explore the docs »

View Demo · Report Bug · Request Feature

Table of Contents
  1. About The Project
  2. Getting Started
  3. Basic Usage
  4. Sounds
  5. Contributing
  6. License
  7. Author
  8. Acknowledgements

About The Project

SnakeJazz provides decorators to let you listen to the running status of your Snake Python functions. Most definitly inspired by Rick and Morty :wink:

These are the decorators:

  • snakejazz.zzz: You can choose to reproduce a sound at the moment your function starts to excecute, when it finishes or when an error occurs. A different sound for each event can be given.

  • snakejazz.www: Exactly the same as zzz, but you can specify youtube links and the audio will be downloaded.

  • snakejazz.rattle: Rattle from start to finish. This will loop the sound until your function ends. You can either give a local path or a youtube link.

All three of them can be used directly to run with the default configuration. But you can also give some custom sounds for a more enjoyable moment.

Getting Started

There are two simple steps to have SnakeJazz running on you python scripts.

Prerequisites

SnakeJazz works with ffmpeg library for audio processing. To install it simply run:

  • apt

    sudo apt update
    sudo apt install ffmpeg
    
  • dnf

    sudo dnf install ffmpeg
    

You will also need a nice set of headphones to run SnakeJazz. :headphones:

Installation

  1. Standard Installation

    pip install snakejazz
    
  2. Development Install

    git clone https://github.com/mchalela/SnakeJazz.git
    cd SnakeJazz
    pip install -e .
    

Basic Usage

Let's say you have a function that takes some time to compute. Just plug-in the decorator of your preference and you're good to go!

import time
import snakejazz

@snakejazz.rattle
def wait(t):
    """Some function to simulate computing time."""
    time.sleep(t)
    return

# Put on your headphones and run it!
wait(22)

The rattle decorator will play a sound in loop until your function ends.

Now let's say you want to be notified if an error occurs during the execution of your function.

import time
import snakejazz

@snakejazz.zzz(when_error=True)
def wait(t):
    """Some function to simulate computing time."""
    time.sleep(t)
    raise ValueError('Something went wrong')
    return

# Put on your headphones and run it!
wait(3)

Sounds

For the moment SnakeJazz comes with one pack of 33 free sounds called Rhodesmas (available here: link). You can listen to them with the function snakejazz.play_sound. Just run this code:

import snakejazz

for sound, path in snakejazz.sounds.RHODESMAS.items():
    print(f'Playing {sound}')
    snakejazz.play_sound(path)

Contributing

This is an open source project made to be shared. Any contributions you make are greatly appreciated.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

Distributed under the MIT License. See LICENSE for more information.

Author

Martin Chalela - email: tinchochalela@gmail.com

Project Link: https://github.com/mchalela/SnakeJazz

Acknowledgements

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

snakejazz-0.1.1.tar.gz (6.3 MB view details)

Uploaded Source

File details

Details for the file snakejazz-0.1.1.tar.gz.

File metadata

  • Download URL: snakejazz-0.1.1.tar.gz
  • Upload date:
  • Size: 6.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.4.2 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.8.0 tqdm/4.30.0 CPython/3.8.5

File hashes

Hashes for snakejazz-0.1.1.tar.gz
Algorithm Hash digest
SHA256 27d72f02654e7cf8d20e370b2bce08263eb1d24253d8fe3d01544209f764108c
MD5 0e0bb3ff6914dc40fd070f37ae77bedf
BLAKE2b-256 052b785968ab45ee2eb13e16c3a01b3ba2c57359bd4af727a63ed57f2e931568

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