=head2 C<< initialize(ClassName) -> Mouse::Meta::Class >>
-Finds or creates a Mouse::Meta::Class instance for the given ClassName. Only
+Finds or creates a C<Mouse::Meta::Class> instance for the given ClassName. Only
one instance should exist for a given class.
=head2 C<< name -> ClassName >>
Gets (or sets) the list of superclasses of the owner class.
-=head2 C<< add_attribute(name => spec | Mouse::Meta::Attribute) >>
+=head2 C<< add_method(name => CodeRef) >>
-Begins keeping track of the existing L<Mouse::Meta::Attribute> for the owner
-class.
+Adds a method to the owner class.
-=head2 C<< get_all_attributes -> (Mouse::Meta::Attribute) >>
+=head2 C<< has_method(name) -> Bool >>
-Returns the list of all L<Mouse::Meta::Attribute> instances associated with
-this class and its superclasses.
+Returns whether we have a method with the given name.
-=head2 C<< get_attribute_list -> { name => Mouse::Meta::Attribute } >>
+=head2 C<< get_method(name) -> Mouse::Meta::Method | undef >>
-This returns a list of attribute names which are defined in the local
-class. If you want a list of all applicable attributes for a class,
-use the C<get_all_attributes> method.
+Returns a L<Mouse::Meta::Method> with the given name.
+
+Note that you can also use C<< $metaclass->name->can($name) >> for a method body.
+
+=head2 C<< get_method_list -> Names >>
+
+Returns a list of method names which are defined in the local class.
+If you want a list of all applicable methods for a class, use the
+C<get_all_methods> method.
+
+=head2 C<< get_all_methods -> (Mouse::Meta::Method) >>
+
+Return the list of all L<Mouse::Meta::Method> instances associated with
+the class and its superclasses.
+
+=head2 C<< add_attribute(name => spec | Mouse::Meta::Attribute) >>
+
+Begins keeping track of the existing L<Mouse::Meta::Attribute> for the owner
+class.
=head2 C<< has_attribute(Name) -> Bool >>
Returns whether we have a L<Mouse::Meta::Attribute> with the given name.
-=head2 get_attribute Name -> Mouse::Meta::Attribute | undef
+=head2 C<< get_attribute Name -> Mouse::Meta::Attribute | undef >>
Returns the L<Mouse::Meta::Attribute> with the given name.
+=head2 C<< get_attribute_list -> Names >>
+
+Returns a list of attribute names which are defined in the local
+class. If you want a list of all applicable attributes for a class,
+use the C<get_all_attributes> method.
+
+=head2 C<< get_all_attributes -> (Mouse::Meta::Attribute) >>
+
+Returns the list of all L<Mouse::Meta::Attribute> instances associated with
+this class and its superclasses.
+
=head2 C<< linearized_isa -> [ClassNames] >>
Returns the list of classes in method dispatch order, with duplicates removed.
=head2 C<< clone_object(Instance, Parameters) -> Instance >>
-Clones the given C<Instance> which must be an instance governed by this
+Clones the given instance which must be an instance governed by this
metaclass.
+=head2 C<< throw_error(Message, Parameters) >>
+
+Throws an error with the given message.
+
=head1 SEE ALSO
L<Moose::Meta::Class>
+L<Class::MOP::Class>
+
=cut
=head1 METHODS
-=head2 C<< new arguments -> Object >>
+=head2 C<< new (Arguments) -> Object >>
Instantiates a new C<Mouse::Object>. This is obviously intended for subclasses.
-=head2 C<< BUILDARGS(@args) -> HashRef >>
+=head2 C<< BUILDARGS (Arguments) -> HashRef >>
Lets you override the arguments that C<new> takes. Return a hashref of
parameters.
-=head2 C<< BUILDALL \%args >>
+=head2 C<< BUILDALL (\%args) >>
Calls C<BUILD> on each class in the class hierarchy. This is called at the
end of C<new>.
-=head2 C<< BUILD \%args >>
+=head2 C<< BUILD (\%args) >>
You may put any business logic initialization in BUILD methods. You don't
need to redispatch or return any specific value.