Memory efficient Python objects
Clone or download
MatthieuDartiailh Add testing for Python 3.7 (#81)
* Add testing for Python 3.7

* travis: try to use different distributions based on python version

Based on what is now done in mypy: python/mypy#5417

* travis: try setting sudo to required and use pip cache

* atomlist: hack around Python 3.7 fastcall protocol
Latest commit de91134 Sep 20, 2018

README.rst

Welcome to Atom

https://travis-ci.org/nucleic/atom.svg?branch=master

Atom is a framework for creating memory efficient Python objects with enhanced features such as dynamic initialization, validation, and change notification for object attributes. It provides the default model binding behaviour for the Enaml UI framework.

Illustrative Example:

from atom.api import Atom, Unicode, Range, Bool, observe


class Person(Atom):
    """ A simple class representing a person object.

    """
    last_name = Unicode()

    first_name = Unicode()

    age = Range(low=0)

    debug = Bool(False)

    @observe('age')
    def debug_print(self, change):
        """ Prints out a debug message whenever the person's age changes.

        """
        if self.debug:
            templ = "{first} {last} is {age} years old."
            s = templ.format(
                first=self.first_name, last=self.last_name, age=self.age,
            )
            print(s)

    def _default_first_name(self):
        return 'John'


john = Person(last_name='Doe', age=42)
john.debug = True
john.age = 43  # prints message
john.age = 'forty three'   # raises TypeError

For version information, see the Revision History.