line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
=head1 NAME |
2
|
|
|
|
|
|
|
|
3
|
|
|
|
|
|
|
Sub::Metadata - read and write subroutine metadata |
4
|
|
|
|
|
|
|
|
5
|
|
|
|
|
|
|
=head1 SYNOPSIS |
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
use Sub::Metadata qw( |
8
|
|
|
|
|
|
|
sub_body_type |
9
|
|
|
|
|
|
|
sub_closure_role |
10
|
|
|
|
|
|
|
sub_is_lvalue |
11
|
|
|
|
|
|
|
sub_is_constant |
12
|
|
|
|
|
|
|
sub_is_method mutate_sub_is_method |
13
|
|
|
|
|
|
|
sub_is_debuggable mutate_sub_is_debuggable |
14
|
|
|
|
|
|
|
sub_prototype mutate_sub_prototype |
15
|
|
|
|
|
|
|
sub_package mutate_sub_package |
16
|
|
|
|
|
|
|
); |
17
|
|
|
|
|
|
|
|
18
|
|
|
|
|
|
|
$type = sub_body_type($sub); |
19
|
|
|
|
|
|
|
$type = sub_closure_role($sub); |
20
|
|
|
|
|
|
|
if(sub_is_lvalue($sub)) { ... |
21
|
|
|
|
|
|
|
if(sub_is_constant($sub)) { ... |
22
|
|
|
|
|
|
|
if(sub_is_method($sub)) { ... |
23
|
|
|
|
|
|
|
mutate_sub_is_method($sub, 1); |
24
|
|
|
|
|
|
|
if(sub_is_debuggable($sub)) { ... |
25
|
|
|
|
|
|
|
mutate_sub_is_debuggable($sub, 0); |
26
|
|
|
|
|
|
|
$proto = sub_prototype($sub); |
27
|
|
|
|
|
|
|
mutate_sub_prototype($sub, $proto); |
28
|
|
|
|
|
|
|
$pkg = sub_package($sub); |
29
|
|
|
|
|
|
|
mutate_sub_package($sub, $pkg); |
30
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
=head1 DESCRIPTION |
32
|
|
|
|
|
|
|
|
33
|
|
|
|
|
|
|
This module contains functions that examine and modify data that Perl |
34
|
|
|
|
|
|
|
attaches to subroutines. |
35
|
|
|
|
|
|
|
|
36
|
|
|
|
|
|
|
=cut |
37
|
|
|
|
|
|
|
|
38
|
|
|
|
|
|
|
package Sub::Metadata; |
39
|
|
|
|
|
|
|
|
40
|
8
|
|
|
8
|
|
110811
|
{ use 5.006; } |
|
8
|
|
|
|
|
23
|
|
|
8
|
|
|
|
|
244
|
|
41
|
8
|
|
|
8
|
|
30
|
use warnings; |
|
8
|
|
|
|
|
8
|
|
|
8
|
|
|
|
|
221
|
|
42
|
8
|
|
|
8
|
|
35
|
use strict; |
|
8
|
|
|
|
|
23
|
|
|
8
|
|
|
|
|
344
|
|
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
our $VERSION = "0.001"; |
45
|
|
|
|
|
|
|
|
46
|
8
|
|
|
8
|
|
3173
|
use parent "Exporter"; |
|
8
|
|
|
|
|
1838
|
|
|
8
|
|
|
|
|
30
|
|
47
|
|
|
|
|
|
|
our @EXPORT_OK = qw( |
48
|
|
|
|
|
|
|
sub_body_type |
49
|
|
|
|
|
|
|
sub_closure_role |
50
|
|
|
|
|
|
|
sub_is_lvalue |
51
|
|
|
|
|
|
|
sub_is_constant |
52
|
|
|
|
|
|
|
sub_is_method mutate_sub_is_method |
53
|
|
|
|
|
|
|
sub_is_debuggable mutate_sub_is_debuggable |
54
|
|
|
|
|
|
|
sub_prototype mutate_sub_prototype |
55
|
|
|
|
|
|
|
sub_package mutate_sub_package |
56
|
|
|
|
|
|
|
); |
57
|
|
|
|
|
|
|
|
58
|
|
|
|
|
|
|
require XSLoader; |
59
|
|
|
|
|
|
|
XSLoader::load(__PACKAGE__, $VERSION); |
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
=head1 FUNCTIONS |
62
|
|
|
|
|
|
|
|
63
|
|
|
|
|
|
|
Each of these functions takes an argument I, which must be a |
64
|
|
|
|
|
|
|
reference to a subroutine. The function operates on the subroutine |
65
|
|
|
|
|
|
|
referenced by I. |
66
|
|
|
|
|
|
|
|
67
|
|
|
|
|
|
|
The C functions modify a subroutine in place. The subroutine's |
68
|
|
|
|
|
|
|
identity is not changed, but the attributes of the existing subroutine |
69
|
|
|
|
|
|
|
object are changed. All references to the existing subroutine will see |
70
|
|
|
|
|
|
|
the new attributes. Beware of action at a distance. |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
=over |
73
|
|
|
|
|
|
|
|
74
|
|
|
|
|
|
|
=item sub_body_type(SUB) |
75
|
|
|
|
|
|
|
|
76
|
|
|
|
|
|
|
Returns a keyword indicating the general nature of the implementation |
77
|
|
|
|
|
|
|
of I: |
78
|
|
|
|
|
|
|
|
79
|
|
|
|
|
|
|
=over |
80
|
|
|
|
|
|
|
|
81
|
|
|
|
|
|
|
=item B |
82
|
|
|
|
|
|
|
|
83
|
|
|
|
|
|
|
The subroutine's body consists of a network of op nodes for the Perl |
84
|
|
|
|
|
|
|
interpreter. Subroutines written in Perl are almost always of this form. |
85
|
|
|
|
|
|
|
|
86
|
|
|
|
|
|
|
=item B |
87
|
|
|
|
|
|
|
|
88
|
|
|
|
|
|
|
The subroutine has no body, and so cannot be successfully called. |
89
|
|
|
|
|
|
|
|
90
|
|
|
|
|
|
|
=item B |
91
|
|
|
|
|
|
|
|
92
|
|
|
|
|
|
|
The subroutine's body consists of native machine code. Usually these |
93
|
|
|
|
|
|
|
subroutines have been mainly written in C. Constant-valued subroutines |
94
|
|
|
|
|
|
|
written in Perl can also acquire this type of body. |
95
|
|
|
|
|
|
|
|
96
|
|
|
|
|
|
|
=back |
97
|
|
|
|
|
|
|
|
98
|
|
|
|
|
|
|
=item sub_closure_role(SUB) |
99
|
|
|
|
|
|
|
|
100
|
|
|
|
|
|
|
Returns a keyword indicating the status of I with respect to the |
101
|
|
|
|
|
|
|
generation of closures in the Perl language: |
102
|
|
|
|
|
|
|
|
103
|
|
|
|
|
|
|
=over |
104
|
|
|
|
|
|
|
|
105
|
|
|
|
|
|
|
=item B |
106
|
|
|
|
|
|
|
|
107
|
|
|
|
|
|
|
The subroutine is a closure: it was generated from Perl code referencing |
108
|
|
|
|
|
|
|
external lexical variables, and now references a particular set of those |
109
|
|
|
|
|
|
|
variables to make up a complete subroutine. |
110
|
|
|
|
|
|
|
|
111
|
|
|
|
|
|
|
=item B |
112
|
|
|
|
|
|
|
|
113
|
|
|
|
|
|
|
The subroutine is a prototype for closures: it consists of Perl code |
114
|
|
|
|
|
|
|
referencing external lexical variables, and has not been attached to a |
115
|
|
|
|
|
|
|
particular set of those variables. This is not a complete subroutine |
116
|
|
|
|
|
|
|
and cannot be successfully called. It is an oddity of Perl that this |
117
|
|
|
|
|
|
|
type of object is represented as if it were a subroutine, and the |
118
|
|
|
|
|
|
|
situations where one can get access to this kind of object are rare. |
119
|
|
|
|
|
|
|
Prototype subroutines will mainly be encountered by attribute handlers. |
120
|
|
|
|
|
|
|
|
121
|
|
|
|
|
|
|
=item B |
122
|
|
|
|
|
|
|
|
123
|
|
|
|
|
|
|
The subroutine is independent of external lexical variables. |
124
|
|
|
|
|
|
|
|
125
|
|
|
|
|
|
|
=back |
126
|
|
|
|
|
|
|
|
127
|
|
|
|
|
|
|
=item sub_is_lvalue(SUB) |
128
|
|
|
|
|
|
|
|
129
|
|
|
|
|
|
|
Returns a truth value indicating whether I is expected to return an |
130
|
|
|
|
|
|
|
lvalue. An lvalue subroutine is usually created by using the C<:lvalue> |
131
|
|
|
|
|
|
|
attribute, which affects how the subroutine body is compiled and also |
132
|
|
|
|
|
|
|
sets the flag that this function extracts. |
133
|
|
|
|
|
|
|
|
134
|
|
|
|
|
|
|
=item sub_is_constant(SUB) |
135
|
|
|
|
|
|
|
|
136
|
|
|
|
|
|
|
Returns a truth value indicating whether I returns a constant |
137
|
|
|
|
|
|
|
value and can therefore be inlined. It is possible for a subroutine |
138
|
|
|
|
|
|
|
to actually be constant-valued without the compiler detecting it and |
139
|
|
|
|
|
|
|
setting this flag. |
140
|
|
|
|
|
|
|
|
141
|
|
|
|
|
|
|
=item sub_is_method(SUB) |
142
|
|
|
|
|
|
|
|
143
|
|
|
|
|
|
|
Returns a truth value indicating whether I is marked as a method. |
144
|
|
|
|
|
|
|
This marker can be applied by use of the C<:method> attribute, and |
145
|
|
|
|
|
|
|
(as of Perl 5.10) affects almost nothing. |
146
|
|
|
|
|
|
|
|
147
|
|
|
|
|
|
|
=item mutate_sub_is_method(SUB, NEW_METHODNESS) |
148
|
|
|
|
|
|
|
|
149
|
|
|
|
|
|
|
Marks or unmarks I as a method, depending on the truth value of |
150
|
|
|
|
|
|
|
I. |
151
|
|
|
|
|
|
|
|
152
|
|
|
|
|
|
|
=item sub_is_debuggable(SUB) |
153
|
|
|
|
|
|
|
|
154
|
|
|
|
|
|
|
Returns a truth value indicating whether, when the Perl debugger |
155
|
|
|
|
|
|
|
is activated, calls to I can be intercepted by C (see |
156
|
|
|
|
|
|
|
L). Normally this is true for all subroutines, but note |
157
|
|
|
|
|
|
|
that whether a particular call is intercepted also depends on the nature |
158
|
|
|
|
|
|
|
of the calling site. |
159
|
|
|
|
|
|
|
|
160
|
|
|
|
|
|
|
=item mutate_sub_is_debuggable(SUB, NEW_DEBUGGABILITY) |
161
|
|
|
|
|
|
|
|
162
|
|
|
|
|
|
|
Changes whether the Perl debugger will intercept calls to I, |
163
|
|
|
|
|
|
|
depending on the truth value of I. |
164
|
|
|
|
|
|
|
|
165
|
|
|
|
|
|
|
=item sub_prototype(SUB) |
166
|
|
|
|
|
|
|
|
167
|
|
|
|
|
|
|
Returns the prototype of I, which is a string, or C if the |
168
|
|
|
|
|
|
|
subroutine has no prototype. (No prototype is different from the empty |
169
|
|
|
|
|
|
|
string prototype.) Prototypes affect the compilation of calls to the |
170
|
|
|
|
|
|
|
subroutine, where the identity of the called subroutine can be resolved |
171
|
|
|
|
|
|
|
at compile time. (This is unrelated to the closure prototypes described |
172
|
|
|
|
|
|
|
for L.) |
173
|
|
|
|
|
|
|
|
174
|
|
|
|
|
|
|
=item mutate_sub_prototype(SUB, NEW_PROTOTYPE) |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
Sets or deletes the prototype of I, to match I, |
177
|
|
|
|
|
|
|
which must be either a string or C. |
178
|
|
|
|
|
|
|
|
179
|
|
|
|
|
|
|
=item sub_package(SUB) |
180
|
|
|
|
|
|
|
|
181
|
|
|
|
|
|
|
Returns the name of the package within which I is defined, or |
182
|
|
|
|
|
|
|
C if there is none. For a subroutine written in Perl, this |
183
|
|
|
|
|
|
|
is normally the package that is selected in the lexical scope of the |
184
|
|
|
|
|
|
|
subroutine definition. For a subroutine written in C it is normally |
185
|
|
|
|
|
|
|
not set. Where set, this is not necessarily a package containing a name |
186
|
|
|
|
|
|
|
by which the subroutine can be referenced. It is also (for subroutines |
187
|
|
|
|
|
|
|
written in Perl) not necessarily the selected package in any lexical |
188
|
|
|
|
|
|
|
scope within the subroutine. This association of each subroutine with |
189
|
|
|
|
|
|
|
a package affects almost nothing: the main effect is that subroutines |
190
|
|
|
|
|
|
|
in the C package are normally not subject to debugging, even when |
191
|
|
|
|
|
|
|
flagged as debuggable (see L). |
192
|
|
|
|
|
|
|
|
193
|
|
|
|
|
|
|
=item mutate_sub_package(SUB, NEW_PACKAGE) |
194
|
|
|
|
|
|
|
|
195
|
|
|
|
|
|
|
Sets or deletes the package of I, to match I, which |
196
|
|
|
|
|
|
|
must be either a string or C. |
197
|
|
|
|
|
|
|
|
198
|
|
|
|
|
|
|
=back |
199
|
|
|
|
|
|
|
|
200
|
|
|
|
|
|
|
=head1 SEE ALSO |
201
|
|
|
|
|
|
|
|
202
|
|
|
|
|
|
|
L |
203
|
|
|
|
|
|
|
|
204
|
|
|
|
|
|
|
=head1 AUTHOR |
205
|
|
|
|
|
|
|
|
206
|
|
|
|
|
|
|
Andrew Main (Zefram) |
207
|
|
|
|
|
|
|
|
208
|
|
|
|
|
|
|
=head1 COPYRIGHT |
209
|
|
|
|
|
|
|
|
210
|
|
|
|
|
|
|
Copyright (C) 2009, 2010, 2011, 2013, 2015 |
211
|
|
|
|
|
|
|
Andrew Main (Zefram) |
212
|
|
|
|
|
|
|
|
213
|
|
|
|
|
|
|
=head1 LICENSE |
214
|
|
|
|
|
|
|
|
215
|
|
|
|
|
|
|
This module is free software; you can redistribute it and/or modify it |
216
|
|
|
|
|
|
|
under the same terms as Perl itself. |
217
|
|
|
|
|
|
|
|
218
|
|
|
|
|
|
|
=cut |
219
|
|
|
|
|
|
|
|
220
|
|
|
|
|
|
|
1; |