diff options
author | 2019-04-15 19:19:38 +0200 | |
---|---|---|
committer | 2019-04-15 19:19:38 +0200 | |
commit | 2b69aeb0ba03acdacc6daf6edde4c4a5143a5bf7 (patch) | |
tree | 5f7da08d375603f56b172f62121286319087ad53 /pydis_site/apps/api/models/utils.py | |
parent | Add missing test. (diff) | |
parent | Remove the third infraction. (diff) |
Merge pull request #207 from python-discord/api/split-models
#205: split models into multiple modules
Diffstat (limited to 'pydis_site/apps/api/models/utils.py')
-rw-r--r-- | pydis_site/apps/api/models/utils.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/pydis_site/apps/api/models/utils.py b/pydis_site/apps/api/models/utils.py new file mode 100644 index 00000000..731486e7 --- /dev/null +++ b/pydis_site/apps/api/models/utils.py @@ -0,0 +1,20 @@ +from operator import itemgetter + + +class ModelReprMixin: + """ + Adds a `__repr__` method to the model subclassing this + mixin which will display the model's class name along + with all parameters used to construct the object. + """ + + def __repr__(self): + attributes = ' '.join( + f'{attribute}={value!r}' + for attribute, value in sorted( + self.__dict__.items(), + key=itemgetter(0) + ) + if not attribute.startswith('_') + ) + return f'<{self.__class__.__name__}({attributes})>' |