Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/0h-n0/simple-lock
https://github.com/0h-n0/simple-lock
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/0h-n0/simple-lock
- Owner: 0h-n0
- License: mit
- Created: 2018-06-11T09:43:59.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-11-25T19:39:00.000Z (about 6 years ago)
- Last Synced: 2024-11-09T09:49:09.344Z (3 months ago)
- Language: Python
- Size: 34.2 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/a0f40/a0f4064a0f058a8589711d3143a2bc71c867e046" alt="LICENCE"](https://github.com/0h-n0/simple-lock)
[data:image/s3,"s3://crabby-images/7f61a/7f61a13eacab90404f73333cae07a1a5be3c87b6" alt="PYTHON version"](https://github.com/0h-n0/simple-lock)
[data:image/s3,"s3://crabby-images/d573a/d573a7825c7649adf3206ab4e58c709d9172c156" alt="PyPI version"](https://badge.fury.io/py/simple-lock)
[data:image/s3,"s3://crabby-images/15d78/15d7837f4df2eaea76f90f7001f66d7d6998ca57" alt="Build Status"](https://travis-ci.org/0h-n0/simple-lock)
[data:image/s3,"s3://crabby-images/b738f/b738fc689184333ca278a14088c8744d852c50a9" alt="codecov"](https://codecov.io/gh/0h-n0/simple-lock)
[data:image/s3,"s3://crabby-images/7ea72/7ea72ce02c69e468f767a375b0d9e9053ce9907d" alt="Maintainability"](https://codeclimate.com/github/0h-n0/simple-lock/maintainability)
[data:image/s3,"s3://crabby-images/21165/21165c1e93fb536ac77a492a7038f878822959ff" alt="BCH compliance"](https://bettercodehub.com/)
[data:image/s3,"s3://crabby-images/4d8b8/4d8b85b267c4d639a98f0e610d6b2dbd65eb7eef" alt="Downloads"](https://github.com/0h-n0/simple-lock)# simple-lock
simple-lock provides lock system as a decorator or with-statement in your code. It is easy to use them.
## Concept
You can easily implement lock system in your application with modifing a few line. There are mainly two decorator in `simple_lock`. First, `simple_lock.lock` locks function and create a lockfile. After that, other functions refer to the lockfile can't be executed normally. Second, without creating a new lockfile, `simple_lock.watch` watchs a lockfile provieded as one of arguments without creating a new lockfile.
## Instalation
```shell
$ pip install simple-lock
```## How to use
### Lock your function with `simple_lock.lock` decorator.
When a funciton try to create a lockfile and the lockfile already exists. `simple_lock.lock` decorator returns `return_value` like the following codes.
```test.py
from simple_lock import lock
@lock(filename='simple.lock', path='~/locks',
return_value=10)
def sleep():
import time
time.sleep(10)
sleep() # -> 10
```You can provide a function as 'return_value' argument and arguments of 'return_value'.
```test.py
from simple_lock import lock
def add(a, b):
return a + b@lock(filename='simple.lock', path='~/locks',
return_value=add
a=1, b=1)
def sleep():
import time
time.sleep(10)
sleep() # -> 2
````simple_lock.watch` also provides functions similar to `simple_lock.lock`. The difference between `simple_lock.lock` and `simple_lock.watch` is just whether lockfile is created or not.
```test.py
from simple_lock import watch
@watch(filename='simple.lock', path='~/locks',
return_value=10)
def sleep():
import time
time.sleep(10)
sleep() # -> 10
``````test.py
from simple_lock import watch
def add(a, b):
return a + b@watch(filename='simple.lock', path='~/locks',
return_value=add,
a=1, b=1)
def sleep():
import time
time.sleep(10)
sleep() # -> 2
```## References
* https://github.com/benediktschmitt/py-filelock