X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=moose-class%2Fslides%2Findex.html;h=1f2c059df5c1bc9eaddff47d5e0699b808f42890;hb=5b7f2dc1f80c19906bedd8ddc03a38db01db31d2;hp=dbb184dd7680df84682c805c9ebf0dd9f3ba31ee;hpb=3367db4d30307102fef46ce36a819d04729cbb49;p=gitmo%2Fmoose-presentations.git diff --git a/moose-class/slides/index.html b/moose-class/slides/index.html index dbb184d..1f2c059 100644 --- a/moose-class/slides/index.html +++ b/moose-class/slides/index.html @@ -52,7 +52,7 @@ img#me05 {top: 43px;left: 36px;}

Introduction to Moose

-

Dave Rolsky +

Dave Rolsky

@@ -71,8 +71,8 @@ img#me05 {top: 43px;left: 36px;}
@@ -155,7 +155,7 @@ img#me05 {top: 43px;left: 36px;}
package Person;
 use Moose;
 
-has first_name => ( is => 'rw' );
+has first_name => ( is => 'ro' ); @@ -950,10 +950,10 @@ sub BUILD {

Object Construction a la Moose

-
Person->new(@_)
+
Person->new(@args)
    -
  1. Calls Person->BUILDARGS(@_) to turn @_ into a hashref
  2. +
  3. Calls Person->BUILDARGS(@args) to turn @args into a hashref
  4. Blesses a reference
  5. Populates attributes based on the hashref from #1
  6. Calls $new_object->BUILDALL($constructor_args) @@ -1032,7 +1032,7 @@ extends 'LWP';
  7. No DEMOLISH()
  8. -
  9. But see MooseX::NonMoose for a workaround
  10. +
  11. But MooseX::NonMoose fixes all of this
@@ -1069,7 +1069,7 @@ use Moose; @@ -1155,8 +1155,8 @@ Person->can('extends');

Cleaning Up Moose Droppings

package Person;
-use namespace::autoclean;
 use Moose;
+use namespace::autoclean;
 
 ...
 
@@ -1234,7 +1234,7 @@ use Moose;
 
 # perl bin/prove -lv t/00-prereq.t
 
-# perl install-moose (if needed)
+## Read the instructions in t/01-classes.t
 
 # perl bin/prove -lv t/01-classes.t
 
@@ -1307,23 +1307,25 @@ sub print {
   
package Person;
 use Moose;
 
-with 'HasPermissions';
+with 'Printable';

Classes Consume Roles

-
my $person = Person->new(
+
package Person;
+
+sub as_string { $_[0]->first_name() }
+
+...
+
+my $person = Person->new(
     first_name   => 'Kenichi',
     last_name    => 'Asai',
     access_level => 42,
 );
 
-print $person->full_name
-    . ' has '
-    . $person->can_access(42)
-        ? 'great power'
-        : 'little power';
+$person->print();
@@ -1340,7 +1342,9 @@ print $person->full_name
package Person;
 use Moose;
 
-with 'Printable';
+with 'Printable'; + +sub as_string { $_[0]->first_name() }
@@ -1351,6 +1355,8 @@ use Moose; with 'Printable'; +sub as_string { $_[0]->first_name() } + has has_been_printed => ( is => 'rw' ); sub print { @@ -1479,34 +1485,6 @@ Integer->does('Comparable'); # also true!
-

Name Conflicts Between Roles

- -
package HasSubProcess;
-use Moose::Role;
-
-sub execute { ... }
-
-package Killer;
-use Moose::Role;
-
-with 'HasSubProcess';
-
-sub execute { ... }
-
- -
-

Delayed Conflict

- -
package SysadminAssassin;
-with 'Killer';
- - -
- -

Roles as Interfaces

+

Read-only vs Read-write

+ + +
+ +

Required-ness

-

What if I Want to Share?

- -
package Person;
-use Moose;
-
-my $highlander_bank =
-    Bank->new(
-        name => 'Clan MacLeod Trust' );
-
-has bank => (
-    is      => 'rw',
-    default => sub { $highlander_bank },
-);
-
- -

Builder

@@ -2407,62 +2369,6 @@ around run => sub {
-

Augment and Inner

- - -
- -
-

Augment and Inner

- -
package Document;
-
-sub xml { '<doc>' . inner() . '</doc>' }
-
-package Report;
-extends 'Document';
-augment xml =>
-    sub { my $self = shift;
-          $self->title() . inner() . $self->summary() };
-
-package TPSReport;
-extends 'Report';
-augment xml =>
-    sub { my $self = shift;
-          $self->tps_xml() . inner() };
-
- -
-

Augment and Inner

- - -
- -
-

Augment and Inner Usage

- - -
- -

Method Modifiers Summary

- -
- -
-

Method Modifiers Summary

- -
@@ -2708,11 +2600,15 @@ has start_date => (

Subtype Shortcuts - class_type

use Moose::Util::TypeConstraints;
-class_type 'DateTime';
+ +class_type 'DateTime'; + +
-
subtype     'DateTime',
+

+subtype     'DateTime',
     as      'Object',
     where   { $_->isa('DateTime') },
     message { ... };
@@ -2722,11 +2618,15 @@ class_type 'DateTime';

Subtype Shortcuts - role_type

use Moose::Util::TypeConstraints;
-role_type 'Printable';
+ +role_type 'Printable'; + +
-
subtype 'Printable',
+

+subtype 'Printable',
     as  'Object',
     where
         { Moose::Util::does_role(
@@ -2738,11 +2638,15 @@ role_type 'Printable';

Subtype Shortcuts - duck_type

use Moose::Util::TypeConstraints;
-duck_type Car => qw( run break_down );
+ +duck_type Car => qw( run break_down ); + +

-
subtype 'Car',
+

+subtype 'Car',
     as      'Object',
     where   { all { $_->can($_) }
               qw( run break_down ) },
@@ -2753,11 +2657,15 @@ duck_type Car => qw( run break_down );

Subtype Shortcuts - enum

use Moose::Util::TypeConstraints;
-enum Color => qw( red blue green );
+ +enum Color => qw( red blue green ); + +

-
my %ok = map { $_ => 1 }
+

+my %ok = map { $_ => 1 }
              qw( red blue green );
 
 subtype     'Color'
@@ -2772,7 +2680,9 @@ subtype     'Color'
   
package Person;
 
 my $posint =
-    subtype as 'Int', where { $_ > 0 };
+    subtype
+        as 'Int',
+        where { $_ > 0 };
 
 has size => (
     is  => 'ro',
@@ -2831,7 +2741,8 @@ coerce 'My::DateTime',
 

Coercion Examples

-
coerce 'ArrayRef[Int]',
+  
# BAD CODE - DO NOT COPY
+coerce 'ArrayRef[Int]',
     from 'Int',
     via  { [ $_ ] };
@@ -2929,7 +2840,7 @@ sub work {

Digression: The Type Registry

    -
  • Types are actually Moose::Meta::TypeConstraints objects
  • +
  • Types are actually Moose::Meta::TypeConstraint objects
  • Stored in an interpreter-global registry mapping names to objects
@@ -3051,10 +2962,21 @@ has transaction_history => (
+

Specio

+ +
    +
  • My attempt to replace MooseX::Types and built-in types
  • +
  • Third-system effect?
  • +
  • Still alpha - needs some work
  • +
+
+ +

Recommendation

    -
  • Use MooseX::Types
  • +
  • Use MooseX::Types for now
  • +
  • Switch to Specio when it's ready?
  • Compile time error catching and automatic namespacing are huge wins
  • Docs from Moose::Util::TypeConstraints are 98% compatible with MooseX::Types anyway
  • A function exported by a type library works wherever a type name would
  • @@ -3369,7 +3291,6 @@ has history => ( use Moose; has _favorite_numbers => ( traits => [ 'Array' ], - is => 'bare', isa => 'ArrayRef[Int]', default => sub { [] }, init_arg => undef, @@ -3432,7 +3353,7 @@ has account => ( isa => 'BankAccount', handles => { receive_100 => - [ 'deposit', 100 ] + [ 'deposit', 100 ], give_100 => [ 'withdraw', 100 ] }, @@ -3536,6 +3457,10 @@ print Person->meta
+

Questions?

+
+ +

Exercises

# cd exercises
@@ -3566,7 +3491,7 @@ Iterate til this passes all its tests
  • Not comprehensive
  • -
  • 177 MooseX distributions on CPAN as of 09/21/2010
  • +
  • 188 MooseX distributions on CPAN as of 02/03/2011
  • Some of them are crap
@@ -3587,7 +3512,7 @@ Iterate til this passes all its tests

MooseX::Declare

use MooseX::Declare;
-use 5.10.0; # for say
+use 5.12.0; # for say
 
 class Person {
     has greeting =>
@@ -3606,7 +3531,7 @@ class Person {
     
  • Still experimental-ish, but seeing more and more use
  • Not a source filter!
  • Hooks into the Perl parser rather than filtering all your code
  • -
  • But not supported by PPI, perltidy, etc.
  • (yet?) +
  • But not supported by PPI, perltidy, etc. (yet?)
  • @@ -3779,7 +3704,7 @@ with HasCollection => { type => 'Int' };
  • mailing list - moose@perl.org
  • Slides and exercises are in Moose's git repo:
    - git://git.moose.perl.org/moose-presentations/moose.git
  • + git://git.moose.perl.org/moose-presentations.git @@ -3793,7 +3718,7 @@ with HasCollection => { type => 'Int' };