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=501be5bc4a9ae1d7331f4f6335e42c40694974c3;hpb=f92e1df634926feb91baee61fc5356388656a0a7;p=gitmo%2Fmoose-presentations.git diff --git a/moose-class/slides/index.html b/moose-class/slides/index.html index 501be5b..1f2c059 100644 --- a/moose-class/slides/index.html +++ b/moose-class/slides/index.html @@ -71,7 +71,7 @@ img#me05 {top: 43px;left: 36px;} @@ -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
@@ -1155,8 +1155,8 @@ Person->can('extends');

Cleaning Up Moose Droppings

package Person;
-use namespace::autoclean;
 use Moose;
+use namespace::autoclean;
 
 ...
 
@@ -1234,8 +1234,6 @@ 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
@@ -1487,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

@@ -2422,9 +2392,9 @@ around run => sub {
  • alter parameters passed to the original method
  • alter the return value of the original method
  • not call the original method at all (or call a different method)
  • -
  • When using modifiers in a role, require the modified method
  • +
  • When using modifiers in a role, require the modified method
  • @@ -2630,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 { ... };
    @@ -2644,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(
    @@ -2660,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 ) },
    @@ -2675,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'
    @@ -2694,7 +2680,9 @@ subtype     'Color'
       
    package Person;
     
     my $posint =
    -    subtype as 'Int', where { $_ > 0 };
    +    subtype
    +        as 'Int',
    +        where { $_ > 0 };
     
     has size => (
         is  => 'ro',
    @@ -2852,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
    @@ -2974,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
    • @@ -3705,7 +3704,7 @@ with HasCollection => { type => 'Int' };
  • mailing list - moose@perl.org
  • Slides and exercises are in Moose's git repo:
    - git://jules.scsys.co.uk/gitmo/moose-presentations
  • + git://git.moose.perl.org/moose-presentations.git @@ -3719,7 +3718,7 @@ with HasCollection => { type => 'Int' };