This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Integrate the perlfork half of #9513 from maintperl into mainline
[perl5.git] / Todo-5.6
CommitLineData
6dd11d31 1Unicode support
d1edabcf 2 finish byte <-> utf8 and localencoding <-> utf8 conversions
6dd11d31
GS
3 add Unicode::Map equivivalent to core
4 add support for I/O disciplines
d1edabcf
GS
5 - a way to specify disciplines when opening things:
6 open(F, "<:crlf :utf16", $file)
7 - a way to specify disciplines for an already opened handle:
8 binmode(STDIN, ":slurp :raw")
9 - a way to set default disciplines for all handle constructors:
10 use open IN => ":any", OUT => ":utf8", SYS => ":utf16"
6dd11d31 11 eliminate need for "use utf8;"
d1edabcf 12 autoload byte.pm when byte:: is seen by the parser
560a288e 13 check uv_to_utf8() calls for buffer overflow
5396e592
JH
14 make \uXXXX (and \u{XXXX}?) where XXXX are hex digits
15 to work similarly to Unicode tech reports and Java
16 notation \uXXXX (and already existing \x{XXXX))?
17 more than four hexdigits? make also \U+XXXX work?
8fc17342
JH
18 overloadable regex assertions? e.g. in Thai \b cannot
19 be deduced by any simple character class boundary rules,
20 word boundaries must algorithmically computed
2c674647
JH
21
22 see ext/Encode/Todo for notes and references about proper detection
23 of malformed UTF-8
24
25 SCSU? http://www.unicode.org/unicode/reports/tr6/
26 Collation? http://www.unicode.org/unicode/reports/tr10/
27 Normalization? http://www.unicode.org/unicode/reports/tr15/
28 EBCDIC? http://www.unicode.org/unicode/reports/tr16/
29 Regexes? http://www.unicode.org/unicode/reports/tr18/
30 Case Mappings? http://www.unicode.org/unicode/reports/tr21/
31
5396e592 32 See also "Locales", "Regexen", and "Miscellaneous".
6dd11d31 33
d7d0d977 34Multi-threading
6dd11d31
GS
35 support "use Thread;" under useithreads
36 add mechanism to:
37 - create new interpreter in a different thread
38 - exchange data between interpreters/threads
39 - share namespaces between interpreters/threads
40 work out consistent semantics for exit/die in threads
41 support for externally created threads?
42 Thread::Pool?
d7d0d977
MB
43
44Compiler
45 auto-produce executable
46 typed lexicals should affect B::CC::load_pad
47 workarounds to help Win32
d7d0d977
MB
48 END blocks need saving in compiled output
49 _AUTOLOAD prodding
25f62d1c
MB
50 fix comppadlist (names in comppad_name can have fake SvCUR
51 from where newASSIGNOP steals the field)
d7d0d977 52
5152d7c7 53Namespace cleanup
6dd11d31
GS
54 CPP-space: restrict what we export from headers when !PERL_CORE
55 header-space: move into CORE/perl/?
56 API-space: complete the list of things that constitute public api
5152d7c7 57
45ebb638
JH
58Configure
59 make configuring+building away from source directory work (VPATH et al)
d57b1ce7 60 this is related to: cross-compilation configuring (see Todo)
da44fe2a 61 _r support (see Todo for mode detailed description)
1d82895f
JH
62 POSIX 1003.1 1996 Edition support--realtime stuff:
63 POSIX semaphores, message queues, shared memory, realtime clocks,
64 timers, signals (the metaconfig units mostly already exist for these)
5b0d9cef 65 PREFERABLY AS AN EXTENSION
1d82895f 66 UNIX98 support: reader-writer locks, realtime/asynchronous IO
5b0d9cef 67 PREFERABLY AS AN EXTENSION
da44fe2a 68 IPv6 support: see RFC2292, RFC2553
5b0d9cef 69 PREFERABLY AS AN EXTENSION
497711e7 70 there already is Socket6 in CPAN
45ebb638 71
fe32fb73
JH
72Long doubles
73 figure out where the PV->NV->PV conversion gets it wrong at least
74 in AIX and Tru64 (V5.0 and onwards) when using long doubles: see the
55f6b6ec
JH
75 regexp tricks we had to insert to t/comp/use.t and t/lib/bigfltpm.t,
76 (?:9|8999\d+) and the like.
77
7864-bit support
79 Configure probe for quad_t, uquad_t, and (argh) u_quad_t, they might
80 be in some systems the only thing working as quadtype and uquadtype.
5b0d9cef 81 more pain: long_long, u_long_long.
fe32fb73 82
45ebb638 83Locales
6dd11d31 84 deprecate traditional/legacy locales?
8bce6328 85 How do locales work across packages?
6dd11d31 86 figure out how to support Unicode locales
1d82895f 87 suggestion: integrate the IBM Classes for Unicode (ICU)
8bce6328 88 http://oss.software.ibm.com/developerworks/opensource/icu/project/
592fe524
JH
89 ICU is "portable, open-source Unicode library with:
90 charset-independent locales (with multiple locales
91 simultaneously supported in same thread; character
92 conversions; formatting/parsing for numbers, currencies,
93 date/time and messages; message catalogs (resources);
94 transliteration, collation, normalization, and text
95 boundaries (grapheme, word, line-break))".
96 Check out also the Locale Converter:
1d82895f 97 http://alphaworks.ibm.com/tech/localeconverter
592fe524 98 There is also the iconv interface, either from XPG4 or GNU (glibc).
8bce6328
JH
99 iconv is about character set conversions.
100 Either ICU or iconv would be valuable to get integrated
fe32fb73 101 into Perl, Configure already probes for libiconv and <iconv.h>.
45ebb638
JH
102
103Regexen
6dd11d31 104 make RE engine thread-safe
e620704b
JH
105 a way to do full character set arithmetics: now one can do
106 addition, negate a whole class, and negate certain subclasses
107 (e.g. \D, [:^digit:]), but a more generic way to add/subtract/
108 intersect characters/classes, like described in the Unicode technical
109 report on Regular Expression Guidelines,
110 http://www.unicode.org/unicode/reports/tr18/
111 (amusingly, the TR notes that difference and intersection
112 can be done using "Perl-style look-ahead")
113 difference syntax? maybe [[:alpha:][^abc]] meaning
114 "all alphabetic expect a, b, and c"? or [[:alpha:]-[abc]]?
115 (maybe bad, as we explicitly disallow such 'ranges')
116 intersection syntax? maybe [[..]&[...]]?
b8c5462f 117 POSIX [=bar=] and [.zap.] would nice too but there's no API for them
1d82895f
JH
118 =bar= could be done with Unicode, though, see the Unicode TR #15 about
119 normalization forms:
120 http://www.unicode.org/unicode/reports/tr15/
121 this is also a part of the Unicode 3.0:
122 http://www.unicode.org/unicode/uni2book/u2.html
123 executive summary: there are several different levels of 'equivalence'
592fe524
JH
124 trie optimization: factor out common suffixes (and prefixes?)
125 from |-alternating groups (both for exact strings and character
126 classes, use lookaheads?)
45ebb638
JH
127 approximate matching
128
19e16c31
JH
129Security
130 use fchown, fchmod (and futimes?) internally when possible
131 use fchdir(how portable?)
fe32fb73
JH
132 create secure reliable portable temporary file modules
133 audit the standard utilities for security problems and fix them
19e16c31 134
5152d7c7 135Reliable Signals
54aff467 136 custom opcodes
5152d7c7
GS
137 alternate runops() for signal despatch
138 figure out how to die() in delayed sighandler
6dd11d31 139 make Thread::Signal work under useithreads
5152d7c7
GS
140
141Win32 stuff
6dd11d31 142 sort out the spawnvp() mess for system('a','b','c') compatibility
5152d7c7 143 work out DLL versioning
5152d7c7
GS
144
145Miscellaneous
157fa422 146 introduce @( and @) because group names can have spaces
0ff51efc 147 add new modules (Archive::Tar, Compress::Zlib, CPAN::FTP?)
fe32fb73
JH
148 sub-second sleep()? alarm()? time()? (integrate Time::HiRes?
149 Configure doesn't yet probe for usleep/nanosleep/ualarm but
150 the units exist)
151 floating point handling: nans, infinities, fp exception masks, etc.
a3540c92
JH
152 At least the following interfaces exist: fp_classify(), fp_class(),
153 class(), isinf(), isfinite(), finite(), isnormal(), unordered(),
154 <ieeefp.h>, <fp_class.h> (there are metaconfig units for all these),
155 fp_setmask(), fp_getmask(), fp_setround(), fp_getround()
156 (no metaconfig units yet for these).
157 Don't forget finitel(), fp_classl(), fp_class_l(), (yes, both do,
158 unfortunately, exist), and unorderedl().
5b0d9cef 159 PREFERABLY AS AN EXTENSION.
a3540c92 160 As of 5.6.1 there is cpp macro Perl_isnan().
fe32fb73 161 fix the basic arithmetics (+ - * / %) to preserve IVness/UVness if
157fa422
JH
162 both arguments are IVs/UVs: it sucks that one cannot see
163 the 'carry flag' (or equivalent) of the CPU from C,
164 C is too high-level...
6dd11d31 165 replace pod2html with new PodtoHtml? (requires other modules from CPAN)
245ccdfc 166 automate testing with large parts of CPAN
fe32fb73
JH
167 turn Cwd into an XS module? (Configure already probes for getcwd())
168 mmap for speeding up input? (Configure already probes for the mmap family)
169 sendmsg, recvmsg? (Configure doesn't probe for these but the units exist)
1e94dd5d 170 sockatmark?
55f6b6ec 171 setitimer, getitimer? (the metaconfig units exist)
245ccdfc
GS
172
173Ongoing
174 keep filenames 8.3 friendly, where feasible
175 upgrade to newer versions of all independently maintained modules
9cc29783 176 comprehensive perldelta.pod
5152d7c7 177
d7d0d977 178Documentation
5152d7c7
GS
179 describe new age patterns
180 update perl{guts,call,embed,xs} with additions, changes to API
c6018dae 181 convert more examples to use autovivified filehandles
5152d7c7 182 document Win32 choices
5152d7c7 183 spot-check all new modules for completeness
11162842 184 better docs for pack()/unpack()
245ccdfc 185 reorg tutorials vs. reference sections
497711e7
GS
186 make roffitall to be dynamical about its pods and libs
187