From: Dave Rolsky <autarch@urth.org> Date: Thu, 24 Sep 2009 21:55:32 +0000 (-0500) Subject: Add a short section on MX modules X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=0066613deeccc40e1fd0a6216c4f924a85901e59;p=gitmo%2Fmoose-presentations.git Add a short section on MX modules --- diff --git a/moose-class/slides/index.html b/moose-class/slides/index.html index 98e190a..bc2aeb1 100644 --- a/moose-class/slides/index.html +++ b/moose-class/slides/index.html @@ -3534,9 +3534,199 @@ Iterate til this passes all its tests</pre> </div> <div class="slide fake-slide0"> - <h1>Part 8: A Tour of MooseX</h1> + <h1>Part 8: A Brief Tour of MooseX</h1> </div> +<div clas="slide"> + <h1>Notable Moose Extensions on CPAN</h1> + + <ul> + <li><strong>Not comprehensive</strong></li> + <li>128 MooseX distributions on CPAN as of 09/24/2009</li> + <li>Some of them are crap</li> + </ul> +</div> + +<div class="slide"> + <h1>Already Mentioned Several</h1> + + <ul> + <li>MooseX::NonMoose - best solution for subclassing non-Moose parents</li> + <li>MooseX::Declare - <em>real</em> Perl 5 OO</li> + <li>MooseX::FollowPBP and MooseX::SemiAffordanceAccessor</li> + <li>MooseX::Params::Validate and MooseX::Method::Signatures</li> + <li>MooseX::Types</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::Declare</h1> + +<pre><code>use MooseX::Declare; +use 5.10.0; # for say + +class Person { + has greeting + => ( is => 'ro', isa => 'Str' ); + + method speak { + say $self->greeting; + } +}</code></pre> +</div> + +<div class="slide"> + <h1>MooseX::Declare</h1> + + <ul> + <li>Still experimental-ish, but seeing more and more use</li> + <li><strong>Not</strong> a source filter!</li> + <li>Hooks into the Perl parser rather than filtering all your code</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::StrictConstructor</h1> + + <ul> + <li>By default, unknown constructor arguments are ignore</li> + <li>MX::StrictConstructor turns these into an error</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::StrictConstructor</h1> + + <pre><code>package Person; + +use Moose; +<span class="highlight">use MooseX::StrictConstructor;</span> + +has name => ( is => 'ro' ); + +Person->new + ( na<span class="wrong">n</span>e => 'Ringo Shiina' ); # kaboom</code></pre> +</div> + +<div class="slide"> + <h1>MooseX::Traits</h1> + + <ul> + <li>Combines object construction and role application</li> + <li>Makes it easy to create one-off customized objects</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::Traits</h1> + + <pre><code>package MyApp::Thingy; +use Moose; + +<span class="highlight">with 'MooseX::Traits';</span> + +my $thing = + MyApp::Thingy-><span class="highlight">new_with_traits</span> + ( <span class="highlight">traits => [ 'Foo', 'Bar' ],</span> + size => 42 );</code></pre> +</div> + +<div class="slide"> + <h1>MooseX::Getopt</h1> + + <ul> + <li>Makes command-line interface programs easy!</li> + <li>Construct an object from CLI arguments</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::Getopt</h1> + + <pre><code>package App::CLI; +use Moose; + +<span class="highlight">with 'MooseX::Getopt';</span> + +has file => + ( is => 'ro', required => 1 ); +has filters => + ( is => 'ro', isa => 'Str' ); + +sub run { ... }</code></pre> +</div> + +<div class="slide"> + <h1>MooseX::Getopt</h1> + + <ul> + <li>Then call it like this:</li> + </ul> + +<pre><code>#!/usr/bin/perl + +use App::CLI; + +<span class="highlight">App::CLI->new_with_options()</span>->run();</code></pre> + +<pre>$ myapp-cli \ + --file foo \ + --filters compress \ + --filters sanitize</pre> +</div> + +<div class="slide"> + <h1>MooseX::Clone</h1> + + <pre><code>package Person; + +use Moose; +<span class="highlight">with 'MooseX::Clone';</span> + +my $person = Person->new; +my $clone = <span class="highlight">$person->clone;</span></code></pre> +</div> + +<div class="slide"> + <h1>MooseX::NonMoose</h1> + + <ul> + <li>Highly recommended for subclassing non-Moose parents</li> + <li>Gets all the little annoying details right</li> + </ul> +</div> + +<div class="slide"> + <h1>MooseX::Role::Parameterized</h1> + + <pre><code>package HasCollection; +use MooseX::Role::Parameterized; + +parameter type => ( isa => 'Str', + default => 'Item' ); +role { + my $p = shift; + + my $type = 'ArrayRef[' . $p->type() . ']'; + has collection => + ( is => 'ro', + isa => $type ); +};</code></pre> +</div> + +<div class="slide"> + <h1>MooseX::Role::Parameterized</h1> + + <pre><code>package Person; + +use Moose; +with HasCollection => { type => 'Int' };</code></pre> +</div> + +<div class="slide"> + <h1>Questions?</h1> +</div> + <div class="slide fake-slide0"> <h1>Part 9: Writing Moose Extensions</h1> </div>