<div dir="ltr">Wow. Awesome. I will make time to study what you have already done!<br></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Aug 13, 2014 at 2:08 PM, Andrey Vlasovskikh <span dir="ltr"><<a href="mailto:andrey.vlasovskikh@gmail.com" target="_blank">andrey.vlasovskikh@gmail.com</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">2014-08-14, 0:19, Guido van Rossum <<a href="mailto:guido@python.org">guido@python.org</a>> wrote:<br>


<br>
> Yesterday afternoon I had an inspiring conversation with Bob Ippolito (man of many trades, author of simplejson) and Jukka Lehtosalo (author of mypy: <a href="http://mypy-lang.org/" target="_blank">http://mypy-lang.org/</a>). Bob gave a talk at EuroPython about what Python can learn from Haskell (and other languages); yesterday he gave the same talk at Dropbox. The talk is online (<a href="https://ep2014.europython.eu/en/schedule/sessions/121/" target="_blank">https://ep2014.europython.eu/en/schedule/sessions/121/</a>) and in broad strokes comes down to three suggestions:<br>


><br>
>  (a) Python should adopt mypy's syntax for function annotations<br>
<br>
<br>
</div>+1. I'm a developer of the code analysis engine of PyCharm. I have discussed this idea with Jukka Lehtosalo and recently with Dave Halter, the author of Jedi code completion library. Standardized type annotations would be very useful for code analysis tools and IDEs such as PyCharm, Jedi and pylint. Type annotations would be especially great for third-party libraries. The idea is that most Python programmers don't have to write annotations in order to benefit from them. Annotated libraries are often enough for good code analysis.<br>


<br>
We (PyCharm) and Jukka have made some initial steps in this direction, including thoughts on semantics of annotations (<a href="https://github.com/pytypes/pytypes" target="_blank">https://github.com/pytypes/pytypes</a>). Feedback is welcome.<br>


<br>
Here are slides from my talk about optional typing in Python, that show how Mypy types can be used in both static and dynamic type checking (<a href="http://blog.pirx.ru/media/files/2013/python-optional-typing/" target="_blank">http://blog.pirx.ru/media/files/2013/python-optional-typing/</a>), Mypy-related part starts from slide 14.<br>


<br>
We are interested in getting type annotations standardized and we would like to help developing and testing type annotations proposals.<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Andrey Vlasovskikh<br>
Web: <a href="http://pirx.ru/" target="_blank">http://pirx.ru/</a><br>
<br>
</font></span></blockquote></div><br><br clear="all"><br>-- <br>--Guido van Rossum (<a href="http://python.org/~guido">python.org/~guido</a>)
</div>