IronPython 1.0 released today!


I’m extremely happy to announce that we have released IronPython 1.0 today!


I started work on IronPython almost 3 years ago.  My initial motivation for the project was to understand all of the reports that I read on the web claiming that the Common Language Runtime (CLR) was a terrible platform for Python and other dynamic languages.  I was surprised to read these reports because I knew that the JVM was an acceptable platform for these languages.  About 9 years ago I’d built an implementation of Python that ran on the JVM originally called JPython and later shortened to Jython.  This implementation ran a little slower than the native C-based implementation of Python (CPython), but it was easily fast enough and stable enough for production use – testified to by the large number of Java projects that incorporate Jython today.


I wanted to understand how Microsoft could have screwed up so badly that the CLR was a worse platform for dynamic languages than the JVM.  My plan was to take a couple of weeks to build a prototype implementation of Python on the CLR and then to use that work to write a short pithy article called, “Why the CLR is a terrible platform for dynamic languages”.  My plans quickly changed as I worked on the prototype, because I found that Python could run extremely well on the CLR – in many cases noticeably faster than the C-based implementation.  For the standard pystone benchmark, IronPython on the CLR was about 1.7x faster than the C-based implementation.


The more time I spent working on IronPython and with the CLR, the more excited I became about its potential to finally deliver on the vision of a single common platform for a broad range of languages.  At that same time, I was invited to come out to Microsoft to present IronPython and to talk with members of the CLR team about technical issues that I was running into.  I had a great time that day working through these issues with a group of really smart people who all had a deep understanding of virtual machines and language implementation.  After much reflection, I decided to join the CLR team at Microsoft where I could work with the platform to make it an even better target for dynamic languages and be able to have interesting technical discussions like that every day.


The first few months at Microsoft were a challenge as I learned what was involved in working at a large company.  However, once the initial hurdle was over I started experiencing the things that motivated me to come here in the first place.  The team working on dynamic languages in general and IronPython in particular began to grow and I got to have those great technical discussions again about both how to make IronPython as good as it could be and how to make the CLR an even better platform.  We began to take advantage of the great new features for dynamic languages already shipping in .NET 2.0 such as DynamicMethods, blindingly fast delegates and a new generics system that was seamlessly integrated with the existing reflection infrastructure.


We were also able to release IronPython publicly from Microsoft with a BSD-style license.  In the agile spirit of the project, we put out a new release of IronPython once every three weeks (on average) over the course of the project.  This helped us connect well with our daring early adopters and receive and incorporate their feedback to make IronPython better.  We’ve had countless excellent discussions on the mailing list on everything from supporting value types to calling overloaded methods.  Without the drive and input of our users, IronPython would be a much weaker project.


IronPython is about bringing together two worlds.  The key value in IronPython is that it is both a true implementation of Python and is seamlessly integrated with the .NET platform.  Most features were easy and natural choices where the language and the platform fit together with almost no work.  However, there were challenges from the obvious cases like exception type hierarchies to the somewhat esoteric challenges concerning different methods on strings. We spent long days and sometimes weeks looking for the best answers to these challenging problems and in the end I think that we have stayed true to both Python and .NET.


To drive our Python compatibility, we run a large portion of the standard Python regression test suite in addition to a large custom test suite we added that runs IronPython and CPython side-by-side to test for identical behavior whenever possible.  Despite all of this work, there will still be differences between IronPython 1.0 and CPython.  The most obvious difference is that IronPython is missing a number of standard C-based extension modules so things like “import bsddb” will fail.  We maintain a detailed list of differences between the two implementations and aim to reduce the size of this list in every release.


IronPython has also striven for deep integration with the CLR.  For the implementation this is a great thing as it lets us take advantage of highly-tuned components developed for other languages such as the just-in-time compiler, garbage collector, debugging support, reflection, dynamic loading and more.  This integration is also valuable to IronPython developers as it lets them easily use any and all libraries built for .NET from their Python code.


This is the 1.0 release of IronPython.  It’s more complete and well tested than any other 1.0 product I have personally released in my career.  However, like any other software product it’s not perfect.  You can search for known issues and let us know about any new ones that you find in our public bug database.  We’re continuing to work on IronPython and we want your input on how to make 1.1 and future releases even better.


It’s been an exciting journey for me to see IronPython go from a rough prototype playing around with some ideas to a solid 1.0 release.  This never could have happened without all the people who’ve contributed to this project along the way.  My thanks go out to all the users who braved our early releases and passed along their problems and suggestions.  My thanks also go out to the amazing group of people here at Microsoft who’ve come to join this project and drive it to this quality 1.0 release.


