Brett Cannon | 23cbd8a | 2009-01-18 00:24:28 +0000 | [diff] [blame] | 1 | to do |
2 | ///// | ||||
3 | |||||
Brett Cannon | c1761b7 | 2009-02-09 21:51:29 +0000 | [diff] [blame] | 4 | * Refactor source/bytecode finder/loader code such that bytecode support is a |
5 | subclass of source support (makes it nicer for VMs that don't use CPython | ||||
6 | bytecode). | ||||
7 | |||||
Brett Cannon | 4afab6b | 2009-02-21 03:31:35 +0000 | [diff] [blame] | 8 | + PyLoader (for ABC) |
Brett Cannon | 33dbf46 | 2009-02-17 07:15:17 +0000 | [diff] [blame] | 9 | |
Brett Cannon | 0515619 | 2009-02-21 03:53:06 +0000 | [diff] [blame^] | 10 | - load_module for source only |
Brett Cannon | 33dbf46 | 2009-02-17 07:15:17 +0000 | [diff] [blame] | 11 | - get_code for source only |
Brett Cannon | 4afab6b | 2009-02-21 03:31:35 +0000 | [diff] [blame] | 12 | |
13 | + PyFileLoader(PyLoader) | ||||
14 | |||||
Brett Cannon | 33dbf46 | 2009-02-17 07:15:17 +0000 | [diff] [blame] | 15 | - get_data |
16 | - source_mtime | ||||
17 | - source_path | ||||
18 | |||||
Brett Cannon | 4afab6b | 2009-02-21 03:31:35 +0000 | [diff] [blame] | 19 | +PyPycLoader (PyLoader, for ABC) |
Brett Cannon | 33dbf46 | 2009-02-17 07:15:17 +0000 | [diff] [blame] | 20 | |
Brett Cannon | 0515619 | 2009-02-21 03:53:06 +0000 | [diff] [blame^] | 21 | - load_module for source and bytecode |
Brett Cannon | 4afab6b | 2009-02-21 03:31:35 +0000 | [diff] [blame] | 22 | - get_code for source and bytecode |
23 | |||||
24 | + PyPycFileLoader(PyPycLoader, PyFileLoader) | ||||
25 | |||||
Brett Cannon | 33dbf46 | 2009-02-17 07:15:17 +0000 | [diff] [blame] | 26 | - bytecode_path |
27 | - write_bytecode | ||||
28 | |||||
Brett Cannon | d0005ff | 2009-01-26 01:54:40 +0000 | [diff] [blame] | 29 | * Implement PEP 302 protocol for loaders (should just be a matter of testing). |
30 | |||||
Brett Cannon | d0005ff | 2009-01-26 01:54:40 +0000 | [diff] [blame] | 31 | + Source/bytecode. |
32 | |||||
Brett Cannon | 6411aa5 | 2009-02-06 00:07:49 +0000 | [diff] [blame] | 33 | * Public API left to expose (w/ docs!) |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 34 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 35 | + abc |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 36 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 37 | - Finder |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 38 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 39 | * find_module |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 40 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 41 | - Loader |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 42 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 43 | * load_module |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 44 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 45 | - (?) Importer(Finder, Loader) |
46 | - ResourceLoader(Loader) | ||||
Brett Cannon | 6411aa5 | 2009-02-06 00:07:49 +0000 | [diff] [blame] | 47 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 48 | * get_data |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 49 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 50 | - InspectLoader(Loader) |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 51 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 52 | * is_package |
53 | * get_code | ||||
54 | * get_source | ||||
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 55 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 56 | - (?) SourceLoader(ResourceLoader) |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 57 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 58 | * source_path |
59 | * bytecode_path | ||||
60 | * write_bytecode (not abstract) | ||||
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 61 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 62 | + util |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 63 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 64 | - set___package__ decorator |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 65 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 66 | + machinery |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 67 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 68 | - Extensions importers |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 69 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 70 | * ExtensionFinder |
71 | * (?) Loader | ||||
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 72 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 73 | - Source/bytecode importers |
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 74 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 75 | * SourceFinder |
76 | * (?) Loader | ||||
Brett Cannon | 5abdc93 | 2009-01-22 22:43:07 +0000 | [diff] [blame] | 77 | |
Brett Cannon | 22db67e | 2009-02-21 02:51:12 +0000 | [diff] [blame] | 78 | + test (Really want to worry about compatibility with future versions?) |
Brett Cannon | 24b6a2c | 2009-01-18 00:36:55 +0000 | [diff] [blame] | 79 | |
Brett Cannon | d2e7b33 | 2009-02-17 02:45:03 +0000 | [diff] [blame] | 80 | - abc |
81 | |||||
82 | * FinderTests [doc] | ||||
83 | * LoaderTests [doc] | ||||
Brett Cannon | 2c318a1 | 2009-02-07 01:15:27 +0000 | [diff] [blame] | 84 | |
Brett Cannon | a2fcb1d | 2009-02-21 03:12:17 +0000 | [diff] [blame] | 85 | * Remove ``import *`` from importlib.__init__. |
86 | |||||
87 | * Remove __all__ from importlib._bootstrap. | ||||
88 | |||||
89 | * Add leading underscores to all objects in importlib._bootstrap that are not | ||||
90 | publicly exposed. | ||||
91 | |||||
Brett Cannon | debb98d | 2009-02-16 04:18:01 +0000 | [diff] [blame] | 92 | * Make sure that there is documentation *somewhere* fully explaining the |
93 | semantics of import that can be referenced from the package's documentation | ||||
94 | (even if it is in the package documentation itself, although it might be best | ||||
95 | in the language specification). | ||||
96 | |||||
Brett Cannon | 20b56e1 | 2009-02-01 05:55:23 +0000 | [diff] [blame] | 97 | * Write benchmark suite. |
98 | |||||
99 | * OPTIMIZE! | ||||
100 | |||||
Brett Cannon | 6411aa5 | 2009-02-06 00:07:49 +0000 | [diff] [blame] | 101 | + Fast path absolute name. |
102 | + Fast path pulling from sys.modules. | ||||
Brett Cannon | 20b56e1 | 2009-02-01 05:55:23 +0000 | [diff] [blame] | 103 | |
Brett Cannon | 24b6a2c | 2009-01-18 00:36:55 +0000 | [diff] [blame] | 104 | * Bootstrap importlib as implementation of builtins.__import__ |
Brett Cannon | 438cecd | 2009-02-02 20:32:29 +0000 | [diff] [blame] | 105 | |
106 | * Replace standard library modules. | ||||
107 | |||||
108 | + imp | ||||
109 | + py_compile | ||||
110 | + compileall |