[PATCH 3/3] Rework CryptTab.parse (dlehman).

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



---
 storage/__init__.py |   51 +++++++++++++++++++++++++--------------------------
 1 files changed, 25 insertions(+), 26 deletions(-)

diff --git a/storage/__init__.py b/storage/__init__.py
index 3fefbb5..16a6922 100644
--- a/storage/__init__.py
+++ b/storage/__init__.py
@@ -1051,33 +1051,32 @@ class CryptTab(object):
         path = "%s/etc/crypttab" % chroot
         log.debug("parsing %s" % path)
         with open(path) as f:
+            if not self.blkidTab:
+                try:
+                    self.blkidTab = BlkidTab(chroot=chroot)
+                    self.blkidTab.parse()
+                except Exception:
+                    self.blkidTab = None
+
             for line in f.readlines():
-                if not self.blkidTab:
-                    try:
-                        self.blkidTab = BlkidTab(chroot=chroot)
-                        self.blkidTab.parse()
-                    except Exception:
-                        self.blkidTab = None
-
-                for line in lines:
-                    (line, pound, comment) = line.partition("#")
-                    fields = line.split()
-                    if not 2 <= len(fields) <= 4:
-                        continue
-                    elif len(fields) == 2:
-                        fields.extend(['none', ''])
-                    elif len(fields) == 3:
-                        fields.append('')
-
-                    (name, devspec, keyfile, options) = fields
-
-                    # resolve devspec to a device in the tree
-                    device = self.devicetree.resolveDevice(devspec,
-                                                           blkidTab=self.blkidTab)
-                    if device:
-                        self.mappings[name] = {"device": device,
-                                               "keyfile": keyfile,
-                                               "options": options}
+                (line, pound, comment) = line.partition("#")
+                fields = line.split()
+                if not 2 <= len(fields) <= 4:
+                    continue
+                elif len(fields) == 2:
+                    fields.extend(['none', ''])
+                elif len(fields) == 3:
+                    fields.append('')
+
+                (name, devspec, keyfile, options) = fields
+
+                # resolve devspec to a device in the tree
+                device = self.devicetree.resolveDevice(devspec,
+                                                       blkidTab=self.blkidTab)
+                if device:
+                    self.mappings[name] = {"device": device,
+                                           "keyfile": keyfile,
+                                           "options": options}
 
     def populate(self):
         """ Populate the instance based on the device tree's contents. """
-- 
1.6.1.3

_______________________________________________
Anaconda-devel-list mailing list
Anaconda-devel-list@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/anaconda-devel-list

[Index of Archives]     [Kickstart]     [Fedora Users]     [Fedora Legacy List]     [Fedora Maintainers]     [Fedora Desktop]     [Fedora SELinux]     [Big List of Linux Books]     [Yosemite News]     [Yosemite Photos]     [KDE Users]     [Fedora Tools]
  Powered by Linux