<br><br><div class="gmail_quote">On Tue, Aug 16, 2011 at 5:39 PM, Benjamin Peterson <span dir="ltr"><<a href="mailto:benjamin@python.org">benjamin@python.org</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
2011/8/16 Yury Selivanov <<a href="mailto:yselivanov.ml@gmail.com">yselivanov.ml@gmail.com</a>>:<br>
<div class="im">> Is it possible for pypy core developers to create a high-level roadmap with what needs to be done and where? Should python3 be another translation target? Will it be required to touch rpython spec? What data structures need to be introduced? etc. I don't think this planning will take weeks of work, but it will help everyone to understand how much time and money should be invested in the matter.<br>
<br>
</div>First of all, there are some rather large decisions to be made:<br>
<br>
1. Port everything (Python interpreter, RPython) over to Python 3 and<br>
only support Python 3. This would probably be the cleanest and easiest<br>
in the longterm solution, but I doubt many are willing to accept it<br>
quite yet.<br>
<br>
2. Somehow maintain Python 2 and 3 in the same codebase. It sounds<br>
like a hideous mess to me. (I'm happy to be proven wrong.)<br>
<br>
3. Maintain a Python 3 interpreter in a separate repo or branch. This<br>
is probably the best compromise, but it requires the constant<br>
maintenance of someone merging the current head work.<br>
<br>
Then someone has to buckle down and do the actual porting. Depending<br>
on the option selected above, the amount of work will vary from huge<br>
to colossal. If you pick option 2, you have to figure out how to test<br>
both versions. I imagine there will be quite a tangled mess with<br>
unicode.<br>
<br>
At any rate, some of the initial steps which are compatible with<br>
Python 2 such as removing tuple unpacking and normalizing raise<br>
statements can now be taken. They might even make the codebase a bit<br>
cleaner.<br>
<div><div></div><div class="h5"><br>
<br>
<br>
--<br>
Regards,<br>
Benjamin<br>
_______________________________________________<br>
pypy-dev mailing list<br>
<a href="mailto:pypy-dev@python.org">pypy-dev@python.org</a><br>
<a href="http://mail.python.org/mailman/listinfo/pypy-dev" target="_blank">http://mail.python.org/mailman/listinfo/pypy-dev</a><br>
</div></div></blockquote></div><br>Personally I think #3 is the only sane path. We *need* a Python 2 VM for the forseeable future. We're pretty lucky in that the JIT, GC, and all the honest to god complex code is totally seperate from the VM, so just supporting 2 Python VMs is kind of easy (compared to maintaing 2 JITs or something).<div>
<br></div><div>Alex<br clear="all"><div><br></div>-- <br>"I disapprove of what you say, but I will defend to the death your right to say it." -- Evelyn Beatrice Hall (summarizing Voltaire)<br>"The people's good is the highest law." -- Cicero<br>
<br>
</div>