From: Shawn M Moore Date: Sat, 16 May 2009 05:29:12 +0000 (-0400) Subject: Move notbenh's talk X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=c49a20acc14f343812102f6e9dbbf3275a2042e4;p=gitmo%2Fmoose-website.git Move notbenh's talk --- diff --git a/hosted-presentations/2008/notbenh-PDX.xul b/hosted-presentations/2008/notbenh-PDX.xul new file mode 100644 index 0000000..8ad839a --- /dev/null +++ b/hosted-presentations/2008/notbenh-PDX.xul @@ -0,0 +1,4058 @@ + + + + + + + + + + + + +TITLE::Moose in the wild +GLOBAL-SIZE::9 +riding +wild +Moose + +---- +%%%%EM:Moose%%%%? + +---- +hype: + +---- +'postmodern' +object +system +for Perl 5 + + +---- +reality: + +---- +'academically' +correct +p5 OO + + +---- +so what? + + +---- +my concept +of OO was +~off~ + + +---- +package as a +collection of subs +with access to +common data + + +---- +moose changed +all that for me + + +---- +build +objects +by attributes + + + +---- +different? +how? + + + +---- +%%%%PRE: +use strict; +use warnings; +%%%% +included +by default + + +---- +%%%%PRE: +sub new {} +%%%% +built-in + + +---- +free +accessors + + +---- +types + + +---- +roles + + +---- +... ehh, not convinced +I'd have to see it in action. + + +---- +what does Moose look like? + + +---- +let's define +a simple +example: + + +---- +describe +a moose +(the animal) + +---- +moose +have +names + +---- +if no name +is given +default to +'Bullwinkle' + +---- +%%%%PRE: +my $bullwinkle = + Animal::Moose->new; +print $bullwinkle->name; + # 'Bullwinkle' + +my $skippy = + Animal::Moose->new( name => 'Skippy' ) +print $skippy->name; + # 'Skippy' +%%%% + + +---- +pre-Moose: +%%%%PRE: +package Animal::Moose; +use strict; +use warnings; + +sub new { + my ($class, %opts) = @_; + my $self = { + name => $opts{name} || 'Bullwinkle', + }; + return bless $self, $class; +} + +sub name { + my ($self, $new_name) = @_; + if ( defined $new_name ) { + $self->{name} = $new_name; + } + return $self->{name}; +} +1; +%%%% + + +---- +Moose: +%%%%PRE: +package Animal::Moose; +use Moose; + +has name => ( + is => 'rw', + isa => 'Str', + default => 'Bullwinkle', +); +1; +%%%% + + +---- +what is +this 'has'? + + +---- +all about +attributes + +---- +standard format: +%%%%PRE: +has "attribute name" => ( + #attribute definition +); +%%%% + + +---- +access level +%%%%PRE: +is => 'rw', +is => 'ro', +%%%% + + +---- +specify type +%%%%PRE: +isa => 'Str', +isa => 'Int', +isa => 'ArrayRef', +isa => 'HashRef', +isa => 'CGI::Simple', +%%%% + + +---- +need a default? +%%%%PRE: +default => 'string', +default => 12, +default => sub{ [] }, +default => sub{ {} }, +%%%% + + +---- +required attribute +%%%%PRE: +required => 1, +%%%% + + +---- +'optional' attribute +%%%%PRE: +lazy => 1, +%%%% + + +---- +%%%% there's more | http://search.cpan.org/~stevan/Moose-0.38/lib/Moose.pm %%%% + + +---- +why types +are cool? + +---- +built-in +assertions + +---- +advantage? +they make my code die! + + +---- +my options? +%%%%PRE: + Any + Item + Bool + Maybe[`a] + Undef + Defined + Value + Num + Int + Str + ClassName + Ref + ScalarRef + ArrayRef[`a] + HashRef[`a] + CodeRef + RegexpRef + GlobRef + FileHandle + Object + Role +%%%% +%%%% more info on types | http://search.cpan.org/~stevan/Moose-0.38/lib/Moose/Util/TypeConstraints.pm %%%% + + +---- +... they're missing one ... + + +---- +... so make your own ... + + +---- +%%%%PRE: +package PowellsData::Types::Web; +use Moose::Role; +use Moose::Util::TypeConstraints; + +type 'WebObject' + => where { + ref($_) =~ + m/^(Apache2::Request|CGI::Simple)$/ + } + => message { + sprintf( + '(%s) needs to be an Apache2::Request + object or a CGI::Simple object and + it is a %s', + $_, + ref($_) + ) } + ; +%%%% + +---- +... you can also +extend types +via subtypes. + +---- +%%%%PRE: +package PowellsData::Types::SQL; +use Moose::Role; +use Moose::Util::TypeConstraints; + +subtype 'SQL_Select' + => as 'Str' + => where { + $_ =~ m/\bSELECT\b.+\bFROM\b/i + }; + +subtype 'SQL_Insert' + => as 'Str' + => where { + $_ =~ + m/\bINSERT\b.+(?:\bINTO\b)?.+\b(?:VALUES|SET|SELECT)\b/i + }; + +subtype 'SQL_Update' + => as 'Str' + => where { + $_ =~ m/\bUPDATE\b.+\bSET\b/i + }; + +subtype 'SQL_Delete' + => as 'Str' + => where { + $_ =~ m/\bDELETE\b.+\bFROM\b/i }; + +subtype 'SQL' + => as q{SQL_Select|SQL_Insert|SQL_Update|SQL_Delete} ; +%%%% + + +---- +so roles? + +---- +how to eat a moose + +---- +... small pieces + +---- +roles ~ includes + + +---- +usage (theory): +1) abstract the common + + +---- +example: +%%%%PRE: +package PowellsData::Setup::Database; +use Moose::Role; +use DBHost; + +sub d; +has d => ( is => 'rw', + isa => 'DBI::db', + required => 1, + default => sub{ my $d = _dbiconnect('current'); + $d->{mysql_auto_reconnect} = 1; + $d->do("SET NAMES utf8"); + return $d; + } + ); + + + +1; +%%%% + + +---- +now in our code just say: +%%%%PRE: +package My::Bad::DB::Example; +use Moose; + +with q{PowellsData::Setup::Database}; + +sub run_query { + my ($self, $query) = @_; + return $self->d->do($query); +} +%%%% + + +---- +usage (theory): +2) big idea as small chunks + + +---- +%%%%EM:pro:%%%% +write only +what you need + + +---- +%%%%PRE: +package PowellsData::Setup::Database; +use Moose::Role; +use DBHost; + +sub d; +has d => ( is => 'rw', + isa => 'DBI::db', + required => 1, + default => sub{ my $d = _dbiconnect('current'); + $d->{mysql_auto_reconnect} = 1; + $d->do("SET NAMES utf8"); + return $d; + } + ); + + + +1; +%%%% + + +---- +%%%%EM:con:%%%% +lost context + + +---- +%%%%PRE: +with q{PowellsData::Setup::Database}; +%%%% +vs. +%%%%PRE: +use Some::Other::Magic::DB::Manager q{d}; +%%%% + + +---- +%%%%EM:pro:%%%% +group logical actions + + +---- +%%%%PRE: +package Search::Runtime::FPSearch::Section; +use Moose; +use Carp::Assert::More; + +with qw{ + Search::Runtime::Common + PowellsData::Setup::Database + PowellsData::Tools::String +}; + + +sub find { + my ( $self, $needle) = @_; + if ( $self->_has_valid_value($needle) ) { + my $needles = $self->array_of_words( lc( $needle ) ); + my $query = _query($needles); + my $r = $self->d->selectall_arrayref($query, { Slice => {} }, @$needles, @$need +les); + my $score_limit = scalar( @$needles); + + if ( scalar( @$r ) > 0 ) { + #we have resutls + my $out = []; + foreach my $s ( @$r ) { + if ( $s->{score} >= $score_limit ) { + push @$out, {$s->{name} => $s->{link}}; + } + } + return $out; + } + } + return undef; +} +sub _query { + my ($needles) = @_; + assert_listref($needles); + return sprintf( q{ + ( + SELECT DISTINCT X.MAJORSec as name, + CONCAT( 'psection/',X.HTML ) AS link, + X.score, + X.type + FROM ( + SELECT C.MAJORSec, + C.MINORSec, + count(SWC.word_id) AS score, + SWC.type, + C.HTML, + C.sectionkey + FROM Sections.section_word_category SWC + JOIN Sections.category C + ON (SWC.category_id = C.id) + JOIN Sections.section_words SW + ON (SWC.word_id = SW.id) + WHERE SW.word IN (%s) + AND C.MAJORSec NOT LIKE '%%Reader eBook%%' + AND C.MAJORSec NOT LIKE '%%sale%%' + AND C.MAJORSec != '$7 or Less' + AND C.MAJORSec != 'At the Movies' + AND C.MAJORSec != 'New Arrivals' + AND C.MAJORSec != 'Coming Soon!' + AND SWC.type = 'major' + GROUP BY C.id + ORDER BY score DESC + ) AS X + ) + UNION + ( + SELECT CONCAT( Y.MAJORSec, ' - ', Y.MINORSec ) as name, + CONCAT( 'subsecti on/', Y.sectionkey, '.html' ) AS link, + Y.score, + Y.type + FROM ( + SELECT C.MAJORSec, + C.MINORSec, + count(SWC.word_id) AS score, + SWC.type, + C.HTML, + C.sectionkey + FROM Sections.section_word_category SWC + JOIN Sections.category C + ON (SWC.category_id = C.id) + JOIN Sections.section_words SW + ON (SWC.word_id = SW.id) + WHERE SW.word IN (%s) + AND C.MAJORSec NOT LIKE '%%Reader eBook%%' + AND C.MAJORSec NOT LIKE '%%sale%%' + AND C.MAJORSec != '$7 or Less' + AND C.MAJORSec != 'At the Movies' + AND C.MAJORSec != 'New Arrivals' + AND C.MAJORSec != 'Coming Soon!' + AND SWC.type = 'minor' + GROUP BY C.id + ORDER BY score DESC + ) AS Y + + ) + ORDER BY type = 'major' DESC , score DESC + }, + _soq(@$needles), + _soq(@$needles), + ); +} + + +1; +%%%% + + +---- +%%%%EM:con:%%%% +things get +messy fast + + +---- +%%%%PRE: +benh@noodleboy:~/svn/lib_common/dev/Search$ tree . +. +|-- CompleteResults.pm +|-- CompleteResults_distance.pm +|-- Core +| |-- Actions +| | |-- Pages.pm +| | `-- Results.pm +| |-- Actions.pm +| |-- CompleteResults +| | |-- Common.pm +| | |-- LimitedQuery.pm +| | |-- OLDQuery.pm +| | |-- OrderBy.pm +| | |-- Query.pm +| | `-- Restrictions.pm +| |-- CompleteResults.pm +| `-- Shortcut.pm +|-- Core.pm +|-- DB +| |-- Current +| | |-- NoStem.pm +| | |-- PublisherKw.pm +| | |-- PublisherKwOld.pm +| | |-- Search.pm +| | |-- SearchCacheClasses.pm +| | |-- SearchCacheCounter.pm +| | |-- SearchCacheMeta.pm +| | |-- SearchCacheParams.pm +| | |-- SearchCacheResults.pm +| | |-- SearchCacheSections.pm +| | |-- SearchKw.pm +| | |-- SearchKwOld.pm +| | |-- SearchOld.pm +| | |-- SearchTitle.pm +| | |-- SearchTitleOld.pm +| | |-- SectionsKw.pm +| | |-- SectionsKwOld.pm +| | |-- Stock.pm +| | |-- StockOld.pm +| | |-- ZqDb.pm +| | |-- ZqKw.pm +| | `-- ZqTitle.pm +| |-- Current.pm +| `-- Profiler.pm +|-- DB.pm +|-- Debug +| `-- Stopwatch.pm +|-- Debug.pm +|-- Runtime +| |-- Attr.pm +| |-- Common.pm +| |-- Cookies.pm +| |-- Defaults.pm +| |-- FPSearch +| | |-- Author.pm +| | |-- Help.pm +| | `-- Section.pm +| |-- FPSearch.pm +| |-- Internal.pm +| |-- Lookup.pm +| |-- Promote.pm +| |-- Spelling.pm +| |-- Tracking.pm +| |-- Translate.pm +| |-- Values +| | |-- Clean.pm +| | `-- Organize.pm +| |-- Values.pm +| `-- Websearch.pm +|-- Runtime.pm +|-- Test +| |-- pound.pl +| `-- runsearch_lite.pl +|-- Test.pm +`-- playground.pl +%%%%} + + +---- +%%%%EM:pro:%%%% +delegate code + + +---- +%%%%EM:con:%%%% +moose roles +are moose only + + +---- +there's a lot more to roles +%%%% CookBook Example | http://search.cpan.org/~stevan/Moose-0.38/lib/Moose/Cookbook/Recipe6.pod %%%% + +---- + + +---- +kinda-FAQ + + +---- +how to extend a Moose? + + +---- +It's easy: +%%%%PRE: +extends q{object}; +%%%% +vs +%%%%PRE: +use base q{object}; +%%%%% + + +---- +with out new, +how can I +have something +run on creation? + + +---- +%%%%PRE: +sub BUILD { + #... code to be run on create +}; +%%%% + +---- +wow free lunch? +cost? + + + +---- + + + + + +---- +thanks to Stevan Little +and the whole moose crew #moose + + +---- +Thanks for putting up with my yammering + +---- +More info: +- %%%% CPAN | http://search.cpan.org/~stevan/Moose-0.38/ %%%% +- %%%% Cookbook | http://search.cpan.org/~stevan/Moose-0.38/lib/Moose/Cookbook.pod %%%% +- %%%% Moose Site | http://www.iinteractive.com/moose/ %%%% +- IRC: irc.perl.org #moose + +---- +-end- + + + + + + + image { + display: none !important; +} +.dropmarker-button > label { + width: 0 !important; + overflow: hidden !important; +} + +#pages-list-button { + min-width: 0; +} +#pages-list-button > label { + display: none; +} +#pages-list-button menupopup { + max-width: 20em; +} +#pages-list-button menuitem image { + max-width: 32px; + max-height: 32px; +} + + + + +#headerBox, +#footerBox { + margin: 1em; +} + + +#indicatorBar, +#indicatorBar hbox, +#nextPage { + -moz-box-align: center; + -moz-box-pack: center; +} + + + +.monta-label { + padding: 0.05em; + margin: -0.05em; +} +.monta-label[monta-hidden="true"], +.monta-label[monta-hidden="progress"] { + background-position: -100px 0; +} +.monta-label[monta-hidden="progress"] { + background-color: transparent; +} +.monta-label[monta-hidden="false"] { + background: transparent !important; +} + + + +#canvas row description { + border: 1px solid transparent; + white-space: pre; +} + + + +#canvasToolbar { + position: relative; + z-index: 1000; +} + +#sourceEditField, +#pageEditFields textbox { + font-family: -moz-fixed !important; + font-size: medium; +} + +#pageEditFields { + overflow: auto; +} +#pageEditFields textbox { + height: 6em; +} + + + + +#stroke-canvas-box { + position: relative; + display: block; +} +#stroke-canvas-box, +#stroke-canvas-box *|canvas { + line-height: 1; +} + +.stroke-dot { + position: absolute; + display: block; + z-index: 100; +} + + + +.monta-label { + background-image: url(""); +} + +]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/index.html b/index.html index 12140de..acc2c2f 100644 --- a/index.html +++ b/index.html @@ -132,7 +132,7 @@ Try it today!