-
-
Notifications
You must be signed in to change notification settings - Fork 564
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Upgrade to support also Python 3.x #295
Comments
And this likely means only Python 3.5 and up |
Here's one more vote to support Python 3 as that would make debugging multiprocessing exceptions like issue #413 a bit easier. |
At a high level the key issues I can think of are:
And in all cases, I want to support 2 and 3 at the same time with a single codebase which is not a big deal. FWIW, most libraries should be OK except some natives. Upcoming ones (e.g. https://github.com/nexB/license-expression/ ) are also ok (I just ported that to Python 3) |
Signed-off-by: Philippe Ombredanne <[email protected]>
For the 2 to 3 update, the first step will be effectively to gather wheels for every ScanCode-bundled dependencies I do not know which one would be OK or not: this has to be tested And eventually a Python 3 wheel --if not available-- can be built for all OSes/archs using https://github.com/pombreda/thirdparty-manylinux/ https://github.com/pombreda/thirdparty that are Travis and Appveyor build loops that create wheels and upload them to http://dl.bintray.com/pombreda/thirdparty/ Note that I have already started collecting Python 36 wheels there And once all deps are available, the second step is to ensure that all the tests pass both on Py2 and Py3 and start making fixes, one at a time which will be the guide to make the port work And BTW the minimum Python3 version we will support in ScanCode is 3.6.1. |
According to me, most helpful is this so why we are collecting python wheels on version dependent. Are you trying say that packages of python3 should be installed as well like it do in python 2 case |
@vivonk yes, that should be the way |
More reasons to upgrade to Python 3.x, and version 3.7 in particular: https://docs.python.org/3/whatsnew/3.7.html#optimizations |
You have 11 months left to migrate to python 3. Then python 2 will no longer be maintained. What is the status? |
@davidak this is definitely in the plan for this year! Help is definitely needed and welcomed. Would you be willing to chip in to help a bit if you have a few spare cycles? Also, we are planning to participate in the Google Summer of Code this year and if we are accepted that would be a great student project. Mentoring help could be great there. |
Wouldn't it be a nice & clean cut to make ScanCode 3.0 only support Python 3? That would be easy to remember 😉 |
Sadly i have already too many projects :D |
@davidak fair enough: may be you will be willing to kick in the tires when we start to have something usable? |
For now it works for me to manually set the license in my script. When this library works with python 3 i might try to detect it automatically. |
|
I wrote before
And
Unless someone disagree, the next major version after the 3.x release (4.x) will be ported and made to run only on Python3. And Python2 support will be dropped in 4.x and available only in maintenance branches of the 3.x releases. Having a codebase that does not try to support both versions will help quite a bit. Also I do not want to try to support any Python 3 version before version 3.6. So it is more like we will be migrating to Python 3.6+ Objections and feedback welcomed! |
Happy to lose python 2.7. python's story is way too hairy at the moment; we need to get to a place where everyone can always use venv. |
Python 3.6 sounds good |
I agree with @dankegel. Once we are fully migrated to python36+ I do not see a good reason to go out of our way to support python2. |
…ses aboutcode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…ode-org#295 This script copies all thirdparty files(required) and place it in repo as release assets. Signed-off-by: Abhishek Kumar <[email protected]>
…requirements.txt
Expose all .whl,.ABOUT, .NOTICE,.LICENCE files and Create an archive
Automate the creation of requirement.txt and fetch deps
…ode-org#295 Signed-off-by: Abhishek Kumar <[email protected]>
Older version had too many regex deprecation warnings Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
This removes any references to Python 2 and the commoncode.compat module Signed-off-by: Philippe Ombredanne <[email protected]>
None of them are needed in Python 3. Signed-off-by: Philippe Ombredanne <[email protected]>
dict is ordered by default in Python 3.6+ Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
Signed-off-by: Philippe Ombredanne <[email protected]>
We now support fully Python 3.6, 3.7, 3.8 and 3.9 on Linux, Windows and macOS 64 bits. |
The time is now!
Some important reads:
The text was updated successfully, but these errors were encountered: