File Coverage

blib/lib/Syntax/Feature/Qwa.pm
Criterion Covered Total %
statement 56 56 100.0
branch n/a
condition n/a
subroutine 15 15 100.0
pod 0 1 0.0
total 71 72 98.6


line stmt bran cond sub pod time code
1             package Syntax::Feature::Qwa;
2              
3 4     4   114788 use 5.010;
  4         20  
  4         168  
4 4     4   22 use strict;
  4         8  
  4         246  
5              
6             BEGIN {
7 4     4   180 $Syntax::Feature::Qwa::AUTHORITY = 'cpan:TOBYINK';
8 4         92 $Syntax::Feature::Qwa::VERSION = '0.002';
9             }
10              
11 4     4   4621 use Devel::Declare 0.006007 ();
  4         29360  
  4         138  
12 4     4   4361 use Devel::Declare::Context::Simple 0 ();
  4         98520  
  4         142  
13 4     4   44 use B::Hooks::EndOfScope 0.09;
  4         263  
  4         28  
14 4     4   4777 use Sub::Install 0.925 qw( install_sub );
  4         7621  
  4         27  
15 4     4   3889 use namespace::clean 0;
  4         38416  
  4         31  
16            
17             my @NewOps = qw(qwa qwh qwk);
18             my %QuoteOp = (
19             qwa => q{ [%s] },
20             qwh => q{ +{%s} },
21             qwk => q{ do { my $i = 0; +{ map { $_=>++$i } %s } } },
22             );
23              
24             sub import
25             {
26 4     4   38 my ($class) = @_;
27 4         42 my $caller = caller(0);
28 4         13 @_ = ($class, 'into', $caller);
29 4         21 goto \&install;
30             }
31              
32             sub install
33             {
34 4     4 0 11 my ($class, %args) = @_;
35            
36 4         9 my $target = $args{into};
37 12         17 Devel::Declare->setup_for($target => {
38             map {
39 4         9 my $name = $_;
40             ($name => {
41             const => sub {
42 3     3   106 my $ctx = Devel::Declare::Context::Simple->new;
43 3         30 $ctx->init(@_);
44 3         46 return $class->_transform($name, $ctx);
45             },
46             })
47 12         107 } @NewOps
48             });
49 4         203 for my $name (@NewOps) {
50 12         638 install_sub {
51             into => $target,
52             as => $name,
53             code => $class->_run_callback($name),
54             }
55             }
56             on_scope_end {
57 4     4   285 namespace::clean->clean_subroutines($target, @NewOps);
58 4         173 };
59 4         168 return 1;
60             }
61              
62 3     3   120 sub _run_callback { sub($){shift} }
  12     12   85  
63            
64             sub _transform
65             {
66 3     3   7 my ($class, $name, $ctx) = @_;
67            
68 3         16 $ctx->skip_declarator;
69 3         99 my $length = Devel::Declare::toke_scan_str($ctx->offset);
70 3         48 my $string = Devel::Declare::get_lex_stuff;
71 3         9 Devel::Declare::clear_lex_stuff;
72 3         9 my $linestr = $ctx->get_linestr;
73 3         22 my $quoted = substr $linestr, $ctx->offset, $length;
74 3         16 my $spaced = '';
75 3         14 $quoted =~ m{^(\s*)}sm;
76 3         11 $spaced = $1;
77 3         26 my $new = sprintf $QuoteOp{$name}, join q[],
78             q[qw],
79             $spaced,
80             substr($quoted, length($spaced), 1),
81             $string,
82             substr($quoted, -1, 1);
83 3         12 substr($linestr, $ctx->offset, $length) = $new;
84 3         30 $ctx->set_linestr($linestr);
85             # my $s = $ctx->get_linestr;
86             # warn ">>> $s\n";
87 3         50 return 1;
88             }
89              
90             __PACKAGE__
91             __END__