<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Fri, Nov 6, 2015 at 12:33 PM, Ionel Cristian Mărieș <span dir="ltr"><<a href="mailto:contact@ionelmc.ro" target="_blank">contact@ionelmc.ro</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="gmail_default" style="font-family:trebuchet ms,sans-serif">​Why not consider having a "pip" launcher?​ Seems the obvious thing to me - python has the "py" launcher on windows and it works great!<br><br></div><div class="gmail_default" style="font-family:trebuchet ms,sans-serif">Eg: "pip -3" to launch pip using python3, "pip -3.5" to launch pip using python3.5 - just like the "py" launcher.</div></blockquote></div><br>This sounds similar to node's approach to bundling npm where you have a version of npm that runs for all projects using that node runtime. In effect you use the same npm binary independent of which virtualenv you are using, it's tied to the interpreter installation. So you run the pip that came with that python, such as pip2.7 installed with python2.7 and then just tell it which virtualenv to install packages into. You could go further and install a pip alias into the virtualenv that links to the appropriate pip, but there's still only one copy running for all virtualenvs off of that interpreter.</div><div class="gmail_extra"><br></div><div class="gmail_extra">This model is really nice for updating because you don't need to update pip inside every single virtualenv. Another cool feature of npm is that it's also effectively auto-using the virtualenv since it defaults to the local node_modules folder so you don't have to specify it as something like "pip --virtualenv=env install".</div><div class="gmail_extra"><br></div><div class="gmail_extra">Anyway I'm not suggesting such a drastic change but it's nice to look at what else is out there and the benefits. It doesn't mesh particularly well verbatim with how PYTHONPATH+virtualenv works of course.</div></div>