1. Introduce a new version with the plan of discontinuing the previous version <i>11 years</i> later (that's almost half of the time that, by then, python had been a thing), that itself was released only three years after the very tool you're talking about was released.<p>2. Don't even pretend to be interested in trying to do a migration until seven years later.<p>3. Make sure that your migration plan includes a development cycle that's deliberately hostile to the migration process.<p>4. ?<p>5. How could the <i>python maintainers</i> do this to <i>us</i>.<p>The description of the migration process was a good read. The fud afterwards... wasn't.<p>And there were a few inaccuracies (I'm being charitable, some of them were straight up lies).<p>> Python 3.0 was released on December 3, 2008. And it took the better part of a decade for the community to embrace it.<p>False, I've been using python 3, python 3 <i>exclusively</i>, since 2014, for all my projects.<p>> Yes, Python is still healthy today and Python 3 is (finally) being adopted at scale<p>False, same as above.<p>> I am ecstatic the community is finally rallying around Python 3<p>Again, false. Not only did "the community" rallied around python 3 years ago, he isn't really happy about it, but I'll get to that later.<p>> For nearly 4 years, Python 3 took away the consistent syntax for denoting bytes/Unicode string literals.<p>Or, to put it another way, python 3 was compatible with python 2's string types almost eight years before python 2 reached end of life.<p>> An ecosystem that falters for that long is generally not healthy<p>This entire paragraph was a hypothetical. It seems he really wanted to criticize something that did <i>not</i> happen.<p>> The only language I've seen properly implement higher-order abstractions on top of operating system facilities is Rust<p>And here's where his true point becomes evident: this is a hype piece for a language he found that he likes better. He's just attacking something in his previous language that he thinks is valid just as an attempt to highlight why the new toy is truly better. In short: He felt like complaining about the migration would be a good way to proselytize.<p>Just in case: no, it isn't better, and I say this as someone who currently isn't using python nor rust. I'm using a language that I'm quickly growing to hate more than I do either of them at their worst (no, it's not JavaScript).<p>> if Rust were at its current state 5 years ago, Mercurial would have likely ported from Python 2 to Rust instead of Python 3. As crazy as it initially sounded, I think I agree with that assessment.<p>So... The best he can say about rust is that it might be better than python 3 five years ago that, by his own opinion on everything he wrote before this, was terrible? Well, that's a recommendation <i></i>not<i></i> to use rust if I ever saw any.<p>When a hype piece defeats its own point.<p>> And speaking as a maintainer, I have mad respect for the people leading such a large community.<p>No, he doesn't; he used several appeals to emotion beforehand to try to paint them as terrible people.<p>> It should not have taken 11 years to get to where we are today.<p>This statement by itself is a truism that doesn't really mean anything, but the implication is that python 3 is only worthwhile 11 years later and it took that long for it to be so I'll reply to <i>that</i>.<p>No, it didn't. It didn't even take that long for mercurial, they started the migration four and half years ago, not eleven.<p>> am confident it will grow stronger by taking the time to do so<p>What is it to him? He should just move on to rust and be happy with it (sure, there are many people unhappy with it, but he wouldn't take the effort to proselytize if he wasn't).<p>In conclusion, I just don't understand the need to tear something else down to prop up a new thing. I'm sure I would have liked a post about things he could do with rust, but now...