Disallow attributes that are not valid perl
Rafael Garcia-Suarez [Mon, 26 Nov 2007 12:32:00 +0000 (12:32 +0000)]
(patch by Damian)

p4raw-id: //depot/perl@32496

lib/Attribute/Handlers.pm
lib/Attribute/Handlers/t/data_convert.t

index aa4eada..27b60af 100644 (file)
@@ -190,9 +190,14 @@ sub _apply_handler_AH_ {
        my $sym = findsym($pkg, $ref);
        $sym ||= $type eq 'CODE' ? 'ANON' : 'LEXICAL';
        no warnings;
-       my $evaled = !$raw && eval("package $pkg; no warnings; no strict;
-                                   local \$SIG{__WARN__}=sub{die}; [$data]");
-       $data = $evaled || [$data];
+       if (!$raw) {
+           $data = !$raw && eval("package $pkg; no warnings; no strict;
+                                  local \$SIG{__WARN__}=sub{die}; [$data]");
+           if (my $error = $@) {
+               $error =~ s{\s+ at \s+ \(eval \s+ \S+\) \s+ line \s+ \S+}{}x;
+               die "Bad data for $attr attribute: $error\n";
+           }
+       }
        $pkg->$handler($sym,
                       (ref $sym eq 'GLOB' ? *{$sym}{ref $ref}||$ref : $ref),
                       $attr,
@@ -811,6 +816,11 @@ An attribute handler was specified with an C<:ATTR(I<ref_type>)>, but the
 type of referent it was defined to handle wasn't one of the five permitted:
 C<SCALAR>, C<ARRAY>, C<HASH>, C<CODE>, or C<ANY>.
 
+=item C<Bad data for %s attribute: %s>
+
+The data specified as part of the named attribute wasn't valid Perl.
+The error message indicates why it didn't compile.
+
 =item C<Attribute handler %s doesn't handle %s attributes>
 
 A handler for attributes of the specified name I<was> defined, but not
index b0c37c3..14788c1 100644 (file)
@@ -41,14 +41,14 @@ sub test5 :Loud(till,ears,are,bleeding) {
     [qw(till ears are bleeding)]
 }
 
-sub test6 :Loud(my,ears,are,bleeding) {
-    'my,ears,are,bleeding';
+sub test6 :Loud("turn it up to 11, man!") {
+    'turn it up to 11, man!';
 }
 
-sub test7 :Loud(qw/my ears are bleeding) {
-    'qw/my ears are bleeding'; #'
-}
+::ok !defined eval q{
+    sub test7 :Loud(my,ears,are,bleeding) {}
+}, 'test7';
 
-sub test8 :Loud("turn it up to 11, man!") {
-    'turn it up to 11, man!';
-}
+::ok !defined eval q{
+    sub test8 :Loud(qw/my ears are bleeding) {}
+}, 'test8';