Metadata-Version: 2.1
Name: decorateme
Version: 0.2.3
Summary: Python decorators for str/repr, equality, immutability, and more.
Home-page: https://github.com/dmyersturnbull/decorate-me
License: Apache-2.0
Keywords: python,decorators,repr
Author: Douglas Myers-Turnbull
Maintainer: Douglas Myers-Turnbull
Requires-Python: >=3.8,<4.0
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Project-URL: CI, https://github.com/dmyersturnbull/decorate-me/actions
Project-URL: Documentation, https://decorate-me.readthedocs.io
Project-URL: Download, https://pypi.org/project/decorateme/
Project-URL: Issues, https://github.com/dmyersturnbull/decorate-me/issues
Project-URL: Repository, https://github.com/dmyersturnbull/decorate-me
Description-Content-Type: text/markdown

# Decorate-me

[![Version status](https://img.shields.io/pypi/status/decorateme?label=status)](https://pypi.org/project/decorateme)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)
[![Python version compatibility](https://img.shields.io/pypi/pyversions/decorateme?label=Python)](https://pypi.org/project/decorateme)
[![Version on Docker Hub](https://img.shields.io/docker/v/dmyersturnbull/decorate-me?color=green&label=Docker%20Hub)](https://hub.docker.com/repository/docker/dmyersturnbull/decorate-me)
[![Version on Github](https://img.shields.io/github/v/release/dmyersturnbull/decorate-me?include_prereleases&label=GitHub)](https://github.com/dmyersturnbull/decorate-me/releases)
[![Version on PyPi](https://img.shields.io/pypi/v/decorateme?label=PyPi)](https://pypi.org/project/decorateme)  
[![Build (Actions)](https://img.shields.io/github/workflow/status/dmyersturnbull/decorate-me/Build%20&%20test?label=Tests)](https://github.com/dmyersturnbull/decorate-me/actions)
[![Documentation status](https://readthedocs.org/projects/decorate-me/badge)](https://decorate-me.readthedocs.io/en/stable)
[![Coverage (coveralls)](https://coveralls.io/repos/github/dmyersturnbull/decorate-me/badge.svg?branch=main&service=github)](https://coveralls.io/github/dmyersturnbull/decorate-me?branch=main)
[![Maintainability (Code Climate)](https://api.codeclimate.com/v1/badges/ce5a27b46cbe0f3c3039/maintainability)](https://codeclimate.com/github/dmyersturnbull/decorate-me/maintainability)
[![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/dmyersturnbull/decorate-me/badges/quality-score.png?b=main)](https://scrutinizer-ci.com/g/dmyersturnbull/decorate-me/?branch=main)

Python decorators to trim boilerplate.

### Example 1: auto-add __repr__, __str__, __hash__, and __eq__

```python
import decorateme as abcd

@abcd.auto_obj()
class Animal:
    def __init__(self, species: str, age: int):
        self.species = species
        self.age = age

luna1 = Animal("dog", 12)
luna2 = Animal("dog", 12)
str(luna)  # "Animal(species="dog", age=12)"
assert luna1 == luna2
assert hash(luna1) == hash(luna2)
```

### Example 2: Customize

```python
import decorateme as abcd

@abcd.auto_str(only=["species"])
class Animal:
    ...
```

### Example 3: Add warnings about code quality

```python
import decorateme as abcd


@abcd._status("immature")
def my_function():
  ...


my_function()  # warns with an ImmatureWarning
```

### Example 4: Iterate, etc.

```python
import decorateme as abcd
@abcd.sequence_over("members")
class Team:
    def __init__(self, members: list):
        self.members = members

team = Team(["john", "kerri"])
list(team)  # ["john", "kerri"]

@abcd.float_type("v")
class Size:
    def __init__(self, v: float):
        self.v = v
      
float(Size(6.2))  # 6.2
```

### Example 5: clearly document behavior

```python
import decorateme as abcd

@abcd.not_thread_safe
def run_command():
    ...
```

### Example 6: combine things


```python
import decorateme as abcd

@abcd.auto_obj()
@abcd.float_type("weight")
class Uno:
    def __init__(self, weight):
        self.weight = weight

light1, light2, heavy = Uno(3.1), Uno(3.1), Uno(12.8)
assert light1 == light2 != heavy
print(light1)  # 'Duo(weight=22.3)'
assert light1 * heavy == 39.68
```


Licensed under the [Apache License, version 2.0](https://www.apache.org/licenses/LICENSE-2.0).
[New issues](https://github.com/dmyersturnbull/decorate-me/issues) and pull requests are welcome.
Please refer to the [contributing guide](https://github.com/dmyersturnbull/decorate-me/blob/master/CONTRIBUTING.md).
Generated with [Tyrannosaurus](https://github.com/dmyersturnbull/tyrannosaurus).


### List of decorators

**String-like methods**
- auto_repr_str
- auto_str
- auto_repr
- auto_html (for display in Jupyter)
- auto_info (add a .info method)

**Equality**
- auto_eq
- auto_hash
- total_ordering  (from functools)

**Make your class smart**
- auto_obj (auto- for eq, str, and repr)
- dataclass (from dataclasses)

**Docstring-related**
- copy_docstring
- append_docstring

**Timing**
- takes_seconds
- takes_seconds_named
- auto_timeout

**Allow a class to be used as a type**
- iterable_over
- collection_over
- sequence_over
- float_type
- int_type

**Overriding / inheritance**
- final
- overrides
- override_recommended
- ABC (from abc)
- ABCMeta  (from abc)
- abstractmethod  (from abc)

**Mark purpose / use**
- internal
- external
- reserved

**Multithreading**
- thread_safe
- not_thread_safe

**Mutability**
- mutable
- immutable

**Code maturity**
- status (code deprecation & immaturity warnings)

**Singletons**
- auto_singleton


