任务单 #43745

generate_packets.py minimum Python version

开放日期: 2022-01-31 05:09 最后更新: 2022-02-21 21:08

报告人:
属主:
类型:
状态:
关闭
组件:
里程碑:
优先:
5 - Medium
严重性:
5 - Medium
处理结果:
Fixed
文件:
3

Details

The comment in common/generate_packets.py claims it's compatible with every Python version since 1.5, and says to keep it that way; in particular, not to replace string.join calls. The update to make the script Python-3-compatible did just that.

Clearly, the script is not 1.5-compatible anymore (nor does it need to). Given the use of a python3 executable, our minimum supported version is in the Python 3 range – we should figure out / decide what specific version we want that to be, and update the comment accordingly.

任务单历史 (3/20 Histories)

2022-01-31 05:09 Updated by: alienvalkyrie
  • New Ticket "generate_packets.py minimum Python version" created
2022-01-31 13:47 Updated by: cazfi
评论

Reply To alienvalkyrie

Given the use of a python3 executable, our minimum supported version is in the Python 3 range

Actually, you can still do '/usr/bin/python generate_packets.py' on a system with python2, and it works. But do we want to be semantically correct here, or would it be better to tell people that they should not use long EOL python2?

2022-02-02 22:31 Updated by: alienvalkyrie
评论

Reply To cazfi

Reply To alienvalkyrie

Given the use of a python3 executable, our minimum supported version is in the Python 3 range

Actually, you can still do '/usr/bin/python generate_packets.py' on a system with python2, and it works. But do we want to be semantically correct here, or would it be better to tell people that they should not use long EOL python2?

I was referring more to the fact that the build system only looks for python3 – working with Python 2 instead is possible, of course, but without python3, autogen.sh will fail, so anyone working with Python 2 will already need more extensive workarounds (or build everything manually).

But yeah, I'd go the route of saying "this might work with a lower version, but we're only officially supporting <whatever> and higher". Having a more recent minimum supported version would also allow modernizing (and pythonicizing) the script with newer language features and useful library functions.

2022-02-02 22:58 Updated by: alienvalkyrie
评论

Some upper bounds for the minimum supported version (based on what runs on / comes with common operating systems):

  • Ubuntu 18.04 (Bionic Beaver), in standard support until 2023, only comes with Python 3.6
  • Ubuntu 14.04 (Trusty Tahr), in long-term support until April 2024, only comes with Python 3.4
  • Debian 9 "Stretch", in long-term support until June 2022, only comes with Python 3.5
  • Windows 7 can't run Python 3.9 and new

So our range of possible minimum supported versions is somewhere between 3.0 and 3.4. I'd gravitate toward going with Python 3.4 (plenty of features that might turn out to be useful; particularly pathlib might be relevant to our use case).

2022-02-02 23:21 Updated by: cazfi
评论

Reply To alienvalkyrie

without python3, autogen.sh will fail

Good reminder about autogen.sh. Whatever gets decided as the minimum python version, autogen.sh check should be updated to require.

2022-02-03 17:58 Updated by: jdlh
评论

On macOS, Apple has reliably bundled only Python 2.7 with the last several versions of macOS. This is obviously an old version and no longer supported. The word on the MacPorts lists1 is that Apple will stop supplying Python with macOS 12.3, which is currently in beta test.

The Apple stance on Python (and other scripting languages) is that you should not count on Apple to supply any version, you should install the runtime you require with your app.

I am working on delivery Freeciv to macOS via the MacPorts distro. It can install both the GNU autotools, and any necessary version of Python. So, the MacPorts distro of Freeciv should not be inconvenienced by Apple withdrawing Python 2.7 from macOS. Theoretically. I hope.

1 https://lists.macports.org/pipermail/macports-dev/2022-February/044121.html 2 https://developer.apple.com/documentation/macos-release-notes/macos-catalina-10_15-release-notes/ , search for "Scripting Language Runtimes"

2022-02-03 18:03 Updated by: cazfi
评论

Reply To jdlh

I am working on delivery Freeciv to macOS via the MacPorts distro.

This might not be an issue for you. We need python only when building from the git checkout. In the release tarballs the python generated files are already present (and up to date). Just be sure not to use ./autogen.sh (which you don't need as 'configure' and other files are already generated for you), but ./configure.

Obviously this is an issue for anybody wanting to do such development on macOS that would require recreating those python generated files.

2022-02-19 06:45 Updated by: alienvalkyrie
  • 属主 Update from (无) to alienvalkyrie
  • 里程碑 Update from (无) to 3.0.1 (关闭)
评论

Alright, so the way I understand it – the relevant OS/distros mentioned here either come with Python 3.4 or newer, or can install it just as easily as the other needed build tools (or other versions of Python 3, for that matter). The same is not true for 3.5 nor 3.6 unless we choose not to support building on Ubuntu 14.04 LTS and Debian 9 LTS, respectively, without additional hassle.

So choosing 3.4 as our minimum Python version for now (and at least until April 2024) seems like the sensible thing to do – unless we drop support for aforementioned LTS versions, in which case we could bump that up to Python 3.6.

There is an argument to be had about if it's a good idea to also increase the minimum supported version for S3_0, or if we should just fix the generate_packets.py comment there – in case someone's building the new stable release on another system where they can only get even older versions of Python 3. I think it's unlikely to matter, but something still rubs me wrong about the idea of changing the dependencies in the middle of the 3.0.x series.

2022-02-19 09:22 Updated by: cazfi
评论

Reply To alienvalkyrie

wrong about the idea of changing the dependencies in the middle of the 3.0.x series.

Please don't increase dependencies on already released branch - people who already using it must be able to also update within the series. Consider this a security issue - the update might be a fix to a vulnerability.

2022-02-19 09:37 Updated by: alienvalkyrie
  • File 0001-Fix-Python-version-comment-in-generate_packets.py.patch (File ID: 8574) is attached
2022-02-19 09:38 Updated by: alienvalkyrie
  • 处理结果 Update from to Accepted
评论

Reply To cazfi

Consider this a security issue - the update might be a fix to a vulnerability.

Good call; that's the point I figured must exist, but couldn't quite put my finger on.

S3_0 patch that just changes the comment is attached.

2022-02-20 13:38 Updated by: cazfi
评论

List the change in the minimum version in the README.packaging of the branch where it first happens.

2022-02-20 21:03 Updated by: alienvalkyrie
  • File 0001-Make-Python-3.4-the-minimum-officially-supported-ver.patch (File ID: 8595) is attached
2022-02-20 21:03 Updated by: alienvalkyrie
  • File 0001-Fix-Python-version-comment-in-generate_packets.py.patch (File ID: 8574) is deleted
2022-02-20 21:06 Updated by: alienvalkyrie
评论

Reply To cazfi

List the change in the minimum version in the README.packaging of the branch where it first happens.

Done.

2022-02-20 21:06 Updated by: alienvalkyrie
  • File 0001-Make-Python-3.4-the-minimum-officially-supported-ver.patch (File ID: 8595) is deleted
2022-02-21 21:08 Updated by: alienvalkyrie
  • 状态 Update from 开启 to 关闭
  • 处理结果 Update from Accepted to Fixed

编辑

Please login to add comment to this ticket » 登录名