line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Dist::Zilla::Plugin::AlienBase::Doc 0.32 { |
2
|
|
|
|
|
|
|
|
3
|
2
|
|
|
2
|
|
368403
|
use 5.014; |
|
2
|
|
|
|
|
16
|
|
4
|
2
|
|
|
2
|
|
606
|
use Moose; |
|
2
|
|
|
|
|
460611
|
|
|
2
|
|
|
|
|
16
|
|
5
|
2
|
|
|
2
|
|
14659
|
use Carp (); |
|
2
|
|
|
|
|
6
|
|
|
2
|
|
|
|
|
133
|
|
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
# ABSTRACT: Generate boilerplate documentation for Alien::Base subclass |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
with 'Dist::Zilla::Role::FileMunger'; |
11
|
|
|
|
|
|
|
with 'Dist::Zilla::Role::FileFinderUser' => { default_finders => [ ':InstallModules', ':ExecFiles' ] }; |
12
|
|
|
|
|
|
|
with 'Dist::Zilla::Role::PPI'; |
13
|
|
|
|
|
|
|
with 'Dist::Zilla::Role::TextTemplate'; |
14
|
|
|
|
|
|
|
|
15
|
2
|
|
|
2
|
|
1229
|
use Sub::Exporter::ForMethods 'method_installer'; |
|
2
|
|
|
|
|
2090
|
|
|
2
|
|
|
|
|
10
|
|
16
|
|
|
|
|
|
|
use Data::Section 0.004 # fixed header_re |
17
|
2
|
|
|
2
|
|
1560
|
{ installer => method_installer }, '-setup'; |
|
2
|
|
|
|
|
4094
|
|
|
2
|
|
|
|
|
14
|
|
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
|
20
|
|
|
|
|
|
|
has class_name => ( |
21
|
|
|
|
|
|
|
is => 'ro', |
22
|
|
|
|
|
|
|
isa => 'Str', |
23
|
|
|
|
|
|
|
lazy => 1, |
24
|
|
|
|
|
|
|
default => sub { |
25
|
|
|
|
|
|
|
my($self) = @_; |
26
|
|
|
|
|
|
|
my $name = $self->zilla->name; |
27
|
|
|
|
|
|
|
$name =~ s{-}{::}; |
28
|
|
|
|
|
|
|
$name; |
29
|
|
|
|
|
|
|
}, |
30
|
|
|
|
|
|
|
); |
31
|
|
|
|
|
|
|
|
32
|
|
|
|
|
|
|
|
33
|
|
|
|
|
|
|
has min_version => ( |
34
|
|
|
|
|
|
|
is => 'ro', |
35
|
|
|
|
|
|
|
isa => 'Str', |
36
|
|
|
|
|
|
|
default => '0', |
37
|
|
|
|
|
|
|
); |
38
|
|
|
|
|
|
|
|
39
|
|
|
|
|
|
|
|
40
|
|
|
|
|
|
|
has type => ( |
41
|
|
|
|
|
|
|
is => 'ro', |
42
|
|
|
|
|
|
|
isa => 'ArrayRef[Str]', |
43
|
|
|
|
|
|
|
default => sub { [ 'library' ] }, |
44
|
|
|
|
|
|
|
); |
45
|
|
|
|
|
|
|
|
46
|
|
|
|
|
|
|
|
47
|
|
|
|
|
|
|
has name => ( |
48
|
|
|
|
|
|
|
is => 'ro', |
49
|
|
|
|
|
|
|
isa => 'Str', |
50
|
|
|
|
|
|
|
required => 1, |
51
|
|
|
|
|
|
|
); |
52
|
|
|
|
|
|
|
|
53
|
|
|
|
|
|
|
|
54
|
|
|
|
|
|
|
has see_also => ( |
55
|
|
|
|
|
|
|
is => 'ro', |
56
|
|
|
|
|
|
|
isa => 'ArrayRef[Str]', |
57
|
|
|
|
|
|
|
default => sub { [ 'Alien', 'Alien::Base', 'Alien::Build::Manual::AlienUser' ] }, |
58
|
|
|
|
|
|
|
); |
59
|
|
|
|
|
|
|
|
60
|
|
|
|
|
|
|
around mvp_multivalue_args => sub { |
61
|
|
|
|
|
|
|
my($orig, $self) = @_; |
62
|
|
|
|
|
|
|
($self->$orig, 'type', 'see_also'); |
63
|
|
|
|
|
|
|
}; |
64
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
sub render_synopsis |
66
|
|
|
|
|
|
|
{ |
67
|
4
|
|
|
4
|
0
|
62255
|
my($self) = @_; |
68
|
|
|
|
|
|
|
|
69
|
4
|
|
|
|
|
11
|
my $str = "\n=head1 SYNOPSIS"; |
70
|
|
|
|
|
|
|
|
71
|
4
|
|
|
|
|
6
|
foreach my $type (@{ $self->type }) |
|
4
|
|
|
|
|
154
|
|
72
|
|
|
|
|
|
|
{ |
73
|
6
|
|
|
|
|
2451
|
my $template; |
74
|
|
|
|
|
|
|
|
75
|
6
|
100
|
|
|
|
54
|
if($type eq 'library') |
|
|
100
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
76
|
|
|
|
|
|
|
{ |
77
|
2
|
|
|
|
|
14
|
$template = $self->section_data('__SYNOPSIS_LIBRARY__') |
78
|
|
|
|
|
|
|
} |
79
|
|
|
|
|
|
|
elsif($type eq 'tool') |
80
|
|
|
|
|
|
|
{ |
81
|
2
|
|
|
|
|
54
|
$template = $self->section_data('__SYNOPSIS_TOOL__') |
82
|
|
|
|
|
|
|
} |
83
|
|
|
|
|
|
|
elsif($type eq 'ffi') |
84
|
|
|
|
|
|
|
{ |
85
|
2
|
|
|
|
|
9
|
$template = $self->section_data('__SYNOPSIS_FFI__') |
86
|
|
|
|
|
|
|
} |
87
|
|
|
|
|
|
|
else |
88
|
|
|
|
|
|
|
{ |
89
|
0
|
|
|
|
|
0
|
Carp::croak("unknown type: $type"); |
90
|
|
|
|
|
|
|
} |
91
|
|
|
|
|
|
|
|
92
|
6
|
|
|
|
|
3437
|
$template = $$template; |
93
|
6
|
|
|
|
|
228
|
$template =~ s{\s*$}{}; |
94
|
|
|
|
|
|
|
|
95
|
6
|
|
|
|
|
19
|
$str .= "\n\n"; |
96
|
6
|
50
|
|
|
|
244
|
$str .= $self->fill_in_string($template, { |
97
|
|
|
|
|
|
|
class => $self->class_name, |
98
|
|
|
|
|
|
|
name => $self->name, |
99
|
|
|
|
|
|
|
version => $self->min_version, |
100
|
0
|
|
|
|
|
0
|
optversion => $self->min_version ? " @{[ $self->min_version ]}" : '', |
101
|
|
|
|
|
|
|
}); |
102
|
|
|
|
|
|
|
} |
103
|
|
|
|
|
|
|
|
104
|
4
|
|
|
|
|
4820
|
$str .= "\n\n=cut\n\n"; |
105
|
|
|
|
|
|
|
|
106
|
4
|
|
|
|
|
23
|
$str; |
107
|
|
|
|
|
|
|
} |
108
|
|
|
|
|
|
|
|
109
|
|
|
|
|
|
|
sub render_description |
110
|
|
|
|
|
|
|
{ |
111
|
2
|
|
|
2
|
0
|
2092
|
my($self) = @_; |
112
|
|
|
|
|
|
|
|
113
|
2
|
|
|
|
|
7
|
my $template = $self->section_data('__DESCRIPTION__'); |
114
|
|
|
|
|
|
|
|
115
|
2
|
|
|
|
|
99
|
$template = $$template; |
116
|
2
|
|
|
|
|
100
|
$template =~ s{\s*$}{}; |
117
|
|
|
|
|
|
|
|
118
|
2
|
|
|
|
|
6
|
my $str = "\n"; |
119
|
|
|
|
|
|
|
|
120
|
2
|
50
|
|
|
|
85
|
$str .= $self->fill_in_string($template, { |
121
|
|
|
|
|
|
|
class => $self->class_name, |
122
|
|
|
|
|
|
|
name => $self->name, |
123
|
|
|
|
|
|
|
version => $self->min_version, |
124
|
0
|
|
|
|
|
0
|
optversion => $self->min_version ? " @{[ $self->min_version ]}" : '', |
125
|
|
|
|
|
|
|
}); |
126
|
|
|
|
|
|
|
|
127
|
2
|
|
|
|
|
1808
|
$str .= "\n\n"; |
128
|
|
|
|
|
|
|
|
129
|
2
|
|
|
|
|
12
|
$str; |
130
|
|
|
|
|
|
|
} |
131
|
|
|
|
|
|
|
|
132
|
|
|
|
|
|
|
sub render_see_also |
133
|
|
|
|
|
|
|
{ |
134
|
2
|
|
|
2
|
0
|
13
|
my($self) = @_; |
135
|
|
|
|
|
|
|
|
136
|
2
|
|
|
|
|
5
|
my $str = "\n=head1 SEE ALSO\n\n"; |
137
|
2
|
|
|
|
|
5
|
$str .= join ', ', map { "L<$_>" } @{ $self->see_also }; |
|
5
|
|
|
|
|
21
|
|
|
2
|
|
|
|
|
74
|
|
138
|
2
|
|
|
|
|
9
|
$str .= "\n\n=cut\n\n"; |
139
|
|
|
|
|
|
|
|
140
|
2
|
|
|
|
|
8
|
$str; |
141
|
|
|
|
|
|
|
} |
142
|
|
|
|
|
|
|
|
143
|
|
|
|
|
|
|
sub munge_files |
144
|
|
|
|
|
|
|
{ |
145
|
1
|
|
|
1
|
0
|
12567
|
my($self) = @_; |
146
|
1
|
|
|
|
|
3
|
$self->munge_file($_) for @{ $self->found_files }; |
|
1
|
|
|
|
|
7
|
|
147
|
1
|
|
|
|
|
271
|
return; |
148
|
|
|
|
|
|
|
} |
149
|
|
|
|
|
|
|
|
150
|
|
|
|
|
|
|
sub munge_file |
151
|
|
|
|
|
|
|
{ |
152
|
1
|
|
|
1
|
0
|
1677
|
my($self, $file) = @_; |
153
|
|
|
|
|
|
|
|
154
|
1
|
|
|
|
|
15
|
my $doc = $self->ppi_document_for_file($file); |
155
|
|
|
|
|
|
|
|
156
|
1
|
50
|
|
|
|
122490
|
return unless defined $doc; |
157
|
|
|
|
|
|
|
|
158
|
1
|
|
|
|
|
8
|
my $comments = $doc->find('PPI::Token::Comment'); |
159
|
1
|
|
|
|
|
1122
|
my $modified = 0; |
160
|
|
|
|
|
|
|
|
161
|
1
|
50
|
|
|
|
3
|
foreach my $comment (@{ $comments || [] }) |
|
1
|
|
|
|
|
6
|
|
162
|
|
|
|
|
|
|
{ |
163
|
3
|
50
|
|
|
|
13
|
if($comment =~ /^\s*##?\s*ALIEN (SYNOPSIS|DESCRIPTION|SEE ALSO)\s*$/) |
164
|
|
|
|
|
|
|
{ |
165
|
3
|
|
|
|
|
54
|
my $type = $1; |
166
|
3
|
100
|
|
|
|
16
|
if($type eq 'SYNOPSIS') |
|
|
100
|
|
|
|
|
|
|
|
50
|
|
|
|
|
|
167
|
|
|
|
|
|
|
{ |
168
|
1
|
|
|
|
|
7
|
$comment->set_content($self->render_synopsis); |
169
|
|
|
|
|
|
|
} |
170
|
|
|
|
|
|
|
elsif($type eq 'DESCRIPTION') |
171
|
|
|
|
|
|
|
{ |
172
|
1
|
|
|
|
|
5
|
$comment->set_content($self->render_description); |
173
|
|
|
|
|
|
|
} |
174
|
|
|
|
|
|
|
elsif($type eq 'SEE ALSO') |
175
|
|
|
|
|
|
|
{ |
176
|
1
|
|
|
|
|
7
|
$comment->set_content($self->render_see_also); |
177
|
|
|
|
|
|
|
} |
178
|
3
|
|
|
|
|
14
|
$modified = 1; |
179
|
|
|
|
|
|
|
} |
180
|
|
|
|
|
|
|
} |
181
|
|
|
|
|
|
|
|
182
|
1
|
50
|
|
|
|
5
|
if($modified) |
183
|
|
|
|
|
|
|
{ |
184
|
1
|
|
|
|
|
10
|
$self->save_ppi_document_to_file( $doc, $file); |
185
|
1
|
|
|
|
|
1817
|
$self->log_debug([ 'adding ALIEN documentation to %s', $file->name ]); |
186
|
|
|
|
|
|
|
} |
187
|
|
|
|
|
|
|
|
188
|
1
|
|
|
|
|
180
|
return; |
189
|
|
|
|
|
|
|
} |
190
|
|
|
|
|
|
|
|
191
|
|
|
|
|
|
|
__PACKAGE__->meta->make_immutable; |
192
|
|
|
|
|
|
|
|
193
|
|
|
|
|
|
|
} |
194
|
|
|
|
|
|
|
|
195
|
|
|
|
|
|
|
package Dist::Zilla::Plugin::AlienBase::Doc; |
196
|
|
|
|
|
|
|
|
197
|
|
|
|
|
|
|
1; |
198
|
|
|
|
|
|
|
|
199
|
|
|
|
|
|
|
=pod |
200
|
|
|
|
|
|
|
|
201
|
|
|
|
|
|
|
=encoding UTF-8 |
202
|
|
|
|
|
|
|
|
203
|
|
|
|
|
|
|
=head1 NAME |
204
|
|
|
|
|
|
|
|
205
|
|
|
|
|
|
|
Dist::Zilla::Plugin::AlienBase::Doc - Generate boilerplate documentation for Alien::Base subclass |
206
|
|
|
|
|
|
|
|
207
|
|
|
|
|
|
|
=head1 VERSION |
208
|
|
|
|
|
|
|
|
209
|
|
|
|
|
|
|
version 0.32 |
210
|
|
|
|
|
|
|
|
211
|
|
|
|
|
|
|
=head1 SYNOPSIS |
212
|
|
|
|
|
|
|
|
213
|
|
|
|
|
|
|
In your dist.ini: |
214
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
[AlienBase::Doc] |
216
|
|
|
|
|
|
|
name = libfoo |
217
|
|
|
|
|
|
|
|
218
|
|
|
|
|
|
|
In your Alien/Foo.pm: |
219
|
|
|
|
|
|
|
|
220
|
|
|
|
|
|
|
package Alien::Foo; |
221
|
|
|
|
|
|
|
|
222
|
|
|
|
|
|
|
use strict; |
223
|
|
|
|
|
|
|
use warnings; |
224
|
|
|
|
|
|
|
use base qw( Alien::Base ); |
225
|
|
|
|
|
|
|
|
226
|
|
|
|
|
|
|
# ALIEN SYNOPSIS |
227
|
|
|
|
|
|
|
# ALIEN DESCRIPTION |
228
|
|
|
|
|
|
|
# ALIEN SEE ALSO |
229
|
|
|
|
|
|
|
|
230
|
|
|
|
|
|
|
1; |
231
|
|
|
|
|
|
|
|
232
|
|
|
|
|
|
|
=head1 DESCRIPTION |
233
|
|
|
|
|
|
|
|
234
|
|
|
|
|
|
|
This plugin generates some boiler plat documentation for your |
235
|
|
|
|
|
|
|
L<Alien::Base> based L<Alien> module. It will find the special codes |
236
|
|
|
|
|
|
|
C<ALIEN SYNOPSIS>, C<ALIEN DESCRIPTION>, and C<ALIEN SEE ALSO> and |
237
|
|
|
|
|
|
|
replace them with the appropriate boilerplate POD documentation for how |
238
|
|
|
|
|
|
|
to use the module. The generated synopsis and see also sections are |
239
|
|
|
|
|
|
|
probably good enough as is. The description is a little more basic, and |
240
|
|
|
|
|
|
|
you may want to write a more detailed description yourself. It is, at |
241
|
|
|
|
|
|
|
least, better than nothing though! |
242
|
|
|
|
|
|
|
|
243
|
|
|
|
|
|
|
=head1 ATTRIBUTES |
244
|
|
|
|
|
|
|
|
245
|
|
|
|
|
|
|
=head2 class_name |
246
|
|
|
|
|
|
|
|
247
|
|
|
|
|
|
|
The name of the L<Alien::Base> subclass. The default is based on the |
248
|
|
|
|
|
|
|
distribution's main module. |
249
|
|
|
|
|
|
|
|
250
|
|
|
|
|
|
|
=head2 min_version |
251
|
|
|
|
|
|
|
|
252
|
|
|
|
|
|
|
The minimum version to suggest using as a prereq. |
253
|
|
|
|
|
|
|
|
254
|
|
|
|
|
|
|
=head2 type |
255
|
|
|
|
|
|
|
|
256
|
|
|
|
|
|
|
Types of the L<Alien>. This can be specified multiple times. Valid types: |
257
|
|
|
|
|
|
|
|
258
|
|
|
|
|
|
|
=over 4 |
259
|
|
|
|
|
|
|
|
260
|
|
|
|
|
|
|
=item library |
261
|
|
|
|
|
|
|
|
262
|
|
|
|
|
|
|
=item tool |
263
|
|
|
|
|
|
|
|
264
|
|
|
|
|
|
|
=item ffi |
265
|
|
|
|
|
|
|
|
266
|
|
|
|
|
|
|
=back |
267
|
|
|
|
|
|
|
|
268
|
|
|
|
|
|
|
=head2 name |
269
|
|
|
|
|
|
|
|
270
|
|
|
|
|
|
|
[required] |
271
|
|
|
|
|
|
|
|
272
|
|
|
|
|
|
|
The name of the alienized project. For example C<libarchive> or C<infozip>. |
273
|
|
|
|
|
|
|
|
274
|
|
|
|
|
|
|
=head2 see_also |
275
|
|
|
|
|
|
|
|
276
|
|
|
|
|
|
|
List of modules to refer to in the C<SEE ALSO> section. By default this is |
277
|
|
|
|
|
|
|
|
278
|
|
|
|
|
|
|
=over 4 |
279
|
|
|
|
|
|
|
|
280
|
|
|
|
|
|
|
=item L<Alien> |
281
|
|
|
|
|
|
|
|
282
|
|
|
|
|
|
|
=item L<Alien::Base> |
283
|
|
|
|
|
|
|
|
284
|
|
|
|
|
|
|
=item L<Alien::Build::Manual::AlienUser> |
285
|
|
|
|
|
|
|
|
286
|
|
|
|
|
|
|
=back |
287
|
|
|
|
|
|
|
|
288
|
|
|
|
|
|
|
=head1 AUTHOR |
289
|
|
|
|
|
|
|
|
290
|
|
|
|
|
|
|
Graham Ollis <plicease@cpan.org> |
291
|
|
|
|
|
|
|
|
292
|
|
|
|
|
|
|
=head1 COPYRIGHT AND LICENSE |
293
|
|
|
|
|
|
|
|
294
|
|
|
|
|
|
|
This software is copyright (c) 2017 by Graham Ollis. |
295
|
|
|
|
|
|
|
|
296
|
|
|
|
|
|
|
This is free software; you can redistribute it and/or modify it under |
297
|
|
|
|
|
|
|
the same terms as the Perl 5 programming language system itself. |
298
|
|
|
|
|
|
|
|
299
|
|
|
|
|
|
|
=cut |
300
|
|
|
|
|
|
|
|
301
|
|
|
|
|
|
|
__DATA__ |
302
|
|
|
|
|
|
|
|
303
|
|
|
|
|
|
|
__[ __SYNOPSIS_LIBRARY__ ]__ |
304
|
|
|
|
|
|
|
In your Makefile.PL: |
305
|
|
|
|
|
|
|
|
306
|
|
|
|
|
|
|
use ExtUtils::MakeMaker; |
307
|
|
|
|
|
|
|
use Alien::Base::Wrapper (); |
308
|
|
|
|
|
|
|
|
309
|
|
|
|
|
|
|
WriteMakefile( |
310
|
|
|
|
|
|
|
Alien::Base::Wrapper->new('{{ $class }}')->mm_args2( |
311
|
|
|
|
|
|
|
# MakeMaker args |
312
|
|
|
|
|
|
|
NAME => 'My::XS', |
313
|
|
|
|
|
|
|
... |
314
|
|
|
|
|
|
|
), |
315
|
|
|
|
|
|
|
); |
316
|
|
|
|
|
|
|
|
317
|
|
|
|
|
|
|
In your Build.PL: |
318
|
|
|
|
|
|
|
|
319
|
|
|
|
|
|
|
use Module::Build; |
320
|
|
|
|
|
|
|
use Alien::Base::Wrapper qw( {{ $class }} !export ); |
321
|
|
|
|
|
|
|
|
322
|
|
|
|
|
|
|
my $builder = Module::Build->new( |
323
|
|
|
|
|
|
|
... |
324
|
|
|
|
|
|
|
configure_requires => { |
325
|
|
|
|
|
|
|
'{{ $class }}' => '{{ $version }}', |
326
|
|
|
|
|
|
|
... |
327
|
|
|
|
|
|
|
}, |
328
|
|
|
|
|
|
|
Alien::Base::Wrapper->mb_args, |
329
|
|
|
|
|
|
|
... |
330
|
|
|
|
|
|
|
); |
331
|
|
|
|
|
|
|
|
332
|
|
|
|
|
|
|
$build->create_build_script; |
333
|
|
|
|
|
|
|
|
334
|
|
|
|
|
|
|
__[ __SYNOPSIS_FFI__ ]__ |
335
|
|
|
|
|
|
|
In your L<FFI::Platypus> script or module: |
336
|
|
|
|
|
|
|
|
337
|
|
|
|
|
|
|
use FFI::Platypus; |
338
|
|
|
|
|
|
|
use {{ $class }}{{ $optversion }}; |
339
|
|
|
|
|
|
|
|
340
|
|
|
|
|
|
|
my $ffi = FFI::Platypus->new( |
341
|
|
|
|
|
|
|
lib => [ {{ $class }}->dynamic_libs ], |
342
|
|
|
|
|
|
|
); |
343
|
|
|
|
|
|
|
|
344
|
|
|
|
|
|
|
__[ __SYNOPSIS_TOOL__ ]__ |
345
|
|
|
|
|
|
|
In your script or module: |
346
|
|
|
|
|
|
|
|
347
|
|
|
|
|
|
|
use {{ $class }}{{ $optversion }}; |
348
|
|
|
|
|
|
|
use Env qw( @PATH ); |
349
|
|
|
|
|
|
|
|
350
|
|
|
|
|
|
|
unshift @PATH, {{ $class }}->bin_dir; |
351
|
|
|
|
|
|
|
|
352
|
|
|
|
|
|
|
__[ __DESCRIPTION__ ]__ |
353
|
|
|
|
|
|
|
=head1 DESCRIPTION |
354
|
|
|
|
|
|
|
|
355
|
|
|
|
|
|
|
This distribution provides {{ $name }} so that it can be used by other |
356
|
|
|
|
|
|
|
Perl distributions that are on CPAN. It does this by first trying to |
357
|
|
|
|
|
|
|
detect an existing install of {{ $name }} on your system. If found it |
358
|
|
|
|
|
|
|
will use that. If it cannot be found, the source code will be downloaded |
359
|
|
|
|
|
|
|
from the internet and it will be installed in a private share location |
360
|
|
|
|
|
|
|
for the use of other modules. |
361
|
|
|
|
|
|
|
|
362
|
|
|
|
|
|
|
=cut |