- Author: João Bernardo Oliveira (@jbvsmo)
- Version: 0.8
- GitHub: https://github.com/jbvsmo/makeobj
- Wiki: https://github.com/jbvsmo/makeobj/wiki
MakeObj is a module to help create powerful enumeration classes with support to attributes specific for each element.
This module is compatible with Python versions 2.6+ and 3.0+
MakeObj lets you create enumerations with a simple language like that:
@obj RGBColors =:
@keys = 'red', 'green', 'blue'
@attr hex = 'ff0000', '00ff00', '0000ff'
@attr is_nice =:
@default = False
@set => 'blue': TrueThen you can use like this:
RGBColors = makeobj.parse(text)
if RGBColors.blue.is_nice:
print('I like blue')
print('The hex value of {0.name} is #{0.hex}'.format(RGBColors.red))If you have simple enums, you can use like this:
RGBColors = makeobj.make('RGBColors', ['red', 'green', 'blue'])or, with some more data, one may want to write a class:
class RGBColors(makeobj.Obj):
red, green, blue = makeobj.keys(3)
hex = makeobj.attr('ff0000', '00ff00', '0000ff')This project is in test stage and some issues are expected mainly in the parsing language. It will parse conformant code, but still may not show all the errors and may load an invalid file skipping some data when it should raise an error.
The make function works fine but it may be easier to write a class instead. The
SubObj machinery (see the Wiki entry)
only works in the Enum Language. Yet!
- Enumerations with simple attributes, methods or even small objects with their own attributes.
- An Enumeration Language for easy creation of objects.
- The enumeration by default use the values 0 to N-1 but you may specify your own values.
- The elements of the class are really instances of it and can take advantage of the
isinstancefunction. Because of a metaclass factory, the classes do not share unwanted attributes with the instances. - The elements come with two attributes by default:
nameandvalue(also_nameand_valuein case you want to override them). - Elements can (and should!) be checked with the
iscomparison and can be retrieved by name in string form or value from their class:RGBColors('red')orRGBColors[0]orRGBColors.redresult in the same object. - Enum values must be integer for simplicity and to help usability.
- Subclassing is great!
- Finalize the specs of MakeObj Enum Language v1.0.
- Change the
@methodproperty to allow better function/method support - Create a helper function to load a directory of
.makeobjfiles as they were a python module. - Better suport on subclassing: multiple inheritance, parent default attributes