|  | Boost.PythonHeaders <boost/python/init.hpp> | 
initinit synopsisinit
              constructorsoptionaloptional synopsis<boost/python/init.hpp> defines the interface for
    exposing C++ constructors to Python as extension class
    __init__ functions.
__init__ methods to be generated for an extension class, and
    the result has the following properties: 
    
- docstring: An ntbs whose value will bound to the method's
__doc__attribute- keywords: A keyword-expression which will be used to name (a trailing subsequence of) the arguments to the generated
__init__function(s).- call policies: An instance of a model of CallPolicies.
- argument types: An MPL sequence of C++ argument types which will be used to construct the wrapped C++ object. An init expression has one or more valid prefixes which are given by a sequence of prefixes of its argument types.
init<T1 =
    unspecified, T2 =
    unspecified,...Tn =
    unspecified>A MPL sequence which
    can be used to specify a family of one or more __init__
    functions. Only the last Ti supplied
    may be an instantiation of optional<...>.
init
    synopsis
namespace boost { namespace python
{
  template <T1 = unspecified,...Tn = unspecified>
  struct init
  {
      init(char const* doc = 0);
      template <class Keywords> init(Keywords const& kw, char const* doc = 0);
      template <class Keywords> init(char const* doc, Keywords const& kw);
      template <class CallPolicies>
      unspecified operator[](CallPolicies const& policies) const
  };
}}
    init
    constructorsinit(char const* doc = 0); template <class Keywords> init(Keywords const& kw, char const* doc = 0); template <class Keywords> init(char const* doc, Keywords const& kw);
doc is an ntbs. If supplied, kw is the
      result of a doc and whose keywords are
      a reference to kw. If the first form is used, the
      resulting expression's keywords are empty. The expression's
      call policies are an instance of default_call_policies.
      If Tn is optional<U1, U2,...
      Um>, the
      expression's valid prefixes are given by:(Otherwise, the expression has one valid prefix given by the the template arguments the user specified.T1, T2,...Tn-1), (T1, T2,...Tn-1, U1), (T1, T2,...Tn-1, U1, U2), ...(T1, T2,...Tn-1, U1, U2,...Um).
init
    observer functionstemplate <class Policies> unspecified operator[](Policies const& policies) const
init object except that its call
      policies are replaced by a reference to
      policies.optional<T1
    = unspecified, T2 =
    unspecified,...Tn =
    unspecified>A MPL sequence which
    can be used to specify the optional arguments to an __init__
    function.
optional synopsis
namespace boost { namespace python
{
  template <T1 = unspecified,...Tn = unspecified>
  struct optional {};
}}
    Given the C++ declarations:
class Y;
class X
{
 public:
   X(int x, Y* y) : m_y(y) {}
   X(double);
 private:
   Y* m_y;
};
    A corresponding Boost.Python extension class can be created with: 
using namespace boost::python;
class_<X>("X", "This is X's docstring.",
          init<int,char const*>(args("x","y"), "X.__init__'s docstring")[
                with_custodian_and_ward<1,3>()]
          )
   .def(init<double>())
   ;
    © Copyright Dave Abrahams 2002.