Retrieve all classes derived from a class and sort them by a given priority and order, making it easy to draw up and use plugin-like classes.
Makes classes sortable by precedence and priority. The order of precedence of classes and their priority is defined de-centrally and at runtime.
Copyright 2016, 2017, 2018 Odin Kroeger
sortableclasses makes classes sortable. This is useful if all you want to do is take some input, apply a set of transformations, and output the result (i.e., are writing what on UNIX-ish systems is called a ‘filter’). Of course, you may just write, e.g., return t1(t2(t3(...(tn(input)))))) but the more transformations you need to add, the harder this is to maintain. sortableclasses allows you to turn the transformations into classes, assign each of them a priority (or a list of predecessors and successors) and then sort them using sort sorted.
>>> import sortableclasses >>> import abc >>> import functools >>> >>> class Transform(sortableclasses.Pluggable): ... @staticmethod ... @abc.abstractmethod ... def transform(input): ... pass ... >>> class MakeContent(Transform): ... @staticmethod ... def transform(input): ... if input == ':-(': ... return ':-|' ... return input ... >>> class MakeHappy(Transform): ... successorof = (MakeContent,) ... @staticmethod ... def transform(input): ... if input == ':-|': ... return ':-)' ... return input ... >>> class MakeVeryHappy(Transform): ... successorof = (MakeHappy,) ... @staticmethod ... def transform(input): ... if input == ':-)': ... return ':-D' ... return input ... >>> transforms = sorted(Transform.getderived()) >>> transforms [<class 'MakeContent'>, <class 'MakeHappy'>, <class 'MakeVeryHappy'>] >>> input = ':-(' >>> functools.reduce(lambda k, s: s.transform(k), transforms, input) ':-D'
You use sortableclasses at your own risk. You have been warned.
sortableclasses works only in Python 3.
Clone the repository and run setup.py install.
See <https://sortableclassespy.readthedocs.io/en/latest/> for reference.
You can also view the inline documentation, by:
- If there’s something wrong with sortableclasses, please open an issue at:
This programme is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This programme is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>.
- Read the docs:
Release history Release notifications
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size sortableclasses-0.9.4b0-py3-none-any.whl (18.4 kB)||File type Wheel||Python version py3||Upload date||Hashes View hashes|
|Filename, size sortableclasses-0.9.4b0.tar.gz (17.9 kB)||File type Source||Python version None||Upload date||Hashes View hashes|
Hashes for sortableclasses-0.9.4b0-py3-none-any.whl