Shipping IronPython 1.0 isn’t the end of the road, but rather the beginning.  Not only will we continue to drive IronPython forward but we’re also looking at the bigger picture to make all dynamic languages deeply integrated with the .NET platform and with technologies and products built on top of it.  I’m excited about how far we’ve come, but even more excited by what the future holds!


Thanks – Jim Hugunin (for the IronPython Team)


Comments (62)

  1. IronPython is a project that implements the dynamic object-oriented Python language on top of the CLI. …

  2. Congratulations to the IronPython team for releasing their final version of V1.0 for production…

  3. me says:

    Congratulations!

    All of the hard work is really appreciated.

    I look forward to see how support for dynamic languages is improved in future versions of the CLR.

  4. You’ve been kicked (a good thing) – Trackback from DotNetKicks.com

  5. You probably already read this 100 times, but Iron Python 1.0 is released. Check out Jim Hugunin’s reflections…

  6. DaHcn says:

    Excellent language! I’ll start to play with it

  7. Implementacja języka Python dla platformy .NET, czyli IronPython, doczekała się wersji 1.0. Warto zauważyć,

  8. I just read the announcement on James Huguin’s blog, that he and his team released IronPython…

  9. Mike says:

    Good job! Interesting read, I will try it out.

    Any word on wether this will ship integrated with Visual Studio 2005 (maybe a service pack)?

  10. Kurt Christensen says:

    This is outstanding, but are there any plans to provide any support for it within Visual Studio?

  11. IronPython is a Microsoft sponsored open source implementation of the Python dynamic programming language on Microsoft’s .NET framework and version 1.0 was formally released yesterday…

  12. Scott Guthrie has announced the release of V1.0 of the IronPython project for .NET, avialable for download

  13. Ron Bodkin says:

    Congratulations Jim and team: it’s great to see you achieve this milestone!

  14. sfb says:

    Three cheers for you and the IronPython team!

  15. <blockquote>This integration is also valuable to IronPython developers as it lets them easily use any and all libraries built for .NET from their Python code.</blockquote>

    It bears repeating that the IronPython license is no kind of safe-harbor for developing open-source applications on top of Microsoft’s platform. Specifically, if you want to license your application as GPL (and you may have important strategic business reasons for doing so), IronPython’s license itself won’t hinder you, but you probably cannot import many of those libraries.

  16. IronPython 1.0 has been&amp;nbsp;released yesterday!&amp;nbsp; I fondly remember using Python when I was in college…

  17. B# .NET Blog says:

    Dynamic programming language lovers or Python die-hards, check out this great release of IronPython 1.0…

  18. Via Stefan, here is a pragmatic posting that cogently explains that the enterprise software picture isn’t as black and white as folks who constantly engage in the &quot;enterprise vs. enterprisey&quot; battle wish it were. I especially like the &quot;Enterprise-Class

  19. baus says:

    Great work.  Thanks for bringing python to .NET.  Ship it with Visual Studio!

  20. Jim Hugunin says:

    There have been several question about IronPython and Visual Studio.  IronPython has no official VS integration; however, the VS SDK provides fairly rich IronPython integration as a sample which is available with complete sources.  To use this integration you have to be willing to deal with installing the VS SDK and building from sources.  More information is available here:

    http://blogs.msdn.com/aaronmar/archive/2006/02/16/533273.aspx

  21. As has been announced all over the Internet, the IronPython team shipped their 1.0 release this past…

  22. This week Jim Hugunin, lead architect on the CLR-team for IronPython, announced the release of IronPython…

  23. The IronPython and JRuby announcements have been making the rounds in the blogosphere. and of course I want to add my 2c.  I think that these announcements are very significant and should be welcomed by people in both the Python and Ruby communities,

  24. tecosystems says:

    Remember the good old days, when the language landscape was a simple two party battle, defined by Microsoft and .NET on the one hand, with Java and virtually every other large ISV on the other? Yeah, me neither. While I’m…

  25. Software says:

    Ruby &amp; Phyton are just some of the dynamic languages that I&#39;ve been hearing about quite a bit

  26. As has been announced all over the Internet, the IronPython team shipped their 1.0 release this past

  27. An interesting series of events have taken place over the last few months in regards to the .NET Framework.

  28. I know when I think about .Net programming languages the first thing that pops into my head is "C#" followed

  29. I know when I think about .Net programming languages the first thing that pops into my head is &quot;C#&quot;

  30. I know when I think about .Net programming languages the first thing that pops into my head is &quot;C#&quot;

  31. Mono.Cecil is an open source framework, part of the Mono project, that reads .NET assemblies, but also

  32. Compare oxycontin to oxycodone. Oxycontin vs. oxycodone.

Skip to main content