<div dir="auto"><div><br><br><div class="gmail_quote"><div dir="ltr">Le sam. 11 août 2018 à 10:34, Vincent Maillol <<a href="mailto:vincent.maillol@gmail.com" target="_blank" rel="noreferrer">vincent.maillol@gmail.com</a>> a écrit :<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div>Hello,<br><br>Currently the user defined functions are mutables, there can be existed python codes like this:<br><br><span style="font-family:monospace,monospace">>>> def foo():<br>...     pass<br>... <br>>>> if not hasattr(foo, 'partial'):<br>...     foo.partial = {}<br>... <br><br></span></div><span style="font-family:arial,helvetica,sans-serif">Adding a new method to function object can break existing projects, but it is without impact with buit-in functions because they are immutable</span><span style="font-family:monospace,monospace">s.<br></span><div><br></div></div><div class="gmail_extra"></div></blockquote></div></div><div dir="auto"><br></div><div dir="auto">Or use a decorator like in the lib ?</div><div dir="auto"><br></div><div dir="auto">from funcoperators import partially</div><div dir="auto"><br></div><div dir="auto">@partially</div><div dir="auto">def f(x, y):</div><div dir="auto">    return x-y</div><div dir="auto"><br></div><div dir="auto">g = f.part(4)</div><div dir="auto">g(5)</div><div dir="auto"><br></div><div dir="auto">The mutability solution however cannot have a "self" argument :</div><div dir="auto"><br></div><div dir="auto">def f(x,y):</div><div dir="auto">    return x-y</div><div dir="auto"><br></div><div dir="auto">f.stuff = lambda self: self(5, 2)</div><div dir="auto">f.stuff()  # missing self</div><div dir="auto"><br></div><div dir="auto">One would have to give "f".</div><div dir="auto"><br></div><div dir="auto">f.partial = lambda *a, **b: functools.partial(f, *a, **b)</div><div dir="auto"><br></div><div dir="auto">g = f.partial(4)</div><div dir="auto">g(5)</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="gmail_extra"><br><div class="gmail_quote">2018-08-09 18:59 GMT+02:00 Michel Desmoulin <span dir="ltr"><<a href="mailto:desmoulinmichel@gmail.com" rel="noreferrer noreferrer" target="_blank">desmoulinmichel@gmail.com</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I'd rather have functools.partial() to be added as a new method on<br>
function objects.<br>
<br>
><br>
> fromfunctools importpartial<br>
><br>
><br>
> def add(x:int,y:int)->int:<br>
>     returnx +y<br>
><br>
><br>
> add_2 = partial(add,2)<br>
><br>
<br>
Would become:<br>
<br>
add_2 = add.partial(2)<br>
<br>
Nothing to change on the parser, no obscure syntax for future readers,<br>
and we can get the opportunity of rewriting partial() in C as right now<br>
it is amazingly way, way slower than a lambda.<br>
_______________________________________________<br>
Python-ideas mailing list<br>
<a href="mailto:Python-ideas@python.org" rel="noreferrer noreferrer" target="_blank">Python-ideas@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/python-ideas" rel="noreferrer noreferrer noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/python-ideas</a><br>
Code of Conduct: <a href="http://python.org/psf/codeofconduct/" rel="noreferrer noreferrer noreferrer" target="_blank">http://python.org/psf/codeofconduct/</a><br>
</blockquote></div><br></div>
_______________________________________________<br>
Python-ideas mailing list<br>
<a href="mailto:Python-ideas@python.org" rel="noreferrer noreferrer" target="_blank">Python-ideas@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/python-ideas" rel="noreferrer noreferrer noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/python-ideas</a><br>
Code of Conduct: <a href="http://python.org/psf/codeofconduct/" rel="noreferrer noreferrer noreferrer" target="_blank">http://python.org/psf/codeofconduct/</a><br>
</blockquote></div></div></div>