Skip to content
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

Drastically lowers LinuxDistribution._distro_release_info complexity #327

Merged
merged 1 commit into from
Feb 18, 2022

Conversation

HorlogeSkynet
Copy link
Member

No description provided.

src/distro/distro.py Show resolved Hide resolved
src/distro/distro.py Outdated Show resolved Hide resolved
src/distro/distro.py Outdated Show resolved Hide resolved
@HorlogeSkynet HorlogeSkynet force-pushed the cleanup/distro_release_info branch from dbb9964 to 9e50a5d Compare February 17, 2022 18:52
@HorlogeSkynet
Copy link
Member Author

HorlogeSkynet commented Feb 17, 2022

@hartwork This is the diff I've just amended, to simplify your review 😇

More simplifications, and your documentation-related ideas.

diff --git a/src/distro/distro.py b/src/distro/distro.py
index 8209256..4d08067 100755
--- a/src/distro/distro.py
+++ b/src/distro/distro.py
@@ -1250,7 +1250,12 @@ class LinuxDistribution:
             match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename)
         else:
             try:
-                basenames = os.listdir(self.etc_dir)
+                basenames = [
+                    basename
+                    for basename in os.listdir(self.etc_dir)
+                    if basename not in _DISTRO_RELEASE_IGNORE_BASENAMES
+                    and os.path.isfile(os.path.join(self.etc_dir, basename))
+                ]
                 # We sort for repeatability in cases where there are multiple
                 # distro specific files; e.g. CentOS, Oracle, Enterprise all
                 # containing `redhat-release` on top of their own.
@@ -1262,10 +1267,8 @@ class LinuxDistribution:
                 # error is handled in `_parse_distro_release_file()`.
                 basenames = _DISTRO_RELEASE_BASENAMES
             for basename in basenames:
-                if basename in _DISTRO_RELEASE_IGNORE_BASENAMES:
-                    continue
                 match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename)
-                if not match:
+                if match is None:
                     continue
                 filepath = os.path.join(self.etc_dir, basename)
                 distro_info = self._parse_distro_release_file(filepath)
@@ -1274,13 +1277,13 @@ class LinuxDistribution:
                     continue
                 self.distro_release_file = filepath
                 break
-            else:
+            else:  # the loop didn't "break": no candidate.
                 return {}
 
         if match is not None:
             distro_info["id"] = match.group(1)
 
-        # manually set id for CloudLinux
+        # CloudLinux < 7: manually enrich info with proper id.
         if "cloudlinux" in distro_info.get("name", "").lower():
             distro_info["id"] = "cloudlinux"
 

@HorlogeSkynet HorlogeSkynet merged commit 5d22880 into master Feb 18, 2022
@HorlogeSkynet HorlogeSkynet deleted the cleanup/distro_release_info branch February 18, 2022 20:04
@hartwork hartwork added this to the 1.8.0 milestone Oct 10, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants