I've moved on to a slightly more complex situation. The same phone call
record contains two different date fields. One is a string like 'Jan
21, 2010' (incidentally, this date is repeated for each record, as it
represents the end of the billing cycle), which I have successfully
converted with:
type 'My::Types::Date' => as 'Str' => where { defined $_ and $_ =~
/^\d{8}$/ };
coerce 'My::Types::Date' => from 'Str' => via { my $d = shift;
if ($d =~ /^([a-zA-Z]+) ([0-9]+).*(\d\d\d\d)$/) { ...this code works}
The second situation is complex. Instead of a full date with year,
month, and day of the call, I am given MM/DD. No year. I have logic
that 'figures out' the year based on the billing cycle end date (above)
which I put into &explodeDate. Being a big fan of perl's debugger, I've
identified that by the time the subroutine gets called, I have no
reference to either the date, or my object.
elsif ($d =~ \d\d\/\d\d) {$d = &explodeDate;}
sub explodeDate {
my $self = shift; # Nothing here...
}
Is this proper use of coercion, or is there a better way? If I'm on the
right track, how do I get access to my object within 'explodeDate'?
Steve
This method works great! I was very close to getting coercion to work,
but somehow my substitution returned '2' every time. Thanks all for the
help
Steve
Something along the lines of the following should work:
package Types;
use Moose::Util::TypeConstraints;
# note, need a type here, as otherwise coersions won't work if done as
a subtype of 'Str'
type "Types.pcr"
=> where { defined $_ and $_ =~ /^\d+$/ };
coerce "Types.pcr"
=> from "Str"
=> via { my $v = shift; $v =~ s/-//g; $v };
package UsageDetail;
use Moose;
# Note the 'coerce' flag and isa here
has pcr => (
is => "rw",
isa => "Types.pcr",
coerce => 1
);
package main;
my $dashful = UsageDetail->new( pcr => "9-8-7-6-5-4-3-2-1" );
my $dashless = UsageDetail->new( pcr => "123456789" );
print "Dashful: " . $dashful->pcr . "\n";
print "Dashless: " .$dashless->pcr . "\n"
-
The above gives:
Dashful: 987654321
Dashless: 123456789
On Fri, Feb 26, 2010 at 2:21 PM, Steve<st...@matsch.com> wrote:
I have been attempting to solve the following problem:
I have a class, 'UsageDetail' which takes a CSV phone call record and
inserts it into my database. One of the attributes, 'WirelessNumber' has
dashes in it, ie: '989-555-1212'. I don't want to store the dashes in the
db. I've rtfm over and over, but I haven't been successful in storing
without the dashes. I've tried subtypes, but that didn't work. BTW, the
values passed in to my constructor are not ONLY the 3-3-4 digit format,
sometimes the wireless number is 2 digits, and my WirelessNumber attr. isa
'Str' currently. Also, I can't modify the value passed into my constructor,
as it is used for many different tables. Any suggestions are greatly
appreciated.
Steve
No virus found in this incoming message.
Checked by AVG - www.avg.com
Version: 9.0.733 / Virus Database: 271.1.1/2711 - Release Date: 02/26/10
02:34:00
No virus found in this incoming message.
Checked by AVG - www.avg.com
Version: 9.0.733 / Virus Database: 271.1.1/2711 - Release Date: 02/26/10
02:34:00