[Python-3000] PEP 3124 - Overloading, Generic Functions, Interfaces, etc.
Paul Moore
p.f.moore at gmail.com
Fri May 11 10:40:27 CEST 2007
On 11/05/07, Greg Ewing <greg.ewing at canterbury.ac.nz> wrote:
> I'm now even more of the opinion that this is too
> complicated for Python's first generic function system.
> "If it's hard to explain, it's probably a bad idea."
Hmm. My view is that it *is* simple to explain, but unfortunately
Phillip's explanation in the PEP is not that simple explanation :-(
In my view, too much of the PEP is taken up with edge cases,
relatively obscure specialist uses, and unnecessary explanations of
implementation details. However, I haven't had any time recently to
review it in enough detail to offer a concrete proposal on how to
simplify it, so I've kept quiet so far.
I would argue that the PEP could be *very* simple if it restricted
itself to the basic idea. Much of what is being discussed is, in my
view, implementation detail - which Phillip finds compelling because
it shows the power of the basic approach, but which is turning others
off because it's more complex and subtle than a basic use case.
There are many features in Python which are powerful and simple on the
surface, but get quite gory when you delve beneath the covers
(new-style classes, decorators, generators, for example). That doesn't
mean they shouldn't be there.
Paul.
More information about the Python-3000
mailing list