aboutsummaryrefslogtreecommitdiffstats
path: root/pydis_site/apps/api/models/utils.py
diff options
context:
space:
mode:
authorGravatar Johannes Christ <[email protected]>2019-04-15 19:19:38 +0200
committerGravatar GitHub <[email protected]>2019-04-15 19:19:38 +0200
commit2b69aeb0ba03acdacc6daf6edde4c4a5143a5bf7 (patch)
tree5f7da08d375603f56b172f62121286319087ad53 /pydis_site/apps/api/models/utils.py
parentAdd missing test. (diff)
parentRemove 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.py20
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})>'