This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
46e19bdec7e38f9c310708194180aca0eb3905f7
[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 See L<perlapi/PL_keyword_plugin> for the mechanism.
53
54 Introduced in: Perl 5.11.2
55
56 =item Array and hash container functions accept references
57
58 Introduced in Perl 5.14.0
59
60 The ticket for this feature is
61 L<[perl #119437]|https://rt.perl.org/rt3/Ticket/Display.html?id=119437>.
62
63 =item Lexical subroutines
64
65 Introduced in: Perl 5.18
66
67 See also: L<perlsub/Lexical Subroutines>
68
69 Using this feature triggers warnings in the category
70 C<experimental::lexical_subs>.
71
72 =item Regular Expression Set Operations
73
74 Introduced in: Perl 5.18
75
76 The ticket for this feature is
77 L<[perl #119451]|https://rt.perl.org/rt3/Ticket/Display.html?id=119451>.
78
79 See also: L<perlrecharclass/Extended Bracketed Character Classes>
80
81 Using this feature triggers warnings in the category
82 C<experimental::regex_sets>.
83
84 =item C<\s> in regexp matches vertical tab
85
86 Introduced in Perl 5.18
87
88 =item The <:win32> IO pseudolayer
89
90 See also L<perlrun>
91
92 =item There is an C<installhtml> target in the Makefile.
93
94 The ticket for this feature is
95 L<[perl #116487]|https://rt.perl.org/rt3/Ticket/Display.html?id=116487>.
96
97 =item Unicode in Perl on EBCDIC
98
99 See also: L<perlre/"Special Backtracking Control Verbs">
100
101 =back
102
103 =head2 Accepted features
104
105 These features were so wildly successful and played so well with others that
106 we decided to remove their experimental status and admit them as full, stable
107 features in the world of Perl, lavishing all the benefits and luxuries thereof.
108 They are also awarded +5 Stability and +3 Charisma.
109
110 =over 8
111
112 =item 64-bit support
113
114 Introduced in Perl 5.005
115
116 =item die accepts a reference
117
118 Introduced in Perl 5.005
119
120 =item DB module
121
122 Introduced in Perl 5.6.0
123
124 See also L<perldebug>, L<perldebtut>
125
126 =item Weak references
127
128 Introduced in Perl 5.6.0
129
130 =item Internal file glob
131
132 Introduced in Perl 5.6.0
133
134 =item fork() emulation
135
136 Introduced in Perl 5.6.1
137
138 See also L<perlfork>
139
140 =item -Dusemultiplicity -Duseithreads
141
142 Introduced in Perl 5.6.0
143
144 Accepted in Perl 5.8.0
145
146 =item Support for long doubles
147
148 Introduced in Perl 5.6.0
149
150 Accepted in Perl 5.8.1
151
152 =item The C<\N> regex character class
153
154 The C<\N> character class, not to be confused with the named character
155 sequence C<\N{NAME}>, denotes any non-newline character in a regular
156 expression.
157
158 Introduced in Perl 5.12
159
160 Exact version of acceptance unclear, but no later than Perl 5.18.
161
162 =item C<(?{code})> and C<(??{ code })>
163
164 Introduced in Perl 5.6.0
165
166 Accepted in Perl 5.20.0
167
168 See also L<perlre>
169
170 =item Linux abstract Unix domain sockets
171
172 Introduced in Perl 5.9.2
173
174 Accepted before Perl 5.20.0.  The Socket library is now primarily maintained
175 on CPAN, rather than in the perl core.
176
177 See also L<Socket>
178
179 =item Lvalue subroutines
180
181 Introduced in Perl 5.6.0
182
183 Accepted in Perl 5.20.0
184
185 See also L<perlsub>
186
187 =item Backtracking control verbs
188
189 C<(*ACCEPT)>
190
191 Introduced in: Perl 5.10
192
193 Accepted in Perl 5.20.0
194
195 =item The <:pop> IO pseudolayer
196
197 See also L<perlrun>
198
199 Accepted in Perl 5.20.0
200
201 =back
202
203 =head2 Removed features
204
205 These features are no longer considered experimental and their functionality
206 has disappeared. It's your own fault if you wrote production programs using
207 these features after we explicitly told you not to (see L<perlpolicy>).
208
209 =over 8
210
211 =item 5.005-style threading
212
213 Introduced in Perl 5.005
214
215 Removed in Perl 5.10
216
217 =item perlcc
218
219 Introduced in Perl 5.005
220
221 Moved from Perl 5.9.0 to CPAN
222
223 =item The pseudo-hash data type
224
225 Introduced in Perl 5.6.0
226
227 Removed in Perl 5.9.0
228
229 =item GetOpt::Long Options can now take multiple values at once (experimental)
230
231 C<Getopt::Long> upgraded to version 2.35
232
233 Removed in Perl 5.8.8
234
235 =item Assertions
236
237 The C<-A> command line switch
238
239 Introduced in Perl 5.9.0
240
241 Removed in Perl 5.9.5
242
243 =item Test::Harness::Straps
244
245 Moved from Perl 5.10.1 to CPAN
246
247 =item C<legacy>
248
249 The experimental C<legacy> pragma was swallowed by the C<feature> pragma.
250
251 Introduced in: 5.11.2
252
253 Removed in: 5.11.3
254
255 =back
256
257 =head1 AUTHORS
258
259 brian d foy C<< <brian.d.foy@gmail.com> >>
260
261 SE<eacute>bastien Aperghis-Tramoni C<< <saper@cpan.org> >>
262
263 =head1 COPYRIGHT
264
265 Copyright 2010, brian d foy C<< <brian.d.foy@gmail.com> >>
266
267 =head1 LICENSE
268
269 You can use and redistribute this document under the same terms as Perl
270 itself.
271
272 =cut