summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2023-06-20 08:51:40 +0000
committerCoprDistGit <infra@openeuler.org>2023-06-20 08:51:40 +0000
commit19cfa9b30986d902264d40e632950facfeb39602 (patch)
tree43e53e7a859afa0af2920ec9655be908f703487e
parente44af15a6d988967198e53e88b79bc4a5d9711f1 (diff)
automatic import of python-chimeopeneuler20.03
-rw-r--r--.gitignore1
-rw-r--r--python-chime.spec849
-rw-r--r--sources1
3 files changed, 851 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..80f4ba6 100644
--- a/.gitignore
+++ b/.gitignore
@@ -0,0 +1 @@
+/chime-0.7.0.tar.gz
diff --git a/python-chime.spec b/python-chime.spec
new file mode 100644
index 0000000..212e34d
--- /dev/null
+++ b/python-chime.spec
@@ -0,0 +1,849 @@
+%global _empty_manifest_terminate_build 0
+Name: python-chime
+Version: 0.7.0
+Release: 1
+Summary: Python sound notifications made easy.
+License: MIT
+URL: https://github.com/MaxHalford/chime
+Source0: https://mirrors.aliyun.com/pypi/web/packages/94/bc/918e3769666d918904b70f1fbdabfc3fbc3fbe97240a2a610b98b9b3fe0e/chime-0.7.0.tar.gz
+BuildArch: noarch
+
+
+%description
+<div align="center">
+ <h1>chime</h1>
+ <q><i>Python sound notifications made easy.</i></q>
+</div>
+<br>
+
+<div align="center">
+ <!-- Tests -->
+ <a href="https://github.com/MaxHalford/chime/actions?query=workflow%3Atests">
+ <img src="https://github.com/MaxHalford/chime/workflows/tests/badge.svg?style=flat-square" alt="tests">
+ </a>
+ <!-- Soundboard -->
+ <a href="https://chime-soundboard.herokuapp.com/">
+ <img src="https://github.com/MaxHalford/chime/workflows/soundboard/badge.svg?style=flat-square" alt="soundboard">
+ </a>
+ <!-- PyPI -->
+ <a href="https://pypi.org/project/chime">
+ <img src="https://img.shields.io/pypi/v/chime.svg?label=release&color=blue&style=flat-square" alt="pypi">
+ </a>
+ <!-- PePy -->
+ <a href="https://pepy.tech/project/chime">
+ <img src="https://img.shields.io/badge/dynamic/json?style=flat-square&maxAge=86400&label=downloads&query=%24.total_downloads&url=https%3A%2F%2Fapi.pepy.tech%2Fapi%2Fprojects%2Fchime" alt="pepy">
+ </a>
+ <!-- License -->
+ <a href="https://opensource.org/licenses/MIT">
+ <img src="https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square" alt="license">
+ </a>
+</div>
+<br>
+
+## Table of contents
+
+- [Table of contents](#table-of-contents)
+- [Motivation](#motivation)
+- [Installation](#installation)
+- [Basic usage](#basic-usage)
+- [Theming](#theming)
+- [IPython/Jupyter magic](#ipythonjupyter-magic)
+- [Exception notifications](#exception-notifications)
+- [Command-line usage](#command-line-usage)
+- [Platform support](#platform-support)
+- [I can't hear anything 🙉](#i-cant-hear-anything-)
+- [Setting a default theme](#setting-a-default-theme)
+- [Command-line arguments](#command-line-arguments)
+- [Adding a new theme](#adding-a-new-theme)
+- [Things to do](#things-to-do)
+- [Acknowledgements](#acknowledgements)
+- [License](#license)
+
+## Motivation
+
+I made this because I wanted a simple auditory cue system to tell me when a long-running number crunching script had finished. I didn't want to have to fiddle with the command-line, and also wanted a cross-platform solution. Thus was born `chime`!
+
+## Installation
+
+```sh
+pip install chime
+```
+
+This library has **no dependencies**. The IPython/Jupyter functionality is only imported if you've installed the `ipython` library. It should work for any Python version above or equal to 3.6.
+
+## Basic usage
+
+`chime` puts four functions at your disposal:
+
+```py
+>>> import chime
+
+>>> chime.success()
+>>> chime.warning()
+>>> chime.error()
+>>> chime.info()
+
+```
+
+Calling any of the above functions will play a sound. Note that the sounds are played in asynchronous processes, and are thus non-blocking. Each function should take around 2ms to execute, regardless of the sound length. You're free to use each sound notification in any way you see fit. I'm not your mama.
+
+## Theming
+
+The sounds that are played depend on which theme is being used.
+
+```py
+>>> chime.theme() # return the current theme
+'chime'
+
+```
+
+Several themes are available:
+
+```py
+>>> chime.themes()
+['big-sur', 'chime', 'mario', 'material', 'pokemon', 'sonic', 'zelda']
+
+```
+
+The theme can be changed by passing a theme name to the `theme` function:
+
+```py
+>>> chime.theme('zelda')
+
+```
+
+A couple of things to note:
+
+- You can listen to the sounds interactively via [this soundboard](https://chime-soundboard.herokuapp.com/), which is made with [Streamlit](https://www.streamlit.io/).
+- A random theme will be picked each time you play a sound if you set the theme to `'random'`.
+
+## IPython/Jupyter magic
+
+Load the extension as so:
+
+```py
+%load_ext chime
+```
+
+You can wrap a line:
+
+```py
+%chime print("I'm a line")
+```
+
+You can also wrap an entire cell:
+
+```py
+%%chime
+
+print("I'm a cell")
+```
+
+The magic command will call `chime.success` when the line/cell finishes successfully. Otherwise, `chime.error` is called whenever an exception is raised.
+
+## Exception notifications
+
+If you run `chime.notify_exceptions`, then `chime.error` will be called whenever an exception is raised.
+
+```py
+chime.notify_exceptions()
+
+raise ValueError("I'm going to make some noise")
+```
+
+## Command-line usage
+
+You can run `chime` from the command-line:
+
+```sh
+$ chime
+```
+
+By default, this will play the success sound. You can also choose which sound to play, like so:
+
+```sh
+$ chime info
+```
+
+You can also choose which theme to use:
+
+```sh
+$ chime info --theme zelda
+```
+
+If you're using bash, then you can use `chime` to notify you when a program finishes:
+
+```sh
+$ echo "Hello world!"; chime
+```
+
+This will play the sound regardless of the fact that the first command succeeded or not. If you're running on Windows, then you can run the following equivalent:
+
+```sh
+> echo "Hello world!" & chime
+```
+
+## Platform support
+
+Under the hood, `chime` runs a command in the shell to play a `.wav` file. The command-line program that is used depends on the [platform](https://www.wikiwand.com/en/Computing_platform) that you're using. Platform information is available in the [`sys.platform` variable](https://docs.python.org/3/library/sys.html#sys.platform) as well as the [`platform` module](https://docs.python.org/3/library/platform.html) from the standard library. Currently, the supported platforms are:
+
+- Darwin
+- Linux
+- Windows
+
+A `UserWarning` is raised if you run a `chime` sound on an unsupported platform. Feel free to get in touch or issue a pull request if you want to add support for a specific platform. Likewise, don't hesitate if you're encountering trouble with one of the above platforms. I won't bite.
+
+## I can't hear anything 🙉
+
+Did you check if you turned your sound on? Just kidding. 😜
+
+This library is designed to be non-invasive. By default, sounds are played asynchronously in unchecked processes. Therefore, if something goes wrong, the process dies silently. If you can't hear anything and you think that the issue is coming from `chime`, then set the `sync` parameter when you play a sound:
+
+```py
+>>> chime.info(sync=True)
+
+```
+
+This will play the sound synchronously and issue a warning if something goes wrong, which should allow you to debug the issue. You can also raise an exception instead of sending a warning by setting the `raise_error` parameter:
+
+```py
+>>> chime.info(sync=True, raise_error=True)
+
+```
+
+Note that setting `raise_error` won't do anything if `sync` is set to `False`.
+
+## Setting a default theme
+
+To change the default theme a configuration file may be created in `~/.config/chime/chime.conf` on Unix or `%APPDATA%\chime\chime.ini` on Windows.
+
+For example, to change the default theme to `'zelda'`, the configuration file would contain:
+
+```ini
+[chime]
+theme = zelda
+
+```
+
+## Command-line arguments
+
+Chime works by running commands in the CLI. For instance, `aplay` is used on Linux systems, while `afplay` is used on Darwin systems. Arguments can be specified by setting the `RUN_ARGS` variable. For example, here's how to select a specific sound card, assuming a Linux system using `aplay`:
+
+```py
+>>> chime.RUN_ARGS = "--device sysdefault:CARD=PCH"
+
+```
+
+You can also specify this as a default configuration in the configuration file:
+
+```ini
+[chime]
+cli_args = '--device sysdefault:CARD=PCH'
+
+```
+
+At present, it isn't possible to pass CLI arguments on Windows, due to a limitation of the [`winsound`](https://docs.python.org/3/library/winsound.html) module.
+
+## Adding a new theme
+
+I have toyed with the idea of allowing users to add their own theme(s), but at the moment I rather keep things minimal. However, I'm happy to integrate new themes into the library. You can propose a new theme by [opening a pull request](https://github.com/MaxHalford/chime/issues/new) that adds the necessary .wav files to the [`themes` directory](https://github.com/MaxHalford/chime/tree/main/themes). A theme is made up of four files: `success.wav`, `warning.wav`, `error.wav`, and `info.wav`. That's all you need to do: the theme will picked up be automatically once the necessary files are provided.
+
+Be creative! 👩‍🎨
+
+## Things to do
+
+- Some mechanism to automatically call `chime.warning` when a warning occurs.
+- Make it work with a remote machine. For instance a Jupyter Notebook hosted on a remote machine.
+- More themes!
+
+## Acknowledgements
+
+- Special thanks to [Michael Vlah](https://github.com/vlahm) for being a gentleman by giving up the "chime" name on PyPI.
+- Thanks to u/Pajke on reddit for helping me debug Windows support.
+- Thanks to [David Chen](https://github.com/dchen327) for adding Linux support by suggesting the use of [aplay](https://linux.die.net/man/1/aplay).
+- Thanks to [Vincent Warmerdam](https://twitter.com/fishnets88) for suggesting a command-line interface.
+- Calmcode made a [video introduction to chime](https://calmcode.io/chime/introduction.html) ❤️
+- Thanks to [Paulo S. Costa](https://github.com/paw-lu) for contributing in many different ways.
+- Thanks to [d34d_m8](https://github.com/d34dm8) for adding OpenBSD support.
+
+## License
+
+As you would probably expect, this is [MIT licensed](LICENSE).
+
+
+%package -n python3-chime
+Summary: Python sound notifications made easy.
+Provides: python-chime
+BuildRequires: python3-devel
+BuildRequires: python3-setuptools
+BuildRequires: python3-pip
+%description -n python3-chime
+<div align="center">
+ <h1>chime</h1>
+ <q><i>Python sound notifications made easy.</i></q>
+</div>
+<br>
+
+<div align="center">
+ <!-- Tests -->
+ <a href="https://github.com/MaxHalford/chime/actions?query=workflow%3Atests">
+ <img src="https://github.com/MaxHalford/chime/workflows/tests/badge.svg?style=flat-square" alt="tests">
+ </a>
+ <!-- Soundboard -->
+ <a href="https://chime-soundboard.herokuapp.com/">
+ <img src="https://github.com/MaxHalford/chime/workflows/soundboard/badge.svg?style=flat-square" alt="soundboard">
+ </a>
+ <!-- PyPI -->
+ <a href="https://pypi.org/project/chime">
+ <img src="https://img.shields.io/pypi/v/chime.svg?label=release&color=blue&style=flat-square" alt="pypi">
+ </a>
+ <!-- PePy -->
+ <a href="https://pepy.tech/project/chime">
+ <img src="https://img.shields.io/badge/dynamic/json?style=flat-square&maxAge=86400&label=downloads&query=%24.total_downloads&url=https%3A%2F%2Fapi.pepy.tech%2Fapi%2Fprojects%2Fchime" alt="pepy">
+ </a>
+ <!-- License -->
+ <a href="https://opensource.org/licenses/MIT">
+ <img src="https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square" alt="license">
+ </a>
+</div>
+<br>
+
+## Table of contents
+
+- [Table of contents](#table-of-contents)
+- [Motivation](#motivation)
+- [Installation](#installation)
+- [Basic usage](#basic-usage)
+- [Theming](#theming)
+- [IPython/Jupyter magic](#ipythonjupyter-magic)
+- [Exception notifications](#exception-notifications)
+- [Command-line usage](#command-line-usage)
+- [Platform support](#platform-support)
+- [I can't hear anything 🙉](#i-cant-hear-anything-)
+- [Setting a default theme](#setting-a-default-theme)
+- [Command-line arguments](#command-line-arguments)
+- [Adding a new theme](#adding-a-new-theme)
+- [Things to do](#things-to-do)
+- [Acknowledgements](#acknowledgements)
+- [License](#license)
+
+## Motivation
+
+I made this because I wanted a simple auditory cue system to tell me when a long-running number crunching script had finished. I didn't want to have to fiddle with the command-line, and also wanted a cross-platform solution. Thus was born `chime`!
+
+## Installation
+
+```sh
+pip install chime
+```
+
+This library has **no dependencies**. The IPython/Jupyter functionality is only imported if you've installed the `ipython` library. It should work for any Python version above or equal to 3.6.
+
+## Basic usage
+
+`chime` puts four functions at your disposal:
+
+```py
+>>> import chime
+
+>>> chime.success()
+>>> chime.warning()
+>>> chime.error()
+>>> chime.info()
+
+```
+
+Calling any of the above functions will play a sound. Note that the sounds are played in asynchronous processes, and are thus non-blocking. Each function should take around 2ms to execute, regardless of the sound length. You're free to use each sound notification in any way you see fit. I'm not your mama.
+
+## Theming
+
+The sounds that are played depend on which theme is being used.
+
+```py
+>>> chime.theme() # return the current theme
+'chime'
+
+```
+
+Several themes are available:
+
+```py
+>>> chime.themes()
+['big-sur', 'chime', 'mario', 'material', 'pokemon', 'sonic', 'zelda']
+
+```
+
+The theme can be changed by passing a theme name to the `theme` function:
+
+```py
+>>> chime.theme('zelda')
+
+```
+
+A couple of things to note:
+
+- You can listen to the sounds interactively via [this soundboard](https://chime-soundboard.herokuapp.com/), which is made with [Streamlit](https://www.streamlit.io/).
+- A random theme will be picked each time you play a sound if you set the theme to `'random'`.
+
+## IPython/Jupyter magic
+
+Load the extension as so:
+
+```py
+%load_ext chime
+```
+
+You can wrap a line:
+
+```py
+%chime print("I'm a line")
+```
+
+You can also wrap an entire cell:
+
+```py
+%%chime
+
+print("I'm a cell")
+```
+
+The magic command will call `chime.success` when the line/cell finishes successfully. Otherwise, `chime.error` is called whenever an exception is raised.
+
+## Exception notifications
+
+If you run `chime.notify_exceptions`, then `chime.error` will be called whenever an exception is raised.
+
+```py
+chime.notify_exceptions()
+
+raise ValueError("I'm going to make some noise")
+```
+
+## Command-line usage
+
+You can run `chime` from the command-line:
+
+```sh
+$ chime
+```
+
+By default, this will play the success sound. You can also choose which sound to play, like so:
+
+```sh
+$ chime info
+```
+
+You can also choose which theme to use:
+
+```sh
+$ chime info --theme zelda
+```
+
+If you're using bash, then you can use `chime` to notify you when a program finishes:
+
+```sh
+$ echo "Hello world!"; chime
+```
+
+This will play the sound regardless of the fact that the first command succeeded or not. If you're running on Windows, then you can run the following equivalent:
+
+```sh
+> echo "Hello world!" & chime
+```
+
+## Platform support
+
+Under the hood, `chime` runs a command in the shell to play a `.wav` file. The command-line program that is used depends on the [platform](https://www.wikiwand.com/en/Computing_platform) that you're using. Platform information is available in the [`sys.platform` variable](https://docs.python.org/3/library/sys.html#sys.platform) as well as the [`platform` module](https://docs.python.org/3/library/platform.html) from the standard library. Currently, the supported platforms are:
+
+- Darwin
+- Linux
+- Windows
+
+A `UserWarning` is raised if you run a `chime` sound on an unsupported platform. Feel free to get in touch or issue a pull request if you want to add support for a specific platform. Likewise, don't hesitate if you're encountering trouble with one of the above platforms. I won't bite.
+
+## I can't hear anything 🙉
+
+Did you check if you turned your sound on? Just kidding. 😜
+
+This library is designed to be non-invasive. By default, sounds are played asynchronously in unchecked processes. Therefore, if something goes wrong, the process dies silently. If you can't hear anything and you think that the issue is coming from `chime`, then set the `sync` parameter when you play a sound:
+
+```py
+>>> chime.info(sync=True)
+
+```
+
+This will play the sound synchronously and issue a warning if something goes wrong, which should allow you to debug the issue. You can also raise an exception instead of sending a warning by setting the `raise_error` parameter:
+
+```py
+>>> chime.info(sync=True, raise_error=True)
+
+```
+
+Note that setting `raise_error` won't do anything if `sync` is set to `False`.
+
+## Setting a default theme
+
+To change the default theme a configuration file may be created in `~/.config/chime/chime.conf` on Unix or `%APPDATA%\chime\chime.ini` on Windows.
+
+For example, to change the default theme to `'zelda'`, the configuration file would contain:
+
+```ini
+[chime]
+theme = zelda
+
+```
+
+## Command-line arguments
+
+Chime works by running commands in the CLI. For instance, `aplay` is used on Linux systems, while `afplay` is used on Darwin systems. Arguments can be specified by setting the `RUN_ARGS` variable. For example, here's how to select a specific sound card, assuming a Linux system using `aplay`:
+
+```py
+>>> chime.RUN_ARGS = "--device sysdefault:CARD=PCH"
+
+```
+
+You can also specify this as a default configuration in the configuration file:
+
+```ini
+[chime]
+cli_args = '--device sysdefault:CARD=PCH'
+
+```
+
+At present, it isn't possible to pass CLI arguments on Windows, due to a limitation of the [`winsound`](https://docs.python.org/3/library/winsound.html) module.
+
+## Adding a new theme
+
+I have toyed with the idea of allowing users to add their own theme(s), but at the moment I rather keep things minimal. However, I'm happy to integrate new themes into the library. You can propose a new theme by [opening a pull request](https://github.com/MaxHalford/chime/issues/new) that adds the necessary .wav files to the [`themes` directory](https://github.com/MaxHalford/chime/tree/main/themes). A theme is made up of four files: `success.wav`, `warning.wav`, `error.wav`, and `info.wav`. That's all you need to do: the theme will picked up be automatically once the necessary files are provided.
+
+Be creative! 👩‍🎨
+
+## Things to do
+
+- Some mechanism to automatically call `chime.warning` when a warning occurs.
+- Make it work with a remote machine. For instance a Jupyter Notebook hosted on a remote machine.
+- More themes!
+
+## Acknowledgements
+
+- Special thanks to [Michael Vlah](https://github.com/vlahm) for being a gentleman by giving up the "chime" name on PyPI.
+- Thanks to u/Pajke on reddit for helping me debug Windows support.
+- Thanks to [David Chen](https://github.com/dchen327) for adding Linux support by suggesting the use of [aplay](https://linux.die.net/man/1/aplay).
+- Thanks to [Vincent Warmerdam](https://twitter.com/fishnets88) for suggesting a command-line interface.
+- Calmcode made a [video introduction to chime](https://calmcode.io/chime/introduction.html) ❤️
+- Thanks to [Paulo S. Costa](https://github.com/paw-lu) for contributing in many different ways.
+- Thanks to [d34d_m8](https://github.com/d34dm8) for adding OpenBSD support.
+
+## License
+
+As you would probably expect, this is [MIT licensed](LICENSE).
+
+
+%package help
+Summary: Development documents and examples for chime
+Provides: python3-chime-doc
+%description help
+<div align="center">
+ <h1>chime</h1>
+ <q><i>Python sound notifications made easy.</i></q>
+</div>
+<br>
+
+<div align="center">
+ <!-- Tests -->
+ <a href="https://github.com/MaxHalford/chime/actions?query=workflow%3Atests">
+ <img src="https://github.com/MaxHalford/chime/workflows/tests/badge.svg?style=flat-square" alt="tests">
+ </a>
+ <!-- Soundboard -->
+ <a href="https://chime-soundboard.herokuapp.com/">
+ <img src="https://github.com/MaxHalford/chime/workflows/soundboard/badge.svg?style=flat-square" alt="soundboard">
+ </a>
+ <!-- PyPI -->
+ <a href="https://pypi.org/project/chime">
+ <img src="https://img.shields.io/pypi/v/chime.svg?label=release&color=blue&style=flat-square" alt="pypi">
+ </a>
+ <!-- PePy -->
+ <a href="https://pepy.tech/project/chime">
+ <img src="https://img.shields.io/badge/dynamic/json?style=flat-square&maxAge=86400&label=downloads&query=%24.total_downloads&url=https%3A%2F%2Fapi.pepy.tech%2Fapi%2Fprojects%2Fchime" alt="pepy">
+ </a>
+ <!-- License -->
+ <a href="https://opensource.org/licenses/MIT">
+ <img src="https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square" alt="license">
+ </a>
+</div>
+<br>
+
+## Table of contents
+
+- [Table of contents](#table-of-contents)
+- [Motivation](#motivation)
+- [Installation](#installation)
+- [Basic usage](#basic-usage)
+- [Theming](#theming)
+- [IPython/Jupyter magic](#ipythonjupyter-magic)
+- [Exception notifications](#exception-notifications)
+- [Command-line usage](#command-line-usage)
+- [Platform support](#platform-support)
+- [I can't hear anything 🙉](#i-cant-hear-anything-)
+- [Setting a default theme](#setting-a-default-theme)
+- [Command-line arguments](#command-line-arguments)
+- [Adding a new theme](#adding-a-new-theme)
+- [Things to do](#things-to-do)
+- [Acknowledgements](#acknowledgements)
+- [License](#license)
+
+## Motivation
+
+I made this because I wanted a simple auditory cue system to tell me when a long-running number crunching script had finished. I didn't want to have to fiddle with the command-line, and also wanted a cross-platform solution. Thus was born `chime`!
+
+## Installation
+
+```sh
+pip install chime
+```
+
+This library has **no dependencies**. The IPython/Jupyter functionality is only imported if you've installed the `ipython` library. It should work for any Python version above or equal to 3.6.
+
+## Basic usage
+
+`chime` puts four functions at your disposal:
+
+```py
+>>> import chime
+
+>>> chime.success()
+>>> chime.warning()
+>>> chime.error()
+>>> chime.info()
+
+```
+
+Calling any of the above functions will play a sound. Note that the sounds are played in asynchronous processes, and are thus non-blocking. Each function should take around 2ms to execute, regardless of the sound length. You're free to use each sound notification in any way you see fit. I'm not your mama.
+
+## Theming
+
+The sounds that are played depend on which theme is being used.
+
+```py
+>>> chime.theme() # return the current theme
+'chime'
+
+```
+
+Several themes are available:
+
+```py
+>>> chime.themes()
+['big-sur', 'chime', 'mario', 'material', 'pokemon', 'sonic', 'zelda']
+
+```
+
+The theme can be changed by passing a theme name to the `theme` function:
+
+```py
+>>> chime.theme('zelda')
+
+```
+
+A couple of things to note:
+
+- You can listen to the sounds interactively via [this soundboard](https://chime-soundboard.herokuapp.com/), which is made with [Streamlit](https://www.streamlit.io/).
+- A random theme will be picked each time you play a sound if you set the theme to `'random'`.
+
+## IPython/Jupyter magic
+
+Load the extension as so:
+
+```py
+%load_ext chime
+```
+
+You can wrap a line:
+
+```py
+%chime print("I'm a line")
+```
+
+You can also wrap an entire cell:
+
+```py
+%%chime
+
+print("I'm a cell")
+```
+
+The magic command will call `chime.success` when the line/cell finishes successfully. Otherwise, `chime.error` is called whenever an exception is raised.
+
+## Exception notifications
+
+If you run `chime.notify_exceptions`, then `chime.error` will be called whenever an exception is raised.
+
+```py
+chime.notify_exceptions()
+
+raise ValueError("I'm going to make some noise")
+```
+
+## Command-line usage
+
+You can run `chime` from the command-line:
+
+```sh
+$ chime
+```
+
+By default, this will play the success sound. You can also choose which sound to play, like so:
+
+```sh
+$ chime info
+```
+
+You can also choose which theme to use:
+
+```sh
+$ chime info --theme zelda
+```
+
+If you're using bash, then you can use `chime` to notify you when a program finishes:
+
+```sh
+$ echo "Hello world!"; chime
+```
+
+This will play the sound regardless of the fact that the first command succeeded or not. If you're running on Windows, then you can run the following equivalent:
+
+```sh
+> echo "Hello world!" & chime
+```
+
+## Platform support
+
+Under the hood, `chime` runs a command in the shell to play a `.wav` file. The command-line program that is used depends on the [platform](https://www.wikiwand.com/en/Computing_platform) that you're using. Platform information is available in the [`sys.platform` variable](https://docs.python.org/3/library/sys.html#sys.platform) as well as the [`platform` module](https://docs.python.org/3/library/platform.html) from the standard library. Currently, the supported platforms are:
+
+- Darwin
+- Linux
+- Windows
+
+A `UserWarning` is raised if you run a `chime` sound on an unsupported platform. Feel free to get in touch or issue a pull request if you want to add support for a specific platform. Likewise, don't hesitate if you're encountering trouble with one of the above platforms. I won't bite.
+
+## I can't hear anything 🙉
+
+Did you check if you turned your sound on? Just kidding. 😜
+
+This library is designed to be non-invasive. By default, sounds are played asynchronously in unchecked processes. Therefore, if something goes wrong, the process dies silently. If you can't hear anything and you think that the issue is coming from `chime`, then set the `sync` parameter when you play a sound:
+
+```py
+>>> chime.info(sync=True)
+
+```
+
+This will play the sound synchronously and issue a warning if something goes wrong, which should allow you to debug the issue. You can also raise an exception instead of sending a warning by setting the `raise_error` parameter:
+
+```py
+>>> chime.info(sync=True, raise_error=True)
+
+```
+
+Note that setting `raise_error` won't do anything if `sync` is set to `False`.
+
+## Setting a default theme
+
+To change the default theme a configuration file may be created in `~/.config/chime/chime.conf` on Unix or `%APPDATA%\chime\chime.ini` on Windows.
+
+For example, to change the default theme to `'zelda'`, the configuration file would contain:
+
+```ini
+[chime]
+theme = zelda
+
+```
+
+## Command-line arguments
+
+Chime works by running commands in the CLI. For instance, `aplay` is used on Linux systems, while `afplay` is used on Darwin systems. Arguments can be specified by setting the `RUN_ARGS` variable. For example, here's how to select a specific sound card, assuming a Linux system using `aplay`:
+
+```py
+>>> chime.RUN_ARGS = "--device sysdefault:CARD=PCH"
+
+```
+
+You can also specify this as a default configuration in the configuration file:
+
+```ini
+[chime]
+cli_args = '--device sysdefault:CARD=PCH'
+
+```
+
+At present, it isn't possible to pass CLI arguments on Windows, due to a limitation of the [`winsound`](https://docs.python.org/3/library/winsound.html) module.
+
+## Adding a new theme
+
+I have toyed with the idea of allowing users to add their own theme(s), but at the moment I rather keep things minimal. However, I'm happy to integrate new themes into the library. You can propose a new theme by [opening a pull request](https://github.com/MaxHalford/chime/issues/new) that adds the necessary .wav files to the [`themes` directory](https://github.com/MaxHalford/chime/tree/main/themes). A theme is made up of four files: `success.wav`, `warning.wav`, `error.wav`, and `info.wav`. That's all you need to do: the theme will picked up be automatically once the necessary files are provided.
+
+Be creative! 👩‍🎨
+
+## Things to do
+
+- Some mechanism to automatically call `chime.warning` when a warning occurs.
+- Make it work with a remote machine. For instance a Jupyter Notebook hosted on a remote machine.
+- More themes!
+
+## Acknowledgements
+
+- Special thanks to [Michael Vlah](https://github.com/vlahm) for being a gentleman by giving up the "chime" name on PyPI.
+- Thanks to u/Pajke on reddit for helping me debug Windows support.
+- Thanks to [David Chen](https://github.com/dchen327) for adding Linux support by suggesting the use of [aplay](https://linux.die.net/man/1/aplay).
+- Thanks to [Vincent Warmerdam](https://twitter.com/fishnets88) for suggesting a command-line interface.
+- Calmcode made a [video introduction to chime](https://calmcode.io/chime/introduction.html) ❤️
+- Thanks to [Paulo S. Costa](https://github.com/paw-lu) for contributing in many different ways.
+- Thanks to [d34d_m8](https://github.com/d34dm8) for adding OpenBSD support.
+
+## License
+
+As you would probably expect, this is [MIT licensed](LICENSE).
+
+
+%prep
+%autosetup -n chime-0.7.0
+
+%build
+%py3_build
+
+%install
+%py3_install
+install -d -m755 %{buildroot}/%{_pkgdocdir}
+if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi
+if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi
+if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi
+if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi
+pushd %{buildroot}
+if [ -d usr/lib ]; then
+ find usr/lib -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/lib64 ]; then
+ find usr/lib64 -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/bin ]; then
+ find usr/bin -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+if [ -d usr/sbin ]; then
+ find usr/sbin -type f -printf "\"/%h/%f\"\n" >> filelist.lst
+fi
+touch doclist.lst
+if [ -d usr/share/man ]; then
+ find usr/share/man -type f -printf "\"/%h/%f.gz\"\n" >> doclist.lst
+fi
+popd
+mv %{buildroot}/filelist.lst .
+mv %{buildroot}/doclist.lst .
+
+%files -n python3-chime -f filelist.lst
+%dir %{python3_sitelib}/*
+
+%files help -f doclist.lst
+%{_docdir}/*
+
+%changelog
+* Tue Jun 20 2023 Python_Bot <Python_Bot@openeuler.org> - 0.7.0-1
+- Package Spec generated
diff --git a/sources b/sources
new file mode 100644
index 0000000..f9b30e7
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+870d3e51139a948c7e34e04899f2e295 chime-0.7.0.tar.gz