1MakeMethods::Standard::UAsrerrayC(o3n)tributed Perl DocuMmaeknetMaettihoonds::Standard::Array(3)
2
3
4
6 Class::MakeMethods::Standard::Array - Methods for Array objects
7
9 package MyObject;
10 use Class::MakeMethods::Standard::Array (
11 new => 'new',
12 scalar => [ 'foo', 'bar' ],
13 array => 'my_list',
14 hash => 'my_index',
15 );
16 ...
17
18 my $obj = MyObject->new( foo => 'Foozle' );
19 print $obj->foo();
20
21 $obj->bar('Barbados');
22 print $obj->bar();
23
24 $obj->my_list(0 => 'Foozle', 1 => 'Bang!');
25 print $obj->my_list(1);
26
27 $obj->my_index('broccoli' => 'Blah!', 'foo' => 'Fiddle');
28 print $obj->my_index('foo');
29
31 The Standard::Array suclass of MakeMethods provides a basic constructor
32 and accessors for blessed-array object instances.
33
34 Calling Conventions
35 When you "use" this package, the method names you provide as arguments
36 cause subroutines to be generated and installed in your module.
37
38 See "Calling Conventions" in Class::MakeMethods::Standard for more
39 information.
40
41 Declaration Syntax
42 To declare methods, pass in pairs of a method-type name followed by one
43 or more method names.
44
45 Valid method-type names for this package are listed in "METHOD
46 GENERATOR TYPES".
47
48 See "Declaration Syntax" in Class::MakeMethods::Standard and "Parameter
49 Syntax" in Class::MakeMethods::Standard for more information.
50
51 Positional Accessors and %FIELDS
52 Each accessor method is assigned the next available array index at
53 which to store its value.
54
55 The mapping between method names and array positions is stored in a
56 hash named %FIELDS in the declaring package. When a package declares
57 its first positional accessor, its %FIELDS are initialized by searching
58 its inheritance tree.
59
60 Warning: Subclassing packages that use positional accessors is somewhat
61 fragile, since you may end up with two distinct methods assigned to the
62 same position. Specific cases to avoid are:
63
64 • If you inherit from more than one class with positional accessors,
65 the positions used by the two sets of methods will overlap.
66
67 • If your superclass adds additional positional accessors after you
68 declare your first, they will overlap yours.
69
71 new - Constructor
72 For each method name passed, returns a subroutine with the following
73 characteristics:
74
75 • Has a reference to a sample item to copy. This defaults to a
76 reference to an empty array, but you may override this with the
77 "'defaults' =" array_ref> method parameter.
78
79 • If called as a class method, makes a new array containing values
80 from the sample item, and blesses it into that class.
81
82 • If called on an array-based instance, makes a copy of it and
83 blesses the copy into the same class as the original instance.
84
85 • If passed a list of method-value pairs, calls each named method
86 with the associated value as an argument.
87
88 • Returns the new instance.
89
90 Sample declaration and usage:
91
92 package MyObject;
93 use Class::MakeMethods::Standard::Array (
94 new => 'new',
95 );
96 ...
97
98 # Bare constructor
99 my $empty = MyObject->new();
100
101 # Constructor with initial sequence of method calls
102 my $obj = MyObject->new( foo => 'Foozle', bar => 'Barbados' );
103
104 # Copy with overriding sequence of method calls
105 my $copy = $obj->new( bar => 'Bob' );
106
107 scalar - Instance Accessor
108 For each method name passed, uses a closure to generate a subroutine
109 with the following characteristics:
110
111 • Must be called on an array-based instance.
112
113 • Determines the array position associated with the method name, and
114 uses that as an index into each instance to access the related
115 value. This defaults to the next available slot in %FIELDS, but you
116 may override this with the "'array_index' =" number> method
117 parameter, or by pre-filling the contents of %FIELDS.
118
119 • If called without any arguments returns the current value (or
120 undef).
121
122 • If called with an argument, stores that as the value, and returns
123 it,
124
125 Sample declaration and usage:
126
127 package MyObject;
128 use Class::MakeMethods::Standard::Array (
129 scalar => 'foo',
130 );
131 ...
132
133 # Store value
134 $obj->foo('Foozle');
135
136 # Retrieve value
137 print $obj->foo;
138
139 array - Instance Ref Accessor
140 For each method name passed, uses a closure to generate a subroutine
141 with the following characteristics:
142
143 • Must be called on an array-based instance.
144
145 • Determines the array position associated with the method name, and
146 uses that as an index into each instance to access the related
147 value. This defaults to the next available slot in %FIELDS, but you
148 may override this with the "'array_index' =" number> method
149 parameter, or by pre-filling the contents of %FIELDS.
150
151 • The value for each instance will be a reference to an array (or
152 undef).
153
154 • If called without any arguments, returns the current array-ref
155 value (or undef).
156
157 • If called with a single non-ref argument, uses that argument as an
158 index to retrieve from the referenced array, and returns that value
159 (or undef).
160
161 • If called with a single array ref argument, uses that list to
162 return a slice of the referenced array.
163
164 • If called with a list of argument pairs, each with a non-ref index
165 and an associated value, stores the value at the given index in the
166 referenced array. If the instance's value was previously undefined,
167 a new array is autovivified. The current value in each position
168 will be overwritten, and later arguments with the same index will
169 override earlier ones. Returns the current array-ref value.
170
171 • If called with a list of argument pairs, each with the first item
172 being a reference to an array of up to two numbers, loops over each
173 pair and uses those numbers to splice the value array.
174
175 The first controlling number is the position at which the splice
176 will begin. Zero will start before the first item in the list.
177 Negative numbers count backwards from the end of the array.
178
179 The second number is the number of items to be removed from the
180 list. If it is omitted, or undefined, or zero, no items are
181 removed. If it is a positive integer, that many items will be
182 returned.
183
184 If both numbers are omitted, or are both undefined, they default to
185 containing the entire value array.
186
187 If the second argument is undef, no values will be inserted; if it
188 is a non-reference value, that one value will be inserted; if it is
189 an array-ref, its values will be copied.
190
191 The method returns the items that removed from the array, if any.
192
193 Sample declaration and usage:
194
195 package MyObject;
196 use Class::MakeMethods::Standard::Array (
197 array => 'bar',
198 );
199 ...
200
201 # Clear and set contents of list
202 print $obj->bar([ 'Spume', 'Frost' ] );
203
204 # Set values by position
205 $obj->bar(0 => 'Foozle', 1 => 'Bang!');
206
207 # Positions may be overwritten, and in any order
208 $obj->bar(2 => 'And Mash', 1 => 'Blah!');
209
210 # Retrieve value by position
211 print $obj->bar(1);
212
213 # Direct access to referenced array
214 print scalar @{ $obj->bar() };
215
216 There are also calling conventions for slice and splice operations:
217
218 # Retrieve slice of values by position
219 print join(', ', $obj->bar( undef, [0, 2] ) );
220
221 # Insert an item at position in the array
222 $obj->bar([3], 'Potatoes' );
223
224 # Remove 1 item from position 3 in the array
225 $obj->bar([3, 1], undef );
226
227 # Set a new value at position 2, and return the old value
228 print $obj->bar([2, 1], 'Froth' );
229
230 hash - Instance Ref Accessor
231 For each method name passed, uses a closure to generate a subroutine
232 with the following characteristics:
233
234 • Must be called on an array-based instance.
235
236 • Determines the array position associated with the method name, and
237 uses that as an index into each instance to access the related
238 value. This defaults to the next available slot in %FIELDS, but you
239 may override this with the "'array_index' =" number> method
240 parameter, or by pre-filling the contents of %FIELDS.
241
242 • The value for each instance will be a reference to a hash (or
243 undef).
244
245 • If called without any arguments, returns the contents of the hash
246 in list context, or a hash reference in scalar context (or undef).
247
248 • If called with one argument, uses that argument as an index to
249 retrieve from the referenced hash, and returns that value (or
250 undef). If the single argument is an array ref, then a slice of the
251 referenced hash is returned.
252
253 • If called with a list of key-value pairs, stores the value under
254 the given key in the referenced hash. If the instance's value was
255 previously undefined, a new hash is autovivified. The current value
256 under each key will be overwritten, and later arguments with the
257 same key will override earlier ones. Returns the contents of the
258 hash in list context, or a hash reference in scalar context.
259
260 Sample declaration and usage:
261
262 package MyObject;
263 use Class::MakeMethods::Standard::Array (
264 hash => 'baz',
265 );
266 ...
267
268 # Set values by key
269 $obj->baz('foo' => 'Foozle', 'bar' => 'Bang!');
270
271 # Values may be overwritten, and in any order
272 $obj->baz('broccoli' => 'Blah!', 'foo' => 'Fiddle');
273
274 # Retrieve value by key
275 print $obj->baz('foo');
276
277 # Retrive slice of values by position
278 print join(', ', $obj->baz( ['foo', 'bar'] ) );
279
280 # Direct access to referenced hash
281 print keys %{ $obj->baz() };
282
283 # Reset the hash contents to empty
284 @{ $obj->baz() } = ();
285
286 object - Instance Ref Accessor
287 For each method name passed, uses a closure to generate a subroutine
288 with the following characteristics:
289
290 • Must be called on an array-based instance.
291
292 • Determines the array position associated with the method name, and
293 uses that as an index into each instance to access the related
294 value. This defaults to the next available slot in %FIELDS, but you
295 may override this with the "'array_index' =" number> method
296 parameter, or by pre-filling the contents of %FIELDS.
297
298 • The value for each instance will be a reference to an object (or
299 undef).
300
301 • If called without any arguments returns the current value.
302
303 • If called with an argument, stores that as the value, and returns
304 it,
305
306 Sample declaration and usage:
307
308 package MyObject;
309 use Class::MakeMethods::Standard::Hash (
310 object => 'foo',
311 );
312 ...
313
314 # Store value
315 $obj->foo( Foozle->new() );
316
317 # Retrieve value
318 print $obj->foo;
319
321 See Class::MakeMethods for general information about this distribution.
322
323 See Class::MakeMethods::Standard for more about this family of
324 subclasses.
325
326 See Class::MakeMethods::Standard::Hash for equivalent functionality
327 based on blessed hashes. If your module will be extensively subclassed,
328 consider switching to Standard::Hash to avoid the subclassing concerns
329 described above.
330
331
332
333perl v5.36.0 2022-07-22 MakeMethods::Standard::Array(3)