1Class::Inspector(3) User Contributed Perl Documentation Class::Inspector(3)
2
3
4
6 Class::Inspector - Get information about a class and its structure
7
9 version 1.36
10
12 use Class::Inspector;
13
14 # Is a class installed and/or loaded
15 Class::Inspector->installed( 'Foo::Class' );
16 Class::Inspector->loaded( 'Foo::Class' );
17
18 # Filename related information
19 Class::Inspector->filename( 'Foo::Class' );
20 Class::Inspector->resolved_filename( 'Foo::Class' );
21
22 # Get subroutine related information
23 Class::Inspector->functions( 'Foo::Class' );
24 Class::Inspector->function_refs( 'Foo::Class' );
25 Class::Inspector->function_exists( 'Foo::Class', 'bar' );
26 Class::Inspector->methods( 'Foo::Class', 'full', 'public' );
27
28 # Find all loaded subclasses or something
29 Class::Inspector->subclasses( 'Foo::Class' );
30
32 Class::Inspector allows you to get information about a loaded class.
33 Most or all of this information can be found in other ways, but they
34 aren't always very friendly, and usually involve a relatively high
35 level of Perl wizardry, or strange and unusual looking code.
36 Class::Inspector attempts to provide an easier, more friendly interface
37 to this information.
38
40 installed
41 my $bool = Class::Inspector->installed($class);
42
43 The "installed" static method tries to determine if a class is
44 installed on the machine, or at least available to Perl. It does this
45 by wrapping around "resolved_filename".
46
47 Returns true if installed/available, false if the class is not
48 installed, or "undef" if the class name is invalid.
49
50 loaded
51 my $bool = Class::Inspector->loaded($class);
52
53 The "loaded" static method tries to determine if a class is loaded by
54 looking for symbol table entries.
55
56 This method it uses to determine this will work even if the class does
57 not have its own file, but is contained inside a single file with
58 multiple classes in it. Even in the case of some sort of run-time
59 loading class being used, these typically leave some trace in the
60 symbol table, so an Autoload or Class::Autouse-based class should
61 correctly appear loaded.
62
63 Returns true if the class is loaded, false if not, or "undef" if the
64 class name is invalid.
65
66 filename
67 my $filename = Class::Inspector->filename($class);
68
69 For a given class, returns the base filename for the class. This will
70 NOT be a fully resolved filename, just the part of the filename BELOW
71 the @INC entry.
72
73 print Class->filename( 'Foo::Bar' );
74 > Foo/Bar.pm
75
76 This filename will be returned with the right separator for the local
77 platform, and should work on all platforms.
78
79 Returns the filename on success or "undef" if the class name is
80 invalid.
81
82 resolved_filename
83 my $filename = Class::Inspector->resolved_filename($class);
84 my $filename = Class::Inspector->resolved_filename($class, @try_first);
85
86 For a given class, the "resolved_filename" static method returns the
87 fully resolved filename for a class. That is, the file that the class
88 would be loaded from.
89
90 This is not necessarily the file that the class WAS loaded from, as the
91 value returned is determined each time it runs, and the @INC include
92 path may change.
93
94 To get the actual file for a loaded class, see the "loaded_filename"
95 method.
96
97 Returns the filename for the class, or "undef" if the class name is
98 invalid.
99
100 loaded_filename
101 my $filename = Class::Inspector->loaded_filename($class);
102
103 For a given loaded class, the "loaded_filename" static method
104 determines (via the %INC hash) the name of the file that it was
105 originally loaded from.
106
107 Returns a resolved file path, or false if the class did not have it's
108 own file.
109
110 functions
111 my $arrayref = Class::Inspector->functions($class);
112
113 For a loaded class, the "functions" static method returns a list of the
114 names of all the functions in the classes immediate namespace.
115
116 Note that this is not the METHODS of the class, just the functions.
117
118 Returns a reference to an array of the function names on success, or
119 "undef" if the class name is invalid or the class is not loaded.
120
121 function_refs
122 my $arrayref = Class::Inspector->function_refs($class);
123
124 For a loaded class, the "function_refs" static method returns
125 references to all the functions in the classes immediate namespace.
126
127 Note that this is not the METHODS of the class, just the functions.
128
129 Returns a reference to an array of "CODE" refs of the functions on
130 success, or "undef" if the class is not loaded.
131
132 function_exists
133 my $bool = Class::Inspector->function_exists($class, $functon);
134
135 Given a class and function name the "function_exists" static method
136 will check to see if the function exists in the class.
137
138 Note that this is as a function, not as a method. To see if a method
139 exists for a class, use the "can" method for any class or object.
140
141 Returns true if the function exists, false if not, or "undef" if the
142 class or function name are invalid, or the class is not loaded.
143
144 methods
145 my $arrayref = Class::Inspector->methods($class, @options);
146
147 For a given class name, the "methods" static method will returns ALL
148 the methods available to that class. This includes all methods
149 available from every class up the class' @ISA tree.
150
151 Returns a reference to an array of the names of all the available
152 methods on success, or "undef" if the class name is invalid or the
153 class is not loaded.
154
155 A number of options are available to the "methods" method that will
156 alter the results returned. These should be listed after the class
157 name, in any order.
158
159 # Only get public methods
160 my $method = Class::Inspector->methods( 'My::Class', 'public' );
161
162 public
163 The "public" option will return only 'public' methods, as defined
164 by the Perl convention of prepending an underscore to any 'private'
165 methods. The "public" option will effectively remove any methods
166 that start with an underscore.
167
168 private
169 The "private" options will return only 'private' methods, as
170 defined by the Perl convention of prepending an underscore to an
171 private methods. The "private" option will effectively remove an
172 method that do not start with an underscore.
173
174 Note: The "public" and "private" options are mutually exclusive
175
176 full
177 "methods" normally returns just the method name. Supplying the
178 "full" option will cause the methods to be returned as the full
179 names. That is, instead of returning "[ 'method1', 'method2',
180 'method3' ]", you would instead get "[ 'Class::method1',
181 'AnotherClass::method2', 'Class::method3' ]".
182
183 expanded
184 The "expanded" option will cause a lot more information about
185 method to be returned. Instead of just the method name, you will
186 instead get an array reference containing the method name as a
187 single combined name, a la "full", the separate class and method,
188 and a CODE ref to the actual function ( if available ). Please note
189 that the function reference is not guaranteed to be available.
190 "Class::Inspector" is intended at some later time, to work with
191 modules that have some kind of common run-time loader in place (
192 e.g "Autoloader" or "Class::Autouse" for example.
193
194 The response from "methods( 'Class', 'expanded' )" would look
195 something like the following.
196
197 [
198 [ 'Class::method1', 'Class', 'method1', \&Class::method1 ],
199 [ 'Another::method2', 'Another', 'method2', \&Another::method2 ],
200 [ 'Foo::bar', 'Foo', 'bar', \&Foo::bar ],
201 ]
202
203 subclasses
204 my $arrayref = Class::Inspector->subclasses($class);
205
206 The "subclasses" static method will search then entire namespace (and
207 thus all currently loaded classes) to find all classes that are
208 subclasses of the class provided as a the parameter.
209
210 The actual test will be done by calling "isa" on the class as a static
211 method. (i.e. "My::Class->isa($class)".
212
213 Returns a reference to a list of the loaded classes that match the
214 class provided, or false is none match, or "undef" if the class name
215 provided is invalid.
216
218 <http://ali.as/>, Class::Handle, Class::Inspector::Functions
219
221 Original author: Adam Kennedy <adamk@cpan.org>
222
223 Current maintainer: Graham Ollis <plicease@cpan.org>
224
225 Contributors:
226
227 Tom Wyant
228
229 Steffen Müller
230
231 Kivanc Yazan (KYZN)
232
234 This software is copyright (c) 2002-2019 by Adam Kennedy.
235
236 This is free software; you can redistribute it and/or modify it under
237 the same terms as the Perl 5 programming language system itself.
238
239
240
241perl v5.34.0 2021-07-22 Class::Inspector(3)