<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div>On Apr 14, 2015, at 07:58, Simon Kennedy <<a href="mailto:sffjunkie@gmail.com">sffjunkie@gmail.com</a>> wrote:</div><blockquote type="cite"><div><div dir="ltr"><br>On Tuesday, 14 April 2015 14:01:30 UTC+1, Steven D'Aprano  wrote:<blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;"><br>Well, you've certainly been meticulous :-)
<br>
<br>[...]
<br>> * Removing the notion of 'virtual' environments. Everything's just an
<br>> environment.
<br>
<br>What's the difference?
<br></blockquote><div><br></div><div>Not a lot ;-) Merely a reduction in concepts by 1.</div><div><br></div><div>The question I asked myself when I thought about it is. Why 'virtual'? What's the conceptual difference between a standard Python install and a virtualenv (now that no-site-packages is the default.)? How does it help a Python user to distinguish between the two? Why do we have py.exe which finds a Python install but not a virtualenv?<br></div><div><br></div><div>So why not merge the Python install and the virtual environment into a single concept - Python Environments</div><div><br></div><div>Then we could have two tools</div><div><br></div><div>1. 'py' which finds and starts environments. (plus py could automatically find scripts in the bin / scripts / tools directories without having to add them to the path)</div></div></div></blockquote><div><br></div><div>How exactly does it do that? One of the nice things about virtual environments is that I can put them anywhere--in my home directory, on a network share, on an external drive, etc. I can make them relocatable and deploy them just by copying a directory. And so on. How could a tool possibly find all my environments?</div><div><br></div><div>More importantly, why would I ever want it to? The reason to have separate environments is so I can switch between them. A tool that treats them all the same as my base install is a tool that defeats the purpose of all of them.</div><div><br></div><div>And I certainly don't want anything installed in the bin/scripts/tools for any environment on my system to act like it's on my path even though it isn't.</div><br><blockquote type="cite"><div><div dir="ltr"><div>2. 'pyenv' which manages environments (create, list, show info, activate etc.)<br></div><div><br></div><div><br></div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;"><br>
<br>> * Splitting the standard library in twain. stdlib = 'baselib' + 'extlib'.
<br>>   - baselib = Enough to start up a Python environment / install pip.
<br>>   - extlib = The rest of the current stdlib. Changes more frequently than
<br>> the baselib.
<br>
<br>Hmmm. That would have consequences. Are you okay with abandoning large 
<br>parts of the corporate, government and education sectors?
<br>
<br>The thing is, one of the reasons that Python is so successful is that it 
<br>is *batteries included*. That's been a selling point for 20 years. This 
<br>means that using only the standard library, you can be productive and 
<br>get real work done. This is important for people using a standard 
<br>operating environment, or in restricted networks with no access to the 
<br>internet, or in any scenario where people have to get approval before 
<br>they can use a particular software package. Not everyone is able to just 
<br>download arbitrary packages from the Internet and use them on the spur 
<br>of the moment.
<br>
<br>With Python, they only need to get *one* package approved: "Can I 
<br>download Python and use it?" It might take six weeks to get approval, 
<br>but once you do, you have not just the core language, but a good 150+ 
<br>solid, useful, powerful libraries (and a few not so good ones).
<br>
<br>With your Python 3.9.9, they get the core language, and a mechanism for 
<br>downloading from PyPI, which they are not allowed to do without 
<br>approval, on pain of dismissal. Or not able to do, because the corporate 
<br>network blocks it. And don't even think about sneaking it in via USB key 
<br>from home... So each and every package that needs to be downloaded from 
<br>PyPI could take six weeks to get approval before they can run "pip 
<br>install os".
<br>
<br>The thing is, the broader Python ecosystem is not just hackers on Linux 
<br>with control over their own machines. It includes people in schools 
<br>using locked-down SOEs, corporate users with restricted network access 
<br>or paranoid legal/IT departments, people in developing nations with 
<br>unreliable internet access, and more.
<br>
<br></blockquote><div><br></div><div>The idea of the baselib + extlib is an attempt to address the desire to update parts of the stdlib faster than every Python release.</div><div><br></div><div>You would still get all the batteries included. When installing a new version of Python the extlib would be installed along with the baselib just not along side the baselib i.e. it would be in a separate on disk structure.</div><div><br></div><div>A new version of Python would be</div><div><br></div><div>* python.exe + baselib</div><div>* extlib on disk structure somewhere else</div></div></div></blockquote><div><br></div><div>So this is basically just PEP 413 in disguise. Have you read the discussions on that PEP, or at least the withdrawal reason?</div><div><br></div><div>You do add two additional things--moving most of the stdlib into an unspecified different location, and inventing a new tool (but just the name, not anything about what it actually does that couldn't already be done with pip) for doing the updates--but I'm not sure what either of those buys.</div><br><blockquote type="cite"><div><div dir="ltr"><div>The pippin tool which manages the extlib can pull in updates to the on disk repository in a batch as and when the maintainer wants.</div><div>and the environment's maintainer can update the environment with the version they want.</div><div><br></div><div>Installation from the extlib disk structure to the current environment is 'just a copy' operation.</div><div><br></div><div><div>A difference then between a package on PyPi and in the extlib is only that the extlib is 'blessed' by the same people who have control of the Python releases.</div></div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">
<br>> * A new tool called pippin to manage the extlib
<br>
<br>Does this actually exist, or have you picked it because the name is 
<br>cool? (It is a cool name.)
<br></blockquote><div><br></div><div>Almost everything in the document doesn't exist yet and this in no exception. I think being a Tolkien fan may have something to do with why I picked it.</div><div> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">
<br>(There is already a pippin on PyPI and github. I don't know if they are 
<br>the same project. The one of github claims to be experimental. Remember 
<br>that most experiments fail.)
<br>
<br>
<br>> * Formalising what a package index is
<br>
<br>What do you mean?
<br>
<br></blockquote><div><br></div><div>I can envision a future where there are multiple Python Package Indexes.</div><div><br></div><div>* The cheeseshop for 'uncontrolled' packages.</div><div>* A company specific package index that only packages that have been signed by an administrator can be installed.</div><div>* Plus others</div><div><br></div><div>Plus indexes in various stages of development</div><div><br></div><div>* PyPi - The current version</div><div>* Warehouse - The next version</div><div>* devpi - a bleeding edge development version</div><div><br></div><div>If there are to be tools which can interface with all these then there should be a formal document. Does this exist? I could not find one. All I've found various PEPS which propose updates to the cheeseshop.</div><div><br></div><div>This along with the pypi tool completes the PyPi Trinity.</div><div> <br></div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">
<br>> * Addressing a Python project's lifecycle.
<br>
<br>Surely that will be different for every project?
<br>
<br></blockquote><div><br></div><div>Sort of, but every project must go through some of these stages.</div><div><br></div><div>Create, Design, Code, Build, Test, Create Distribution, Upload, Download, Install</div></div></div></blockquote><div><br></div>Not every project needs all these stages. Not every project cycles through them in the same order. Many projects are developed by organizations that have their own process. Forcing everyone to do it the same way just means stopping many people from doing it at all.<div><br><blockquote type="cite"><div><div dir="ltr"><div>Consistent configuration between each of these steps would be desirable would it not? </div></div></div></blockquote><div><br></div><div>Like what? Other than the small amount of information that's already in setup.py and the .cnf file, what other configuration do most projects need between any of these steps?</div><div><br></div><blockquote type="cite"><div><div dir="ltr"><div>Allowing the creation of tools to manage projects.</div></div></div></blockquote><div><br></div><div>PyCharm, Eclipse PyDev, etc. already seem to be able to manage projects without anyone doing anything to allow it. What functionality are they missing that you want?</div><br><blockquote type="cite"><div><div dir="ltr"><div>If we don't look at them as a whole then we'll probably end up with inconsistencies.</div><div><br></div><div> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">
<br>> * Configuration handling
<br>
<br>What about it?
<br>
<br></blockquote><div><br></div><div>Because it's a thing that could be much more consistent across Python software.</div><div><br></div><div>What do we store in config files and where do we store them</div><div><br></div><div>* Sections</div><div>* Item names</div><div>* Item values (either singular or in a list)</div><div>* Item types</div><div><br></div><div>All configuration file formats can handle these but there's no best practice. </div></div></div></blockquote><div><br></div><div>No they can't. Plenty of configuration file formats can't handle sections; others handle unlimited levels of hierarchy. Some don't handle types, many handle small fixed sets of types (each different from the fixed set of types another format handles), only a few can handle arbitrary types. And so on.</div><div><br></div><blockquote type="cite"><div><div dir="ltr"><div>Why not formalise it?</div><div><br></div><div>Which directory should they go in? Again consistency is desirable. Surely we can come up with a 'blessed' set of locations?</div></div></div></blockquote><div><br></div><div>Surely not. To the extent that you want that at all, it should be up to the OS, not Python. Consider what happens if Python says "config files on Unix must go in ~/.config", then Apple says "if you put config information anywhere but the defaults database inside your container, your app can't be sold on the App Store". So now nobody can write an app in Python and sell it in the App Store?</div><br><blockquote type="cite"><div><div dir="ltr"><div>Then document also attempts to address the layering of configurations across</div><div><br></div><div>* In Code</div><div>* Site config</div><div>* user config</div><div>* Environment variables</div><div>* Command line parameters</div></div></div></blockquote><div><br></div><div>You almost certainly don't want that to work the same across every Python program. If I'm writing a tool in Python to do something MySQL-related, I want it to handle that stuff the same way as other MySQL-related tools, not the same way as other tools written in Python.</div><div> </div><blockquote type="cite"><div dir="ltr"><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">> * Removing the use of 'lib' suffixes from almost all packages.
<br>
<br>Why?
<br>
<br></blockquote><div><br></div><div>Because it's my vision of a future and I like consistency ;-) The question for me is why is it used in some places in the stdlib and not in others? What purpose does it serve? If it's a good idea shouldn't every package in the stdlib have a lib suffix? About the only place I can see it being useful is importlib because there's already an import statement and you don't want to 'import import' in your code<br></div><div> </div><blockquote class="gmail_quote" style="margin: 0;margin-left: 0.8ex;border-left: 1px #ccc solid;padding-left: 1ex;">
<br>> * Claiming any name in PyPi starting with 'py'
<br>
<br>That's going to be *really unpopular*. What is the purpose behind that?
<br>
<br></blockquote><div><br></div><div>I'm also sure it would be really unpopular but see the start of my previous response.</div><div><br></div><div>As it's only a vision of a possible future I'm under no illusion that it's the answer to all Python's 'problems' but it's an attempt to group all the disparate discussions into a single document.</div></div></blockquote><blockquote type="cite"><div dir="ltr"><div>My answers may almost all be wrong / unimplementable but the discussions on the mailing list so far seem isolated and this is my attempt to make sense of them all.</div></div></blockquote><div><br></div><div>Why do you think solving separate problems separately ("isolated") is a problem in the first place?</div><div><br></div><div>Why is discussing a jumble of dozens of barely-formed ideas, which are admittedly almost all wrong / unimplementable, as useful as discussing even one good idea on its own?</div><div><br></div><blockquote type="cite"><div dir="ltr"><div><br></div><div>Regards</div><div>Simon</div></div></blockquote><blockquote type="cite"><div><span>_______________________________________________</span><br><span>Python-ideas mailing list</span><br><span><a href="mailto:Python-ideas@python.org">Python-ideas@python.org</a></span><br><span><a href="https://mail.python.org/mailman/listinfo/python-ideas">https://mail.python.org/mailman/listinfo/python-ideas</a></span><br><span>Code of Conduct: <a href="http://python.org/psf/codeofconduct/">http://python.org/psf/codeofconduct/</a></span></div></blockquote></div></body></html>