b0b627
# HG changeset patch
b0b627
# User Daniel <daniel@thunderbird.net>
b0b627
# Date 1658184582 0
b0b627
#      Mon Jul 18 22:49:42 2022 +0000
b0b627
# Node ID 9998ed5c2bcee289b03828eba670053614fa26da
b0b627
# Parent  e572bc3cfa07492189aec439e98378b0811ae3bb
b0b627
Bug 1753683 - Replace distutils (deprecated) with packaging. r=rjl
b0b627
b0b627
Differential Revision: https://phabricator.services.mozilla.com/D152123
b0b627
b0b627
diff --git a/comm/python/thirdroc/thirdroc/__init__.py b/comm/python/thirdroc/thirdroc/__init__.py
b0b627
--- a/comm/python/thirdroc/thirdroc/__init__.py
b0b627
+++ b/comm/python/thirdroc/thirdroc/__init__.py
b0b627
@@ -3,11 +3,11 @@
b0b627
 # file, You can obtain one at http://mozilla.org/MPL/2.0/.
b0b627
 
b0b627
 from __future__ import print_function, absolute_import
b0b627
 
b0b627
 import re
b0b627
-from distutils.version import StrictVersion
b0b627
+from packaging.version import parse
b0b627
 
b0b627
 VTAG_RE = re.compile(r"^v\d+\.\d+\.\d+$")
b0b627
 
b0b627
 
b0b627
 def tag2version(tag):
b0b627
@@ -22,16 +22,16 @@ def tag2version(tag):
b0b627
         raise Exception("Invalid tag {}".format(tag))
b0b627
 
b0b627
 
b0b627
 def get_latest_version(*versions):
b0b627
     """
b0b627
-    Given a list of versions (that must parse with distutils.version.StrictVersion,
b0b627
+    Given a list of versions (that must parse with packaging.version.parse),
b0b627
     return the latest/newest version.
b0b627
     :param list versions:
b0b627
-    :return StrictVersion:
b0b627
+    :return Version:
b0b627
     """
b0b627
-    version_list = [StrictVersion(tag2version(v)) for v in versions]
b0b627
+    version_list = [parse(tag2version(v)) for v in versions]
b0b627
     version_list.sort()
b0b627
     return version_list[-1]
b0b627
 
b0b627
 
b0b627
 def latest_version(*versions):
b0b627
diff --git a/comm/python/thirdroc/thirdroc/rnp.py b/comm/python/thirdroc/thirdroc/rnp.py
b0b627
--- a/comm/python/thirdroc/thirdroc/rnp.py
b0b627
+++ b/comm/python/thirdroc/thirdroc/rnp.py
b0b627
@@ -6,11 +6,11 @@ from __future__ import absolute_import
b0b627
 
b0b627
 import os
b0b627
 from io import StringIO
b0b627
 from datetime import date
b0b627
 import re
b0b627
-from distutils.version import StrictVersion
b0b627
+from packaging.version import parse
b0b627
 
b0b627
 from mozbuild.preprocessor import Preprocessor
b0b627
 
b0b627
 
b0b627
 def rnp_source_update(rnp_root, version_str, revision, timestamp, bug_report):
b0b627
@@ -21,14 +21,14 @@ def rnp_source_update(rnp_root, version_
b0b627
     :param string version_str: latest version
b0b627
     :param string revision: revision hash (short form)
b0b627
     :param float timestamp: UNIX timestamp from revision
b0b627
     :param string bug_report: where to report bugs for this RNP build
b0b627
     """
b0b627
-    version = StrictVersion(version_str)
b0b627
-    version_major = version.version[0]
b0b627
-    version_minor = version.version[1]
b0b627
-    version_patch = version.version[2]
b0b627
+    version = parse(version_str)
b0b627
+    version_major = version.major
b0b627
+    version_minor = version.minor
b0b627
+    version_patch = version.micro
b0b627
     date_str = date.fromtimestamp(float(timestamp)).strftime("%Y%m%d")
b0b627
     revision_short = revision[:8]
b0b627
     version_full = "{}+git{}.{}.MZLA".format(version_str, date_str, revision_short)
b0b627
 
b0b627
     defines = dict(