Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.python > #102503

Re: Efficient Wrappers for Instance Methods

From Random832 <random832@fastmail.com>
Newsgroups comp.lang.python
Subject Re: Efficient Wrappers for Instance Methods
Date 2016-02-04 13:35 -0500
Message-ID <mailman.69.1454610940.30993.python-list@python.org> (permalink)
References (4 earlier) <56B26D3D.6040703@mail.de> <n8tqt8$8m8$1@ger.gmane.org> <56B2747B.6050209@mail.de> <1454543258.197018.511336178.74125AA7@webmail.messagingengine.com> <56B379CD.5090903@mail.de>

Show all headers | View raw


On Thu, Feb 4, 2016, at 11:18, Sven R. Kunze wrote:
> On 04.02.2016 00:47, Random832 wrote:
> > On Wed, Feb 3, 2016, at 16:43, Sven R. Kunze wrote:
> >> Actually a nice idea if there were no overhead of creating methods for
> >> all heap instances separately. I'll keep that in mind. :)
> > What about changing the class of the object to one which is inherited
> > from its original class and has the method you want? What about reaching
> > into the class and changing the method in the first place? Either may
> > not be appropriate, of course, depending on your use case.
> 
> There is no base class.

I meant something like...

Class C:
    replace = heapreplace

Cs = {}

...

if not isinstance(x, C)
    T = type(x)
    cls = cache.get(T)
    if cls is None:
       cls = type('C_'+T.__name__, (C, T), {})
    x.__class__ = cls

(Of course, by dynamically reassigning __class__ and using the type
constructor, this checks two of the three "crazy type system voodoo"
boxes. I have no idea if it will work, or if I've made a mistake, or if
you'll be able to understand it in six months.)

Back to comp.lang.python | Previous | Next | Find similar | Unroll thread


Thread

Re: Efficient Wrappers for Instance Methods Random832 <random832@fastmail.com> - 2016-02-04 13:35 -0500

csiph-web