[Python-Dev] PEP 443 - Single-dispatch generic functions (original) (raw)

Sam Partington sam.partington at gmail.com
Fri May 24 11:54:27 CEST 2013


On 23 May 2013 22:02, Ronan Lamy <ronan.lamy at gmail.com> wrote:

2013/5/23 Ɓukasz Langa <lukasz at langa.pl>

Last one wins. Just like with assigning names in a scope, defining methods in a class or overriding them in a subclass. This is a serious annoyance, considering that there are several places where a large library can reasonably define the implementations (i.e. with the class, with the function, or in some utility module). Note that in contrast with the case of functions in a module or methods in a class, linting tools cannot be expected to detect a duplication between functions with different names defined in different modules.

But isn't it much much worse than names in scope, as with assigning names in a scope it is only your scope that is affected :

from os.path import join def join(wibble): 'overloads join in this module only'

any other module is unaffected, os.path.join still calls os.path.join

however with this all scopes globally are affected by the last one wins rule.

-----default.py------- from pkgutil import simplegeneric

@simplegeneric def fun(x): print 'default impl'

-------a.py-------- from default import fun

@fun.register(int) def impl_a(x): print 'impl_a'

def f(): fun(0) # expect this to call impl_a

-------b.py------ from default import fun

@fun.register(int) def impl_b(x): print 'impl_b'

def f(): fun(0) # expect this to call impl_b


import a, b a.f() impl_b b.f() impl_b

import b, a a.f() impl_a b.f() impl_a exit()

That is rather worrying. It is more analagous in the above example to sys.modules['os.path'].join = myjoin

I don't have a solution mind though.

Sam



More information about the Python-Dev mailing list