Le jeudi 03 mai, Simon King a écrit:
> On the other hand: One could argue that the parent class can
> expect that some basic tools (such as __hash__ and __repr__) already
> work when being called. Hence, before calling __init__ of the parent
> class, one is supposed to make sure that the "tool chain" is provided.

The parent class cannot expect anything if it's initialization code
hasn't been called, can it?

> And one could argue that a commutative algebra is, in the *first*
> place, a commutative algebra, then in the *second* place it is an
> algebra, which is a module and a commutative ring (which then is a
> ring), which are parents. From that point of view, one would expect
> that the initialisation goes from the most specific to the most
> general - hence, *parallel* to the mro.

No, a commutative algebra is first an algebra, and then has some
additional properties. I never saw a book define them in the reverse
order...

> I simply don't know if there is any convention established (by that I
> mean: Documented, and I'd like to see a link) among Python developers,
> or at least among Sage developers.

Beware of conventions among sage developers : prefer conventions which
apply among many other opensource projects.

Here are some links (the last one is about C++ but it's still
interesting to know what is done elsewhere) :
http://stackoverflow.com/questions/1385759/should-init-call-the-parent-classs-init
http://stackoverflow.com/questions/6187042/inheritance-in-python-and-constructor-calls
http://stackoverflow.com/questions/120876/c-superclass-constructor-calling-rules


Snark on #sagemath

-- 
To post to this group, send an email to sage-devel@googlegroups.com
To unsubscribe from this group, send an email to 
sage-devel+unsubscr...@googlegroups.com
For more options, visit this group at http://groups.google.com/group/sage-devel
URL: http://www.sagemath.org

Reply via email to