JavaAccessors forPeopleWhoLikeJava
stevan [Wed, 9 Aug 2006 00:43:56 +0000 (00:43 +0000)]
lib/Moose/Policy/JavaAccessors.pm [new file with mode: 0644]
t/011_JavaAccessors_test.t [new file with mode: 0644]

diff --git a/lib/Moose/Policy/JavaAccessors.pm b/lib/Moose/Policy/JavaAccessors.pm
new file mode 100644 (file)
index 0000000..fea56dd
--- /dev/null
@@ -0,0 +1,36 @@
+
+package Moose::Policy::JavaAccessors;
+
+use constant attribute_metaclass => 'Moose::Policy::JavaAccessors::Attribute';
+
+package Moose::Policy::JavaAccessors::Attribute;
+use Moose;
+
+extends 'Moose::Meta::Attribute';
+
+before '_process_options' => sub {
+    my ($class, $name, $options) = @_;
+    # NOTE:
+    # If is has been specified, and 
+    # we don't have a reader or writer
+    # Of couse this is an odd case, but
+    # we better test for it anyway.
+    if (exists $options->{is} && !(exists $options->{reader} || exists $options->{writer})) {
+        if ($options->{is} eq 'ro') {
+            $options->{reader} = 'get' . ucfirst($name);
+        }
+        elsif ($options->{is} eq 'rw') {
+            $options->{reader} = 'get' . ucfirst($name);
+            $options->{writer} = 'set' . ucfirst($name);
+        }
+        delete $options->{is};
+    }
+};
+
+1;
+
+__END__
+
+=pod
+
+=cut
diff --git a/t/011_JavaAccessors_test.t b/t/011_JavaAccessors_test.t
new file mode 100644 (file)
index 0000000..93540c9
--- /dev/null
@@ -0,0 +1,38 @@
+#!/usr/bin/perl
+
+use strict;
+use warnings;
+
+use Test::More 'no_plan';
+
+BEGIN {
+    use_ok('Moose::Policy');
+}
+
+{
+    package Foo;
+
+    use Moose::Policy 'Moose::Policy::JavaAccessors';
+    use Moose;
+
+    has 'bar' => (is => 'rw', default => 'Foo::bar');
+    has 'baz' => (is => 'ro', default => 'Foo::baz');
+}
+
+isa_ok(Foo->meta, 'Moose::Meta::Class');
+is(Foo->meta->attribute_metaclass, 'Moose::Policy::JavaAccessors::Attribute', '... got our custom attr metaclass');
+
+isa_ok(Foo->meta->get_attribute('bar'), 'Moose::Policy::JavaAccessors::Attribute');
+
+my $foo = Foo->new;
+isa_ok($foo, 'Foo');
+
+can_ok($foo, 'getBar');
+can_ok($foo, 'setBar');
+
+can_ok($foo, 'getBaz');
+ok(! $foo->can('setBaz'), 'without setter');
+
+is($foo->getBar, 'Foo::bar', '... got the right default value');
+is($foo->getBaz, 'Foo::baz', '... got the right default value');
+