This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
ad46c0f437da311141b2cb4e9cd0ba8694801674
[perl5.git] / pod / perlexperiment.pod
1 =head1 NAME
2
3 perlexperiment - A listing of experimental features in Perl
4
5 =head1 DESCRIPTION
6
7 This document lists the current and past experimental features in the perl
8 core. Although all of these are documented with their appropriate topics,
9 this succinct listing gives you an overview and basic facts about their
10 status.
11
12 So far we've merely tried to find and list the experimental features and infer
13 their inception, versions, etc. There's a lot of speculation here.
14
15 =head2 Current experiments
16
17 =over 8
18
19 =item C<our> can now have an experimental optional attribute C<unique>
20
21 Introduced in Perl 5.8.0
22
23 Deprecated in Perl 5.10.0
24
25 The ticket for this feature is
26 L<[perl #119313]|https://rt.perl.org/rt3/Ticket/Display.html?id=119313>.
27
28 =item Smart match (C<~~>)
29
30 Introduced in Perl 5.10.0
31
32 Modified in Perl 5.10.1, 5.12.0
33
34 Using this feature triggers warnings in the category
35 C<experimental::smartmatch>.
36
37 The ticket for this feature is
38 L<[perl #119317]|https://rt.perl.org/rt3/Ticket/Display.html?id=119317>.
39
40 =item Lexical C<$_>
41
42 Introduced in Perl 5.10.0
43
44 Using this feature triggers warnings in the category
45 C<experimental::lexical_topic>.
46
47 The ticket for this feature is
48 L<[perl #119315]|https://rt.perl.org/rt3/Ticket/Display.html?id=119315>.
49
50 =item Pluggable keywords
51
52 The ticket for this feature is
53 L<[perl #119455]|https://rt.perl.org/rt3/Ticket/Display.html?id=119455>.
54
55 See L<perlapi/PL_keyword_plugin> for the mechanism.
56
57 Introduced in: Perl 5.11.2
58
59 =item Array and hash container functions accept references
60
61 Introduced in Perl 5.14.0
62
63 The ticket for this feature is
64 L<[perl #119437]|https://rt.perl.org/rt3/Ticket/Display.html?id=119437>.
65
66 =item Lexical subroutines
67
68 Introduced in: Perl 5.18
69
70 See also: L<perlsub/Lexical Subroutines>
71
72 Using this feature triggers warnings in the category
73 C<experimental::lexical_subs>.
74
75 The ticket for this feature is
76 L<[perl #120085]|https://rt.perl.org/rt3/Ticket/Display.html?id=120085>.
77
78 =item Regular Expression Set Operations
79
80 Introduced in: Perl 5.18
81
82 The ticket for this feature is
83 L<[perl #119451]|https://rt.perl.org/rt3/Ticket/Display.html?id=119451>.
84
85 See also: L<perlrecharclass/Extended Bracketed Character Classes>
86
87 Using this feature triggers warnings in the category
88 C<experimental::regex_sets>.
89
90 =item Subroutine signatures
91
92 Introduced in Perl 5.20.0
93
94 Using this feature triggers warnings in the category
95 C<experimental::signatures>.
96
97 The ticket for this feature is
98 L<[perl #121481]|https://rt.perl.org/Ticket/Display.html?id=121481>.
99
100 =item Postfix dereference syntax
101
102 Introduced in Perl 5.20.0
103
104 Using this feature triggers warnings in the category
105 C<experimental::postderef>.
106
107 The ticket for this feature is
108 L<[perl #120162]|https://rt.perl.org:443/rt3/Ticket/Display.html?id=120162>.
109
110 =item Aliasing via reference
111
112 Introduced in Perl 5.22.0
113
114 Using this feature triggers warnings in the category
115 C<experimental::refaliasing>.
116
117 The ticket for this feature is
118 L<[perl #122947]|https://rt.perl.org/rt3/Ticket/Display.html?id=122947>.
119
120 See also: L<perlref/Assigning to References>
121
122 =item The "const" attribute
123
124 Introduced in Perl 5.22.0
125
126 Using this feature triggers warnings in the category
127 C<experimental::const_attr>.
128
129 The ticket for this feature is
130 L<[perl #123630]|https://rt.perl.org/rt3/Ticket/Display.html?id=123630>.
131
132 See also: L<perlsub/Constant Functions>
133
134 =item String- and number-specific bitwise operators
135
136 Introduced in: Perl 5.22.0
137
138 See also: L<perlop/Bitwise String Operators>
139
140 Using this feature triggers warnings in the category
141 C<experimental::bitwise>.
142
143 The ticket for this feature is
144 L<[perl #123707]|https://rt.perl.org/rt3/Ticket/Display.html?id=123707>.
145
146 =item The <:win32> IO pseudolayer
147
148 The ticket for this feature is
149 L<[perl #119453]|https://rt.perl.org/rt3/Ticket/Display.html?id=119453>.
150
151 See also L<perlrun>
152
153 =item There is an C<installhtml> target in the Makefile.
154
155 The ticket for this feature is
156 L<[perl #116487]|https://rt.perl.org/rt3/Ticket/Display.html?id=116487>.
157
158 =item Unicode in Perl on EBCDIC
159
160 =back
161
162 =head2 Accepted features
163
164 These features were so wildly successful and played so well with others that
165 we decided to remove their experimental status and admit them as full, stable
166 features in the world of Perl, lavishing all the benefits and luxuries thereof.
167 They are also awarded +5 Stability and +3 Charisma.
168
169 =over 8
170
171 =item 64-bit support
172
173 Introduced in Perl 5.005
174
175 =item die accepts a reference
176
177 Introduced in Perl 5.005
178
179 =item DB module
180
181 Introduced in Perl 5.6.0
182
183 See also L<perldebug>, L<perldebtut>
184
185 =item Weak references
186
187 Introduced in Perl 5.6.0
188
189 =item Internal file glob
190
191 Introduced in Perl 5.6.0
192
193 =item fork() emulation
194
195 Introduced in Perl 5.6.1
196
197 See also L<perlfork>
198
199 =item -Dusemultiplicity -Duseithreads
200
201 Introduced in Perl 5.6.0
202
203 Accepted in Perl 5.8.0
204
205 =item Support for long doubles
206
207 Introduced in Perl 5.6.0
208
209 Accepted in Perl 5.8.1
210
211 =item The C<\N> regex character class
212
213 The C<\N> character class, not to be confused with the named character
214 sequence C<\N{NAME}>, denotes any non-newline character in a regular
215 expression.
216
217 Introduced in Perl 5.12
218
219 Exact version of acceptance unclear, but no later than Perl 5.18.
220
221 =item C<(?{code})> and C<(??{ code })>
222
223 Introduced in Perl 5.6.0
224
225 Accepted in Perl 5.20.0
226
227 See also L<perlre>
228
229 =item Linux abstract Unix domain sockets
230
231 Introduced in Perl 5.9.2
232
233 Accepted before Perl 5.20.0.  The Socket library is now primarily maintained
234 on CPAN, rather than in the perl core.
235
236 See also L<Socket>
237
238 =item Lvalue subroutines
239
240 Introduced in Perl 5.6.0
241
242 Accepted in Perl 5.20.0
243
244 See also L<perlsub>
245
246 =item Backtracking control verbs
247
248 C<(*ACCEPT)>
249
250 Introduced in: Perl 5.10
251
252 Accepted in Perl 5.20.0
253
254 =item The <:pop> IO pseudolayer
255
256 See also L<perlrun>
257
258 Accepted in Perl 5.20.0
259
260 =item C<\s> in regexp matches vertical tab
261
262 Accepted in Perl 5.22.0
263
264 =back
265
266 =head2 Removed features
267
268 These features are no longer considered experimental and their functionality
269 has disappeared. It's your own fault if you wrote production programs using
270 these features after we explicitly told you not to (see L<perlpolicy>).
271
272 =over 8
273
274 =item 5.005-style threading
275
276 Introduced in Perl 5.005
277
278 Removed in Perl 5.10
279
280 =item perlcc
281
282 Introduced in Perl 5.005
283
284 Moved from Perl 5.9.0 to CPAN
285
286 =item The pseudo-hash data type
287
288 Introduced in Perl 5.6.0
289
290 Removed in Perl 5.9.0
291
292 =item GetOpt::Long Options can now take multiple values at once (experimental)
293
294 C<Getopt::Long> upgraded to version 2.35
295
296 Removed in Perl 5.8.8
297
298 =item Assertions
299
300 The C<-A> command line switch
301
302 Introduced in Perl 5.9.0
303
304 Removed in Perl 5.9.5
305
306 =item Test::Harness::Straps
307
308 Moved from Perl 5.10.1 to CPAN
309
310 =item C<legacy>
311
312 The experimental C<legacy> pragma was swallowed by the C<feature> pragma.
313
314 Introduced in: 5.11.2
315
316 Removed in: 5.11.3
317
318 =back
319
320 =head1 SEE ALSO
321
322 For a complete list of features check L<feature>.
323
324 =head1 AUTHORS
325
326 brian d foy C<< <brian.d.foy@gmail.com> >>
327
328 SE<eacute>bastien Aperghis-Tramoni C<< <saper@cpan.org> >>
329
330 =head1 COPYRIGHT
331
332 Copyright 2010, brian d foy C<< <brian.d.foy@gmail.com> >>
333
334 =head1 LICENSE
335
336 You can use and redistribute this document under the same terms as Perl
337 itself.
338
339 =cut