[Python-ideas] 'Injecting' objects as function-local constants

Terry Reedy tjreedy at udel.edu
Fri Jun 17 22:58:56 CEST 2011


On 6/17/2011 9:26 AM, Nick Coghlan wrote:

> This is why the nonlocal and global directives exist: to tell the
> compiler to change how it treats certain names. Arguments (including
> the associated default values) are given additional special treatment
> due to their placement in the function header. If we want to create a
> new namespace that is given special treatment by the compiler,

I do not really want a new namespace and for the purpose of the OP, 
named local constants (for speed or freezing the meaning of an 
expression or both), we do not need one. There is already a fourth 
'namespace' for constants, a tuple f.__code__.co_consts, whose 'names' 
are indexes, just as with the locals array. Given

def f(a, **, b=1001, len = len): return 2001 # one possible spelling

def f(a):                                    # alternate
     constant b = 1001, len = len
     return 2001

the compiler should put 1001 and len into co.consts and convert 'b' and 
'len' into the corresponding indexes, just like it does with 'a', and 
use the LOAD_CONST bytecode just as with literal constants like 2001 in 
the body. Constant names would not go into .co_names and not increment 
.co_argcount. This would make named constants as fast and def-time 
frozen as default args without the disadvantages of being included in 
the signature and over-writable on calls.

-- 
Terry Jan Reedy




More information about the Python-ideas mailing list