[asperl] add AS patch#20 (exposes more global constants)
[p5sagit/p5-mst-13.2.git] / Todo
diff --git a/Todo b/Todo
index 495be2e..ab28e00 100644 (file)
--- a/Todo
+++ b/Todo
@@ -1,37 +1,59 @@
-* Fixes
+Tie Modules
+       VecArray                Implement array using vec()
+       SubstrArray             Implement array using substr()
+       VirtualArray            Implement array using a file
+       ShiftSplice             Defines shift et al in terms of splice method
 
-CC backend: goto, sort with non-default comparison. last for non-loop blocks.
-Version checking
-improve XSUB handling (both static and dynamic)
-sv_magic can do SvREFCNT_inc(obj) which messes up precalculated refcounts
-allocation of XPV[INAHC]V structures needs fixing: Perl tries to free
-them whereas the compiler expects them to be linked to a xpv[inahc]v_root
-list the same as X[IPR]V structures.
-ref counts
-perl_parse replacement
-fix cstring for long strings
-compile-time initialisation of AvARRAYs
-signed/unsigned problems with NV (and IV?) initialisation and elsewhere?
-CvOUTSIDE for ordinary subs
-DATA filehandle for standalone Bytecode program (easy)
-DATA filehandle for multiple bytecode-compiled modules (harder)
-DATA filehandle for C-compiled program (yet harder)
+Would be nice to have
+       pack "(stuff)*"
+       Contiguous bitfields in pack/unpack
+       lexperl
+       Bundled perl preprocessor
+       Use posix calls internally where possible
+       gettimeofday
+       format BOTTOM
+       -iprefix.
+       -i rename file only when successfully changed
+       All ARGV input should act like <>
+       report HANDLE [formats].
+       support in perlmain to rerun debugger
+       regression tests using __DIE__ hook
+       reference to compiled regexp
+       lexically scoped functions: my sub foo { ... }
+       lvalue functions
+       Full 64 bit support
 
-* Features
+Possible pragmas
+       debugger
+       optimize (use less memory, CPU)
 
-type checking
-compile time v. runtime initialisation
-save PMOPs in compiled form
-selection of what to dump
-options for cutting out line info etc.
-comment output
-shared constants
-module dependencies
+Optimizations
+       constant function cache
+       switch structures
+       eval qw() at compile time
+       foreach (1..1000000)
+       foreach(reverse...)
+       Set KEEP on constant split
+       Cache eval tree (unless lexical outer scope used (mark in &compiling?))
+       rcatmaybe
+       Shrink opcode tables via multiple implementations selected in peep
+       Cache hash value?  (Not a win, according to Guido)
+       Optimize away @_ where possible
+       "one pass" global destruction
+       Optimize sort by { $a <=> $b }
+       Rewrite regexp parser for better integrated optimization
+       LRU cache of regexp: foreach $pat (@pats) { foo() if /$pat/ }
+
+Vague possibilities
+       ref function in list context
+       data prettyprint function?  (or is it, as I suspect, a lib routine?)
+       make tr/// return histogram in list context?
+       Loop control on do{} et al
+       Explicit switch statements
+       built-in globbing
+       compile to real threaded code
+       structured types
+       autocroak?
+       Modifiable $1 et al
+       substr EXPR,OFFSET,LENGTH,STRING
 
-* Optimisations
-collapse LISTOPs to UNOPs or BASEOPs
-compile-time qw(), constant subs
-global analysis of variables, type hints etc.
-demand-loaded bytecode (leader of each basic block replaced by an op
-which loads in bytecode for its block)
-fast sub calls for CC backend