Noose - just enough object orientation to hang yourself


version 0.001


Moose led to Mouse led to Moo led to Mo led finally to M, which gives you the least object-orientation possible, which is none at all. Noose continues this illustrious trend.

Noose gives you just enough object orientation to hang yourself.



Imports the "new" constructor into your class.


You can use "import" to bring new into your class, and it will become a constructor that blesses any key-value pairs provided into an object of the specified class. This is probably not very useful if you are trying not to hang yourself, hint hint.

Simply use Noose to give your class a new method. When the method is called with some key-value pairs, a new object of the specified class is created with the given attributes. Methods are created for each attribute, in the familiar accessor form: calling the method with no arguments just returns the current value for that attribute; calling the method with an argument sets the attribute to that value. No checking of any kind is performed.

Controlling object construction

If you need to have attributes that shouldn't be given in the contructor, or if you want to have any amount of control over object construction at all (which is proably a good idea), then give the empty list when loading Noose, and write a constructor that provides the attributes.

You can use the same technique to override parameters the caller gives you, add new ones, provide defaults, filter or alter values, die if invalid data is provided etc.

    package Fancy;
    use Noose ();

    sub new {
        my $class = shift;
        my %args  = @_;

        die 'RTFM' unless $args{make_it_go};
        $args{fancy}  = 1;
        $args{useful} = 0;

        return Noose::new($class, %args);

    # class body
    sub method { ... }

See examples/ for another example of this technique.

Using the constructor to clone an object

If you call new as an object method, then you will get a clone of the object, unless you used some parameters, in which case those parameters will be used to create accessors just like with normal object creation. If there already were accessors by those names, then the new values will prevail.

See examples/ for example usage.


See the examples subdirectory.


In case it isn't obvious, you should not actually use Noose. It has an Acme:: module in the dependency tree, for crying out loud!


The latest version of this module is available from the Comprehensive Perl Archive Network (CPAN). Visit to find a CPAN site near you, or see


The development version is on github at and may be cloned from git://


You can make new bug reports, and view existing ones, through the web interface at


Mike Doherty <>


This software is copyright (c) 2012 by Mike Doherty.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.