############################################################################## # # Copyright (c) 2001, 2002 Zope Corporation and Contributors. # All Rights Reserved. # # This software is subject to the provisions of the Zope Public License, # Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution. # THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED # WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS # FOR A PARTICULAR PURPOSE. # ############################################################################## """Interfaces This package implements the Python "scarecrow" proposal. The package exports a single name, 'Interface' directly. Interface is used to create an interface with a class statement, as in: from Interface import Interface class IMyInterface(Interface): '''Interface documentation ''' def meth(arg1, arg2): '''Documentation for meth ''' # Note that there is no self argument To find out what you can do with interfaces, see the interface interface, IInterface in the IInterface module. The package has several public modules: o Attribute has the implementation for interface attributes for people who want to build interfaces by hand. (Maybe someone should cry YAGNI for this. ;) o Document has a utility for documenting an interface as structured text. o Exceptions has the interface-defined exceptions o IAttribute defines the attribute descriptor interface. o IElement defined the base interface for IAttribute, IInterface, and IMethod. o IInterface defines the interface interface o IMethod defined the method interface. o Implements has various utilities for examining interface assertions. o Method has the implementation for interface methods. See above. o Verify has utilities for verifying (sort of) interfaces. See the module doc strings for more information. There is also a script, pyself.py in the package that can be used to create interface skeletins. Run it without arguments to get documentation. Revision information: $Id: __init__.py 40218 2005-11-18 14:39:19Z andreasjung $ """ from _Interface import Interface from Attribute import Attribute Base = Interface # XXX We need to stamp out Base usage