Blame SOURCES/0002-Revert-added-API-for-parsing-main-metadata-together-RhBug2062299.patch

b72d0a
From 9f0762b90cc1d85900064c24fad8f7d5a8b73afe Mon Sep 17 00:00:00 2001
b72d0a
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
b72d0a
Date: Wed, 9 Mar 2022 15:23:29 +0100
b72d0a
Subject: [PATCH 1/5] Revert "Add xml_parse_main_metadata_together to python
b72d0a
 parser examples"
b72d0a
b72d0a
This reverts commit 0633e31e491179f0153ef8267874812b4691957b.
b72d0a
---
b72d0a
 examples/python/repodata_parsing.py | 46 -----------------------------
b72d0a
 1 file changed, 46 deletions(-)
b72d0a
b72d0a
diff --git a/examples/python/repodata_parsing.py b/examples/python/repodata_parsing.py
b72d0a
index 4519518..ea517a1 100755
b72d0a
--- a/examples/python/repodata_parsing.py
b72d0a
+++ b/examples/python/repodata_parsing.py
b72d0a
@@ -211,48 +211,6 @@ def second_method():
b72d0a
     for pkg in packages.values():
b72d0a
         print_package_info(pkg)
b72d0a
 
b72d0a
-def third_method():
b72d0a
-    """Parsing main metadata types (primary, filelists, other) at the same time.
b72d0a
-    This approach significantly reduces memory footprint because we don't need
b72d0a
-    to keep all the packages in memory, user can handle them one by one.
b72d0a
-
b72d0a
-    The API reflects xml_parse_primary/filelists/other except that it handles
b72d0a
-    all of them at the same time.
b72d0a
-
b72d0a
-    """
b72d0a
-    def warningcb(warning_type, message):
b72d0a
-        print("PARSER WARNING: %s" % message)
b72d0a
-        return True
b72d0a
-
b72d0a
-    repomd = cr.Repomd()
b72d0a
-    cr.xml_parse_repomd(os.path.join(REPO_PATH, "repodata/repomd.xml"), repomd, warningcb)
b72d0a
-
b72d0a
-    primary_xml_path   = None
b72d0a
-    filelists_xml_path = None
b72d0a
-    other_xml_path     = None
b72d0a
-    for record in repomd.records:
b72d0a
-        if record.type == "primary":
b72d0a
-            primary_xml_path = os.path.join(REPO_PATH, record.location_href)
b72d0a
-        elif record.type == "filelists":
b72d0a
-            filelists_xml_path = os.path.join(REPO_PATH, record.location_href)
b72d0a
-        elif record.type == "other":
b72d0a
-            other_xml_path = os.path.join(REPO_PATH, record.location_href)
b72d0a
-
b72d0a
-    #
b72d0a
-    # Main XML metadata parsing (primary, filelists, other)
b72d0a
-    #
b72d0a
-
b72d0a
-    def pkgcb(pkg):
b72d0a
-        # Called when whole package entry from all 3 metadata xml files is parsed
b72d0a
-        print_package_info(pkg)
b72d0a
-
b72d0a
-    cr.xml_parse_main_metadata_together(primary_xml_path,
b72d0a
-                                        filelists_xml_path,
b72d0a
-                                        other_xml_path,
b72d0a
-                                        None,
b72d0a
-                                        pkgcb,
b72d0a
-                                        warningcb,
b72d0a
-                                        False)
b72d0a
 
b72d0a
 if __name__ == "__main__":
b72d0a
     print('"All in one shot" method:')
b72d0a
@@ -263,7 +221,3 @@ if __name__ == "__main__":
b72d0a
     print("Callback based method:")
b72d0a
     second_method()
b72d0a
 
b72d0a
-    print()
b72d0a
-
b72d0a
-    print("Streaming callback based method:")
b72d0a
-    third_method()
b72d0a
-- 
b72d0a
2.35.1
b72d0a
b72d0a
b72d0a
From 01493aea9bc53e46a0e1020656e60ecb6c543bca Mon Sep 17 00:00:00 2001
b72d0a
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
b72d0a
Date: Wed, 9 Mar 2022 15:23:40 +0100
b72d0a
Subject: [PATCH 2/5] Revert "Add python tests for parsing metadata together"
b72d0a
b72d0a
This reverts commit 0c050128f7e24222011cdfcc67ba58da744affa9.
b72d0a
---
b72d0a
 tests/python/tests/test_xml_parser.py | 206 --------------------------
b72d0a
 1 file changed, 206 deletions(-)
b72d0a
b72d0a
diff --git a/tests/python/tests/test_xml_parser.py b/tests/python/tests/test_xml_parser.py
b72d0a
index ed13cac..ddc089f 100644
b72d0a
--- a/tests/python/tests/test_xml_parser.py
b72d0a
+++ b/tests/python/tests/test_xml_parser.py
b72d0a
@@ -950,209 +950,3 @@ class TestCaseXmlParserRepomd(unittest.TestCase):
b72d0a
         self.assertEqual(repomd.content_tags, [])
b72d0a
         self.assertEqual(len(repomd.records), 3)
b72d0a
 
b72d0a
-class TestCaseXmlParserMainMetadataTogether(unittest.TestCase):
b72d0a
-    def test_xml_parser_main_metadata_together_repo01(self):
b72d0a
-        userdata = {
b72d0a
-                "pkgs": [],
b72d0a
-                "pkgcb_calls": 0,
b72d0a
-                "warnings": []
b72d0a
-            }
b72d0a
-
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            pkg = cr.Package()
b72d0a
-            userdata["pkgs"].append(pkg)
b72d0a
-            return pkg
b72d0a
-
b72d0a
-        def pkgcb(pkg):
b72d0a
-            userdata["pkgcb_calls"] += 1
b72d0a
-
b72d0a
-        def warningcb(warn_type, msg):
b72d0a
-            userdata["warnings"].append((warn_type, msg))
b72d0a
-
b72d0a
-        cr.xml_parse_main_metadata_together(primary=REPO_01_PRIXML, filelists=REPO_01_FILXML, other=REPO_01_OTHXML,
b72d0a
-                                            newpkgcb=newpkgcb, pkgcb=pkgcb, warningcb=warningcb)
b72d0a
-
b72d0a
-        self.assertEqual([pkg.name for pkg in userdata["pkgs"]], ['super_kernel'])
b72d0a
-        self.assertEqual(userdata["pkgcb_calls"], 1)
b72d0a
-        self.assertEqual(userdata["warnings"], [])
b72d0a
-
b72d0a
-        pkg = userdata["pkgs"][0]
b72d0a
-        self.assertEqual(pkg.pkgId, "152824bff2aa6d54f429d43e87a3ff3a0286505c6d93ec87692b5e3a9e3b97bf")
b72d0a
-        self.assertEqual(pkg.name, "super_kernel")
b72d0a
-        self.assertEqual(pkg.arch, "x86_64")
b72d0a
-        self.assertEqual(pkg.version, "6.0.1")
b72d0a
-        self.assertEqual(pkg.epoch, "0")
b72d0a
-        self.assertEqual(pkg.release, "2")
b72d0a
-        self.assertEqual(pkg.summary, "Test package")
b72d0a
-        self.assertEqual(pkg.description, "This package has provides, requires, obsoletes, conflicts options.")
b72d0a
-        self.assertEqual(pkg.url, "http://so_super_kernel.com/it_is_awesome/yep_it_really_is")
b72d0a
-        self.assertEqual(pkg.time_file, 1334667003)
b72d0a
-        self.assertEqual(pkg.time_build, 1334667003)
b72d0a
-        self.assertEqual(pkg.rpm_license, "LGPLv2")
b72d0a
-        self.assertEqual(pkg.rpm_vendor, None)
b72d0a
-        self.assertEqual(pkg.rpm_group, "Applications/System")
b72d0a
-        self.assertEqual(pkg.rpm_buildhost, "localhost.localdomain")
b72d0a
-        self.assertEqual(pkg.rpm_sourcerpm, "super_kernel-6.0.1-2.src.rpm")
b72d0a
-        self.assertEqual(pkg.rpm_header_start, 280)
b72d0a
-        self.assertEqual(pkg.rpm_header_end, 2637)
b72d0a
-        self.assertEqual(pkg.rpm_packager, None)
b72d0a
-        self.assertEqual(pkg.size_package, 2845)
b72d0a
-        self.assertEqual(pkg.size_installed, 0)
b72d0a
-        self.assertEqual(pkg.size_archive, 404)
b72d0a
-        self.assertEqual(pkg.location_href, "super_kernel-6.0.1-2.x86_64.rpm")
b72d0a
-        self.assertEqual(pkg.location_base, None)
b72d0a
-        self.assertEqual(pkg.checksum_type, "sha256")
b72d0a
-        self.assertEqual(pkg.requires,
b72d0a
-                [('bzip2', 'GE', '0', '1.0.0', None, True),
b72d0a
-                 ('expat', None, None, None, None, True),
b72d0a
-                 ('glib', 'GE', '0', '2.26.0', None, False),
b72d0a
-                 ('zlib', None, None, None, None, False)])
b72d0a
-        self.assertEqual(pkg.provides,
b72d0a
-                [('not_so_super_kernel', 'LT', '0', '5.8.0', None, False),
b72d0a
-                 ('super_kernel', 'EQ', '0', '6.0.0', None, False),
b72d0a
-                 ('super_kernel', 'EQ', '0', '6.0.1', '2', False),
b72d0a
-                 ('super_kernel(x86-64)', 'EQ', '0', '6.0.1', '2', False)])
b72d0a
-        self.assertEqual(pkg.conflicts,
b72d0a
-                [('kernel', None, None, None, None, False),
b72d0a
-                 ('super_kernel', 'EQ', '0', '5.0.0', None, False),
b72d0a
-                 ('super_kernel', 'LT', '0', '4.0.0', None, False)])
b72d0a
-        self.assertEqual(pkg.obsoletes,
b72d0a
-                [('kernel', None, None, None, None, False),
b72d0a
-                 ('super_kernel', 'EQ', '0', '5.9.0', None, False)])
b72d0a
-        self.assertEqual(pkg.files,
b72d0a
-                [(None, '/usr/bin/', 'super_kernel'),
b72d0a
-                 (None, '/usr/share/man/', 'super_kernel.8.gz')])
b72d0a
-        self.assertEqual(pkg.changelogs,
b72d0a
-                [('Tomas Mlcoch <tmlcoch@redhat.com> - 6.0.1-1',
b72d0a
-                   1334664000,
b72d0a
-                  '- First release'),
b72d0a
-                 ('Tomas Mlcoch <tmlcoch@redhat.com> - 6.0.1-2',
b72d0a
-                   1334664001,
b72d0a
-                   '- Second release')])
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_repo02(self):
b72d0a
-
b72d0a
-        userdata = {
b72d0a
-                "pkgs": [],
b72d0a
-                "pkgcb_calls": 0,
b72d0a
-                "warnings": []
b72d0a
-            }
b72d0a
-
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            pkg = cr.Package()
b72d0a
-            userdata["pkgs"].append(pkg)
b72d0a
-            return pkg
b72d0a
-
b72d0a
-        def pkgcb(pkg):
b72d0a
-            userdata["pkgcb_calls"] += 1
b72d0a
-
b72d0a
-        def warningcb(warn_type, msg):
b72d0a
-            userdata["warnings"].append((warn_type, msg))
b72d0a
-
b72d0a
-        cr.xml_parse_main_metadata_together(REPO_02_PRIXML, REPO_02_FILXML, REPO_02_OTHXML, newpkgcb, pkgcb, warningcb,
b72d0a
-                                            allow_out_of_order=True)
b72d0a
-
b72d0a
-        self.assertEqual([pkg.name for pkg in userdata["pkgs"]],
b72d0a
-            ['fake_bash', 'super_kernel'])
b72d0a
-        self.assertEqual(userdata["pkgcb_calls"], 2)
b72d0a
-        self.assertEqual(userdata["warnings"], [])
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_repo02_only_pkgcb(self):
b72d0a
-
b72d0a
-        pkgs = []
b72d0a
-
b72d0a
-        def pkgcb(pkg):
b72d0a
-            pkgs.append(pkg)
b72d0a
-
b72d0a
-        cr.xml_parse_main_metadata_together(REPO_02_PRIXML, REPO_02_FILXML, REPO_02_OTHXML,
b72d0a
-                                            None, pkgcb, None)
b72d0a
-
b72d0a
-        self.assertEqual([pkg.name for pkg in pkgs],
b72d0a
-            ['fake_bash', 'super_kernel'])
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_repo02_no_cbs(self):
b72d0a
-        self.assertRaises(ValueError,
b72d0a
-                          cr.xml_parse_main_metadata_together,
b72d0a
-                          REPO_02_PRIXML, REPO_02_FILXML, REPO_02_OTHXML,
b72d0a
-                          None, None, None)
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_warnings(self):
b72d0a
-        userdata = {
b72d0a
-                "pkgs": [],
b72d0a
-                "warnings": []
b72d0a
-            }
b72d0a
-
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            pkg = cr.Package()
b72d0a
-            userdata["pkgs"].append(pkg)
b72d0a
-            return pkg
b72d0a
-
b72d0a
-        def warningcb(warn_type, msg):
b72d0a
-            userdata["warnings"].append((warn_type, msg))
b72d0a
-
b72d0a
-        cr.xml_parse_main_metadata_together(PRIMARY_MULTI_WARN_00_PATH,
b72d0a
-                                            FILELISTS_MULTI_WARN_00_PATH,
b72d0a
-                                            OTHER_MULTI_WARN_00_PATH,
b72d0a
-                                            newpkgcb, None, warningcb)
b72d0a
-
b72d0a
-        self.assertEqual([pkg.name for pkg in userdata["pkgs"]],
b72d0a
-            ['fake_bash', 'super_kernel'])
b72d0a
-        self.assertEqual(userdata["warnings"],
b72d0a
-            [(0, 'Unknown element "fooelement"'),
b72d0a
-             (1, 'Missing attribute "type" of a package element'),
b72d0a
-             (0, 'Unknown element "foo"'),
b72d0a
-             (3, 'Conversion of "foobar" to integer failed'),
b72d0a
-             (0, 'Unknown element "bar"'),
b72d0a
-             (1, 'Missing attribute "arch" of a package element'),
b72d0a
-             (2, 'Unknown file type "xxx"'),
b72d0a
-             (0, 'Unknown element "bar"'),
b72d0a
-             (1, 'Missing attribute "name" of a package element'),
b72d0a
-             (0, 'Unknown element "bar"'),
b72d0a
-             (3, 'Conversion of "xxx" to integer failed')])
b72d0a
-
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_error(self):
b72d0a
-        userdata = { "pkgs": [] }
b72d0a
-
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            pkg = cr.Package()
b72d0a
-            userdata["pkgs"].append(pkg)
b72d0a
-            return pkg
b72d0a
-
b72d0a
-        self.assertRaises(cr.CreaterepoCError, cr.xml_parse_main_metadata_together,
b72d0a
-                          PRIMARY_ERROR_00_PATH, FILELISTS_ERROR_00_PATH,
b72d0a
-                          OTHER_ERROR_00_PATH, newpkgcb, None, None)
b72d0a
-
b72d0a
-        # unlike parsing just primary, filelists or other separately when parsing together primary is parsed first fully
b72d0a
-        # before newpkgcb is called so the error is detected before any user package is created
b72d0a
-        self.assertEqual(len(userdata["pkgs"]), 0)
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_newpkgcb_abort(self):
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            raise Error("Foo error")
b72d0a
-        self.assertRaises(cr.CreaterepoCError,
b72d0a
-                          cr.xml_parse_main_metadata_together,
b72d0a
-                          REPO_02_PRIXML, REPO_02_FILXML, REPO_02_OTHXML,
b72d0a
-                          newpkgcb, None, None)
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_pkgcb_abort(self):
b72d0a
-       def newpkgcb(pkgId, name, arch):
b72d0a
-           return cr.Package()
b72d0a
-       def pkgcb(pkg):
b72d0a
-           raise Error("Foo error")
b72d0a
-       self.assertRaises(cr.CreaterepoCError,
b72d0a
-                         cr.xml_parse_main_metadata_together,
b72d0a
-                         REPO_02_PRIXML, REPO_02_FILXML, REPO_02_OTHXML,
b72d0a
-                         newpkgcb, pkgcb, None)
b72d0a
-
b72d0a
-    def test_xml_parser_main_metadata_together_warningcb_abort(self):
b72d0a
-        def newpkgcb(pkgId, name, arch):
b72d0a
-            return cr.Package()
b72d0a
-        def warningcb(type, msg):
b72d0a
-            raise Error("Foo error")
b72d0a
-        self.assertRaises(cr.CreaterepoCError,
b72d0a
-                          cr.xml_parse_main_metadata_together,
b72d0a
-                          PRIMARY_MULTI_WARN_00_PATH,
b72d0a
-                          FILELISTS_MULTI_WARN_00_PATH,
b72d0a
-                          OTHER_MULTI_WARN_00_PATH,
b72d0a
-                          newpkgcb, None, warningcb)
b72d0a
-- 
b72d0a
2.35.1
b72d0a
b72d0a
b72d0a
From 9210f5d725a71f130bf5fb880f386c2e8e5f66fa Mon Sep 17 00:00:00 2001
b72d0a
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
b72d0a
Date: Wed, 9 Mar 2022 15:23:47 +0100
b72d0a
Subject: [PATCH 3/5] Revert "Wrap c api to python for parsing metadata
b72d0a
 together"
b72d0a
b72d0a
This reverts commit 670006b9f37d8298fe2ec1d6cfc5cdf175a3128b.
b72d0a
---
b72d0a
 src/python/createrepo_cmodule.c |   2 -
b72d0a
 src/python/xml_parser-py.c      | 156 +++++++-------------------------
b72d0a
 src/python/xml_parser-py.h      |   8 --
b72d0a
 3 files changed, 32 insertions(+), 134 deletions(-)
b72d0a
b72d0a
diff --git a/src/python/createrepo_cmodule.c b/src/python/createrepo_cmodule.c
b72d0a
index c0b9200..6937246 100644
b72d0a
--- a/src/python/createrepo_cmodule.c
b72d0a
+++ b/src/python/createrepo_cmodule.c
b72d0a
@@ -79,8 +79,6 @@ static struct PyMethodDef createrepo_c_methods[] = {
b72d0a
         METH_VARARGS, xml_parse_repomd__doc__},
b72d0a
     {"xml_parse_updateinfo",    (PyCFunction)py_xml_parse_updateinfo,
b72d0a
         METH_VARARGS, xml_parse_updateinfo__doc__},
b72d0a
-    {"xml_parse_main_metadata_together",(PyCFunctionWithKeywords)py_xml_parse_main_metadata_together,
b72d0a
-        METH_VARARGS | METH_KEYWORDS, xml_parse_main_metadata_together__doc__},
b72d0a
     {"checksum_name_str",       (PyCFunction)py_checksum_name_str,
b72d0a
         METH_VARARGS, checksum_name_str__doc__},
b72d0a
     {"checksum_type",           (PyCFunction)py_checksum_type,
b72d0a
diff --git a/src/python/xml_parser-py.c b/src/python/xml_parser-py.c
b72d0a
index a1f92f8..0879128 100644
b72d0a
--- a/src/python/xml_parser-py.c
b72d0a
+++ b/src/python/xml_parser-py.c
b72d0a
@@ -34,7 +34,7 @@ typedef struct {
b72d0a
     PyObject *py_newpkgcb;
b72d0a
     PyObject *py_pkgcb;
b72d0a
     PyObject *py_warningcb;
b72d0a
-    PyObject *py_pkgs;       /*!< Current processed package */
b72d0a
+    PyObject *py_pkg;       /*!< Current processed package */
b72d0a
 } CbData;
b72d0a
 
b72d0a
 static int
b72d0a
@@ -48,6 +48,12 @@ c_newpkgcb(cr_Package **pkg,
b72d0a
     PyObject *arglist, *result;
b72d0a
     CbData *data = cbdata;
b72d0a
 
b72d0a
+    if (data->py_pkg) {
b72d0a
+        // Decref ref count on previous processed package
b72d0a
+        Py_DECREF(data->py_pkg);
b72d0a
+        data->py_pkg = NULL;
b72d0a
+    }
b72d0a
+
b72d0a
     arglist = Py_BuildValue("(sss)", pkgId, name, arch);
b72d0a
     result = PyObject_CallObject(data->py_newpkgcb, arglist);
b72d0a
     Py_DECREF(arglist);
b72d0a
@@ -67,18 +73,13 @@ c_newpkgcb(cr_Package **pkg,
b72d0a
 
b72d0a
     if (result == Py_None) {
b72d0a
         *pkg = NULL;
b72d0a
+        data->py_pkg = NULL;
b72d0a
+        Py_DECREF(result);
b72d0a
     } else {
b72d0a
         *pkg = Package_FromPyObject(result);
b72d0a
-        if (data->py_pkgcb != Py_None) {
b72d0a
-            // Store reference to the python pkg (result) only if we will need it later
b72d0a
-            PyObject *keyFromPtr = PyLong_FromVoidPtr(*pkg);
b72d0a
-            PyDict_SetItem(data->py_pkgs, keyFromPtr, result);
b72d0a
-            Py_DECREF(keyFromPtr);
b72d0a
-        }
b72d0a
+        data->py_pkg = result; // Store reference to current package
b72d0a
     }
b72d0a
 
b72d0a
-    Py_DECREF(result);
b72d0a
-
b72d0a
     return CR_CB_RET_OK;
b72d0a
 }
b72d0a
 
b72d0a
@@ -90,23 +91,16 @@ c_pkgcb(cr_Package *pkg,
b72d0a
     PyObject *arglist, *result, *py_pkg;
b72d0a
     CbData *data = cbdata;
b72d0a
 
b72d0a
-    PyObject *keyFromPtr = PyLong_FromVoidPtr(pkg);
b72d0a
-    py_pkg = PyDict_GetItem(data->py_pkgs, keyFromPtr);
b72d0a
-    if (py_pkg) {
b72d0a
-        arglist = Py_BuildValue("(O)", py_pkg);
b72d0a
-        result = PyObject_CallObject(data->py_pkgcb, arglist);
b72d0a
-        PyDict_DelItem(data->py_pkgs, keyFromPtr);
b72d0a
-    } else {
b72d0a
-        // The package was not provided by user in c_newpkgcb,
b72d0a
-        // create new python package object
b72d0a
-        PyObject *new_py_pkg = Object_FromPackage(pkg, 1);
b72d0a
-        arglist = Py_BuildValue("(O)", new_py_pkg);
b72d0a
-        result = PyObject_CallObject(data->py_pkgcb, arglist);
b72d0a
-        Py_DECREF(new_py_pkg);
b72d0a
-    }
b72d0a
+    if (data->py_pkg)
b72d0a
+        py_pkg = data->py_pkg;
b72d0a
+    else
b72d0a
+        py_pkg = Object_FromPackage(pkg, 1);
b72d0a
 
b72d0a
+    arglist = Py_BuildValue("(O)", py_pkg);
b72d0a
+    result = PyObject_CallObject(data->py_pkgcb, arglist);
b72d0a
     Py_DECREF(arglist);
b72d0a
-    Py_DECREF(keyFromPtr);
b72d0a
+    Py_DECREF(py_pkg);
b72d0a
+    data->py_pkg = NULL;
b72d0a
 
b72d0a
     if (result == NULL) {
b72d0a
         // Exception raised
b72d0a
@@ -197,7 +191,7 @@ py_xml_parse_primary(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_primary(filename,
b72d0a
                          ptr_c_newpkgcb,
b72d0a
@@ -212,8 +206,7 @@ py_xml_parse_primary(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -279,7 +272,7 @@ py_xml_parse_primary_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_primary_snippet(target, ptr_c_newpkgcb, &cbdata, ptr_c_pkgcb, &cbdata,
b72d0a
                                  ptr_c_warningcb, &cbdata, do_files, &tmp_err);
b72d0a
@@ -287,7 +280,7 @@ py_xml_parse_primary_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -351,7 +344,7 @@ py_xml_parse_filelists(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_filelists(filename,
b72d0a
                            ptr_c_newpkgcb,
b72d0a
@@ -365,7 +358,7 @@ py_xml_parse_filelists(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -429,7 +422,7 @@ py_xml_parse_filelists_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_filelists_snippet(target, ptr_c_newpkgcb, &cbdata, ptr_c_pkgcb,
b72d0a
                                    &cbdata, ptr_c_warningcb, &cbdata, &tmp_err);
b72d0a
@@ -437,7 +430,7 @@ py_xml_parse_filelists_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -501,7 +494,7 @@ py_xml_parse_other(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_other(filename,
b72d0a
                        ptr_c_newpkgcb,
b72d0a
@@ -515,7 +508,7 @@ py_xml_parse_other(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -579,7 +572,7 @@ py_xml_parse_other_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
     cbdata.py_pkgcb     = py_pkgcb;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     cr_xml_parse_other_snippet(target, ptr_c_newpkgcb, &cbdata, ptr_c_pkgcb, &cbdata,
b72d0a
                                ptr_c_warningcb, &cbdata, &tmp_err);
b72d0a
@@ -587,7 +580,7 @@ py_xml_parse_other_snippet(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     Py_XDECREF(py_newpkgcb);
b72d0a
     Py_XDECREF(py_pkgcb);
b72d0a
     Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
+    Py_XDECREF(cbdata.py_pkg);
b72d0a
 
b72d0a
     if (tmp_err) {
b72d0a
         nice_exception(&tmp_err, NULL);
b72d0a
@@ -630,7 +623,7 @@ py_xml_parse_repomd(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = NULL;
b72d0a
     cbdata.py_pkgcb     = NULL;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = NULL;
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     repomd = Repomd_FromPyObject(py_repomd);
b72d0a
 
b72d0a
@@ -684,7 +677,7 @@ py_xml_parse_updateinfo(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
     cbdata.py_newpkgcb  = NULL;
b72d0a
     cbdata.py_pkgcb     = NULL;
b72d0a
     cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = NULL;
b72d0a
+    cbdata.py_pkg       = NULL;
b72d0a
 
b72d0a
     updateinfo = UpdateInfo_FromPyObject(py_updateinfo);
b72d0a
 
b72d0a
@@ -704,88 +697,3 @@ py_xml_parse_updateinfo(G_GNUC_UNUSED PyObject *self, PyObject *args)
b72d0a
 
b72d0a
     Py_RETURN_NONE;
b72d0a
 }
b72d0a
-
b72d0a
-
b72d0a
-PyObject *
b72d0a
-py_xml_parse_main_metadata_together(G_GNUC_UNUSED PyObject *self, PyObject *args, PyObject *kwargs)
b72d0a
-{
b72d0a
-    char *primary_filename;
b72d0a
-    char *filelists_filename;
b72d0a
-    char *other_filename;
b72d0a
-    int allow_out_of_order = 1;
b72d0a
-    PyObject *py_newpkgcb, *py_pkgcb, *py_warningcb;
b72d0a
-    CbData cbdata;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    static char *kwlist[] = { "primary", "filelists", "other", "newpkgcb", "pkgcb",
b72d0a
-                              "warningcb", "allow_out_of_order", NULL };
b72d0a
-
b72d0a
-    if (!PyArg_ParseTupleAndKeywords(args, kwargs, "sssOOO|p:py_xml_parse_main_metadata_together", kwlist,
b72d0a
-                                     &primary_filename, &filelists_filename, &other_filename, &py_newpkgcb,
b72d0a
-                                     &py_pkgcb, &py_warningcb, &allow_out_of_order)) {
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (!PyCallable_Check(py_newpkgcb) && py_newpkgcb != Py_None) {
b72d0a
-        PyErr_SetString(PyExc_TypeError, "newpkgcb must be callable or None");
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (!PyCallable_Check(py_pkgcb) && py_pkgcb != Py_None) {
b72d0a
-        PyErr_SetString(PyExc_TypeError, "pkgcb must be callable or None");
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (!PyCallable_Check(py_warningcb) && py_warningcb != Py_None) {
b72d0a
-        PyErr_SetString(PyExc_TypeError, "warningcb must be callable or None");
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (py_newpkgcb == Py_None && py_pkgcb == Py_None) {
b72d0a
-        PyErr_SetString(PyExc_ValueError, "both pkgcb and newpkgcb cannot be None");
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    Py_XINCREF(py_newpkgcb);
b72d0a
-    Py_XINCREF(py_pkgcb);
b72d0a
-    Py_XINCREF(py_warningcb);
b72d0a
-
b72d0a
-    cr_XmlParserNewPkgCb    ptr_c_newpkgcb  = NULL;
b72d0a
-    cr_XmlParserPkgCb       ptr_c_pkgcb     = NULL;
b72d0a
-    cr_XmlParserWarningCb   ptr_c_warningcb = NULL;
b72d0a
-
b72d0a
-    if (py_newpkgcb != Py_None)
b72d0a
-        ptr_c_newpkgcb = c_newpkgcb;
b72d0a
-    if (py_pkgcb != Py_None)
b72d0a
-        ptr_c_pkgcb = c_pkgcb;
b72d0a
-    if (py_warningcb != Py_None)
b72d0a
-        ptr_c_warningcb = c_warningcb;
b72d0a
-
b72d0a
-    cbdata.py_newpkgcb  = py_newpkgcb;
b72d0a
-    cbdata.py_pkgcb     = py_pkgcb;
b72d0a
-    cbdata.py_warningcb = py_warningcb;
b72d0a
-    cbdata.py_pkgs      = PyDict_New();
b72d0a
-
b72d0a
-    cr_xml_parse_main_metadata_together(primary_filename,
b72d0a
-                                        filelists_filename,
b72d0a
-                                        other_filename,
b72d0a
-                                        ptr_c_newpkgcb,
b72d0a
-                                        &cbdata,
b72d0a
-                                        ptr_c_pkgcb,
b72d0a
-                                        &cbdata,
b72d0a
-                                        ptr_c_warningcb,
b72d0a
-                                        &cbdata,
b72d0a
-                                        allow_out_of_order,
b72d0a
-                                        &tmp_err);
b72d0a
-
b72d0a
-    Py_XDECREF(py_newpkgcb);
b72d0a
-    Py_XDECREF(py_pkgcb);
b72d0a
-    Py_XDECREF(py_warningcb);
b72d0a
-    Py_XDECREF(cbdata.py_pkgs);
b72d0a
-
b72d0a
-    if (tmp_err) {
b72d0a
-        nice_exception(&tmp_err, NULL);
b72d0a
-        return NULL;
b72d0a
-    }
b72d0a
-
b72d0a
-    Py_RETURN_NONE;
b72d0a
-}
b72d0a
diff --git a/src/python/xml_parser-py.h b/src/python/xml_parser-py.h
b72d0a
index 3260005..e5eea9f 100644
b72d0a
--- a/src/python/xml_parser-py.h
b72d0a
+++ b/src/python/xml_parser-py.h
b72d0a
@@ -64,12 +64,4 @@ PyDoc_STRVAR(xml_parse_updateinfo__doc__,
b72d0a
 
b72d0a
 PyObject *py_xml_parse_updateinfo(PyObject *self, PyObject *args);
b72d0a
 
b72d0a
-PyDoc_STRVAR(xml_parse_main_metadata_together__doc__,
b72d0a
-"xml_parse_main_metadata_together(primary_filename, filelists_filename, other_filename, newpkgcb, pkgcb, warningcb) -> None\n\n"
b72d0a
-"Parse primary.xml, filelists.xml and other.xml together at the same time."
b72d0a
-"- It can handle if packages are not in the same order in all 3 files but memory requirements grow."
b72d0a
-"- It is not guaranteed that newpkgcb is always followed by pkgcb for the given package, it is possible newpkgcb will be called several times for different packages and only after that pkgcbs will be called.");
b72d0a
-
b72d0a
-PyObject *py_xml_parse_main_metadata_together(PyObject *self, PyObject *args, PyObject *kwargs);
b72d0a
-
b72d0a
 #endif
b72d0a
-- 
b72d0a
2.35.1
b72d0a
b72d0a
b72d0a
From ac6f56e87f8a4b1f0a35d9dedc02a8846c9a6390 Mon Sep 17 00:00:00 2001
b72d0a
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
b72d0a
Date: Wed, 9 Mar 2022 15:23:58 +0100
b72d0a
Subject: [PATCH 4/5] Revert "Add c tests for parsing metadata together"
b72d0a
b72d0a
This reverts commit 3ef3d4d77e283ee916fc7977cdc3855b912463e0.
b72d0a
---
b72d0a
 tests/CMakeLists.txt                          |    4 -
b72d0a
 tests/fixtures.h                              |    2 -
b72d0a
 .../test_xml_parser_main_metadata_together.c  |  298 -----
b72d0a
 .../modified_repo_files/long_primary.xml      | 1060 -----------------
b72d0a
 .../repo_02_different_order_filelists.xml     |   16 -
b72d0a
 5 files changed, 1380 deletions(-)
b72d0a
 delete mode 100644 tests/test_xml_parser_main_metadata_together.c
b72d0a
 delete mode 100644 tests/testdata/modified_repo_files/long_primary.xml
b72d0a
 delete mode 100644 tests/testdata/modified_repo_files/repo_02_different_order_filelists.xml
b72d0a
b72d0a
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
b72d0a
index 4ffe837..3936176 100644
b72d0a
--- a/tests/CMakeLists.txt
b72d0a
+++ b/tests/CMakeLists.txt
b72d0a
@@ -38,10 +38,6 @@ ADD_EXECUTABLE(test_xml_parser_updateinfo test_xml_parser_updateinfo.c)
b72d0a
 TARGET_LINK_LIBRARIES(test_xml_parser_updateinfo libcreaterepo_c ${GLIB2_LIBRARIES})
b72d0a
 ADD_DEPENDENCIES(tests test_xml_parser_updateinfo)
b72d0a
 
b72d0a
-ADD_EXECUTABLE(test_xml_parser_main_metadata_together test_xml_parser_main_metadata_together.c)
b72d0a
-TARGET_LINK_LIBRARIES(test_xml_parser_main_metadata_together libcreaterepo_c ${GLIB2_LIBRARIES})
b72d0a
-ADD_DEPENDENCIES(tests test_xml_parser_main_metadata_together)
b72d0a
-
b72d0a
 ADD_EXECUTABLE(test_xml_dump test_xml_dump.c)
b72d0a
 TARGET_LINK_LIBRARIES(test_xml_dump libcreaterepo_c ${GLIB2_LIBRARIES})
b72d0a
 ADD_DEPENDENCIES(tests test_xml_dump)
b72d0a
diff --git a/tests/fixtures.h b/tests/fixtures.h
b72d0a
index 676518c..a47dd66 100644
b72d0a
--- a/tests/fixtures.h
b72d0a
+++ b/tests/fixtures.h
b72d0a
@@ -85,8 +85,6 @@
b72d0a
 #define TEST_MRF_UE_OTH_00      TEST_MODIFIED_REPO_FILES_PATH"unknown_element_00-other.xml"
b72d0a
 #define TEST_MRF_UE_OTH_01      TEST_MODIFIED_REPO_FILES_PATH"unknown_element_01-other.xml"
b72d0a
 #define TEST_MRF_UE_OTH_02      TEST_MODIFIED_REPO_FILES_PATH"unknown_element_02-other.xml"
b72d0a
-#define TEST_LONG_PRIMARY       TEST_MODIFIED_REPO_FILES_PATH"long_primary.xml"
b72d0a
-#define TEST_DIFF_ORDER_FILELISTS TEST_MODIFIED_REPO_FILES_PATH"repo_02_different_order_filelists.xml"
b72d0a
 
b72d0a
 // Test files
b72d0a
 
b72d0a
diff --git a/tests/test_xml_parser_main_metadata_together.c b/tests/test_xml_parser_main_metadata_together.c
b72d0a
deleted file mode 100644
b72d0a
index a4e4ad7..0000000
b72d0a
--- a/tests/test_xml_parser_main_metadata_together.c
b72d0a
+++ /dev/null
b72d0a
@@ -1,298 +0,0 @@
b72d0a
-/*
b72d0a
- * Copyright (C) 2021 Red Hat, Inc.
b72d0a
- *
b72d0a
- * Licensed under the GNU Lesser General Public License Version 2.1
b72d0a
- *
b72d0a
- * This library is free software; you can redistribute it and/or
b72d0a
- * modify it under the terms of the GNU Lesser General Public
b72d0a
- * License as published by the Free Software Foundation; either
b72d0a
- * version 2.1 of the License, or (at your option) any later version.
b72d0a
- *
b72d0a
- * This library is distributed in the hope that it will be useful,
b72d0a
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
b72d0a
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
b72d0a
- * Lesser General Public License for more details.
b72d0a
- *
b72d0a
- * You should have received a copy of the GNU Lesser General Public
b72d0a
- * License along with this library; if not, write to the Free Software
b72d0a
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
b72d0a
- */
b72d0a
-
b72d0a
-#include <glib.h>
b72d0a
-#include <stdlib.h>
b72d0a
-#include <stdio.h>
b72d0a
-#include "fixtures.h"
b72d0a
-#include "createrepo/error.h"
b72d0a
-#include "createrepo/package.h"
b72d0a
-#include "createrepo/misc.h"
b72d0a
-#include "createrepo/xml_parser.h"
b72d0a
-#include "createrepo/xml_parser_internal.h"
b72d0a
-
b72d0a
-// Callbacks
b72d0a
-
b72d0a
-static int
b72d0a
-pkgcb(cr_Package *pkg, void *cbdata, GError **err)
b72d0a
-{
b72d0a
-    g_assert(pkg);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-    if (cbdata) *((int *)cbdata) += 1;
b72d0a
-    cr_package_free(pkg);
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-pkgcb_interrupt(cr_Package *pkg, void *cbdata, GError **err)
b72d0a
-{
b72d0a
-    g_assert(pkg);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-    if (cbdata) *((int *)cbdata) += 1;
b72d0a
-    cr_package_free(pkg);
b72d0a
-    return CR_CB_RET_ERR;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkgcb_skip_fake_bash(cr_Package **pkg,
b72d0a
-                        G_GNUC_UNUSED const char *pkgId,
b72d0a
-                        const char *name,
b72d0a
-                        G_GNUC_UNUSED const char *arch,
b72d0a
-                        G_GNUC_UNUSED void *cbdata,
b72d0a
-                        GError **err)
b72d0a
-{
b72d0a
-    g_assert(pkg != NULL);
b72d0a
-    g_assert(*pkg == NULL);
b72d0a
-    g_assert(pkgId != NULL);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-
b72d0a
-
b72d0a
-    if (!g_strcmp0(name, "fake_bash")) {
b72d0a
-        return CRE_OK;
b72d0a
-    }
b72d0a
-
b72d0a
-    *pkg = cr_package_new();
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkgcb_interrupt(cr_Package **pkg,
b72d0a
-                   G_GNUC_UNUSED const char *pkgId,
b72d0a
-                   G_GNUC_UNUSED const char *name,
b72d0a
-                   G_GNUC_UNUSED const char *arch,
b72d0a
-                   G_GNUC_UNUSED void *cbdata,
b72d0a
-                   GError **err)
b72d0a
-{
b72d0a
-    g_assert(pkg != NULL);
b72d0a
-    g_assert(*pkg == NULL);
b72d0a
-    g_assert(pkgId != NULL);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    if (cbdata) *((int *)cbdata) += 1;
b72d0a
-
b72d0a
-    return CR_CB_RET_ERR;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-warningcb(G_GNUC_UNUSED cr_XmlParserWarningType type,
b72d0a
-          G_GNUC_UNUSED char *msg,
b72d0a
-          void *cbdata,
b72d0a
-          G_GNUC_UNUSED GError **err)
b72d0a
-{
b72d0a
-    g_assert(type < CR_XML_WARNING_SENTINEL);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    g_string_append((GString *) cbdata, msg);
b72d0a
-    g_string_append((GString *) cbdata, ";");
b72d0a
-
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-warningcb_interrupt(G_GNUC_UNUSED cr_XmlParserWarningType type,
b72d0a
-                    G_GNUC_UNUSED char *msg,
b72d0a
-                    G_GNUC_UNUSED void *cbdata,
b72d0a
-                    G_GNUC_UNUSED GError **err)
b72d0a
-{
b72d0a
-    g_assert(type < CR_XML_WARNING_SENTINEL);
b72d0a
-    g_assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    if (cbdata) *((int *)cbdata) += 1;
b72d0a
-
b72d0a
-    return CR_CB_RET_ERR;
b72d0a
-}
b72d0a
-
b72d0a
-// Tests
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_00(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, &parsed, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 2);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_01_out_of_order_pkgs(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY,
b72d0a
-                                                  TEST_DIFF_ORDER_FILELISTS,
b72d0a
-                                                  TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, &parsed, NULL, NULL, FALSE, &tmp_err);
b72d0a
-    g_assert(tmp_err != NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_XMLPARSER);
b72d0a
-
b72d0a
-    g_clear_error(&tmp_err);
b72d0a
-    ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_DIFF_ORDER_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                              NULL, NULL, pkgcb, &parsed, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 2);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_02_invalid_path(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together("/non/existent/file", TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, &parsed, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err != NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_NOFILE);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_03_newpkgcb_returns_null(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  newpkgcb_skip_fake_bash, NULL, pkgcb, &parsed, NULL, NULL, TRUE,
b72d0a
-                                                  &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 1);
b72d0a
-
b72d0a
-    parsed = 0;
b72d0a
-    ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_DIFF_ORDER_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                              newpkgcb_skip_fake_bash, NULL, pkgcb, &parsed, NULL, NULL, TRUE,
b72d0a
-                                              &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 1);
b72d0a
-
b72d0a
-    parsed = 0;
b72d0a
-    ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_DIFF_ORDER_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                              newpkgcb_skip_fake_bash, NULL, pkgcb, &parsed, NULL, NULL, FALSE,
b72d0a
-                                              &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 1);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_04_newpkgcb_interrupt(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  newpkgcb_interrupt, &parsed, NULL, NULL, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err != NULL);
b72d0a
-    g_error_free(tmp_err);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_CBINTERRUPTED);
b72d0a
-    g_assert_cmpint(parsed, ==, 1);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_05_pkgcb_interrupt(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb_interrupt, &parsed, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err != NULL);
b72d0a
-    g_error_free(tmp_err);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_CBINTERRUPTED);
b72d0a
-    g_assert_cmpint(parsed, ==, 1);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_06_warnings_bad_file_type(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    char *warnmsgs;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    GString *warn_strings = g_string_new(0);
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_MRF_BAD_TYPE_FIL, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, &parsed, warningcb, warn_strings, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 2);
b72d0a
-    warnmsgs = g_string_free(warn_strings, FALSE);
b72d0a
-    g_assert_cmpstr(warnmsgs, ==, "Unknown file type \"foo\";");
b72d0a
-    g_free(warnmsgs);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_07_warningcb_interrupt(void)
b72d0a
-{
b72d0a
-    int numofwarnings = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_REPO_02_PRIMARY, TEST_MRF_BAD_TYPE_FIL, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, NULL, warningcb_interrupt, &numofwarnings,
b72d0a
-                                                  TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err != NULL);
b72d0a
-    g_error_free(tmp_err);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_CBINTERRUPTED);
b72d0a
-    g_assert_cmpint(numofwarnings, ==, 1);
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-test_cr_xml_parse_main_metadata_together_08_long_primary(void)
b72d0a
-{
b72d0a
-    int parsed = 0;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int ret = cr_xml_parse_main_metadata_together(TEST_LONG_PRIMARY, TEST_REPO_02_FILELISTS, TEST_REPO_02_OTHER,
b72d0a
-                                                  NULL, NULL, pkgcb, &parsed, NULL, NULL, TRUE, &tmp_err);
b72d0a
-    g_assert(tmp_err == NULL);
b72d0a
-    g_assert_cmpint(ret, ==, CRE_OK);
b72d0a
-    g_assert_cmpint(parsed, ==, 2);
b72d0a
-}
b72d0a
-
b72d0a
-int
b72d0a
-main(int argc, char *argv[])
b72d0a
-{
b72d0a
-    g_test_init(&argc, &argv, NULL);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_00",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_00);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_01_out_of_order_pkgs",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_01_out_of_order_pkgs);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_02_invalid_path",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_02_invalid_path);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_03_newpkgcb_returns_null",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_03_newpkgcb_returns_null);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_04_newpkgcb_interrupt",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_04_newpkgcb_interrupt);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_05_pkgcb_interrupt",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_05_pkgcb_interrupt);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_06_warnings_bad_file_type",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_06_warnings_bad_file_type);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_07_warningcb_interrupt",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_07_warningcb_interrupt);
b72d0a
-
b72d0a
-    g_test_add_func("/xml_parser_filelists/test_cr_xml_parse_main_metadata_together_08_long_primary",
b72d0a
-                    test_cr_xml_parse_main_metadata_together_08_long_primary);
b72d0a
-
b72d0a
-    return g_test_run();
b72d0a
-}
b72d0a
diff --git a/tests/testdata/modified_repo_files/long_primary.xml b/tests/testdata/modified_repo_files/long_primary.xml
b72d0a
deleted file mode 100644
b72d0a
index 41d8a89..0000000
b72d0a
--- a/tests/testdata/modified_repo_files/long_primary.xml
b72d0a
+++ /dev/null
b72d0a
@@ -1,1060 +0,0 @@
b72d0a
-
b72d0a
-<metadata xmlns="http://linux.duke.edu/metadata/common" xmlns:rpm="http://linux.duke.edu/metadata/rpm" packages="2">
b72d0a
-<package type="rpm">
b72d0a
-  <name>fake_bash</name>
b72d0a
-  <arch>x86_64</arch>
b72d0a
-  <version epoch="0" ver="1.1.1" rel="1"/>
b72d0a
-  <checksum type="sha256" pkgid="YES">90f61e546938a11449b710160ad294618a5bd3062e46f8cf851fd0088af184b7</checksum>
b72d0a
-  <summary>Fake bash</summary>
b72d0a
-  <description>Fake bash package</description>
b72d0a
-  <packager></packager>
b72d0a
-  <url>http://fake_bash_shell.com/</url>
b72d0a
-  <time file="1334670842" build="1334670842"/>
b72d0a
-  <size package="2237" installed="0" archive="256"/>
b72d0a
-<location href="fake_bash-1.1.1-1.x86_64.rpm"/>
b72d0a
-  <format>
b72d0a
-    <rpm:license>GPL</rpm:license>
b72d0a
-    <rpm:vendor/>
b72d0a
-    <rpm:group>System Environment/Shells</rpm:group>
b72d0a
-    <rpm:buildhost>localhost.localdomain</rpm:buildhost>
b72d0a
-    <rpm:sourcerpm>fake_bash-1.1.1-1.src.rpm</rpm:sourcerpm>
b72d0a
-    <rpm:header-range start="280" end="2057"/>
b72d0a
-    <rpm:provides>
b72d0a
-      <rpm:entry name="bash"/>
b72d0a
-      <rpm:entry name="fake_bash" flags="EQ" epoch="0" ver="1.1.1" rel="1"/>
b72d0a
-      <rpm:entry name="fake_bash(x86-64)" flags="EQ" epoch="0" ver="1.1.1" rel="1"/>
b72d0a
-    </rpm:provides>
b72d0a
-    <rpm:requires>
b72d0a
-      <rpm:entry name="super_kernel"/>
b72d0a
-    </rpm:requires>
b72d0a
-    <file>/usr/bin/fake_bash</file>
b72d0a
-  </format>
b72d0a
-</package>
b72d0a
-<package type="rpm">
b72d0a
-  <name>super_kernel</name>
b72d0a
-  <arch>x86_64</arch>
b72d0a
-  <version epoch="0" ver="6.0.1" rel="2"/>
b72d0a
-  <checksum type="sha256" pkgid="YES">6d43a638af70ef899933b1fd86a866f18f65b0e0e17dcbf2e42bfd0cdd7c63c3</checksum>
b72d0a
-  <summary>Test package</summary>
b72d0a
-  <description>This package has provides, requires, obsoletes, conflicts options.</description>
b72d0a
-  <packager></packager>
b72d0a
-  <url>http://so_super_kernel.com/it_is_awesome/yep_it_really_is</url>
b72d0a
-  <time file="1334670843" build="1334670843"/>
b72d0a
-  <size package="2845" installed="0" archive="404"/>
b72d0a
-<location href="super_kernel-6.0.1-2.x86_64.rpm"/>
b72d0a
-  <format>
b72d0a
-    <rpm:license>LGPLv2</rpm:license>
b72d0a
-    <rpm:vendor/>
b72d0a
-    <rpm:group>Applications/System</rpm:group>
b72d0a
-    <rpm:buildhost>localhost.localdomain</rpm:buildhost>
b72d0a
-    <rpm:sourcerpm>super_kernel-6.0.1-2.src.rpm</rpm:sourcerpm>
b72d0a
-    <rpm:header-range start="280" end="2637"/>
b72d0a
-    <rpm:provides>
b72d0a
-      <rpm:entry name="not_so_super_kernel" flags="LT" epoch="0" ver="5.8.0"/>
b72d0a
-      <rpm:entry name="super_kernel" flags="EQ" epoch="0" ver="6.0.0"/>
b72d0a
-      <rpm:entry name="super_kernel" flags="EQ" epoch="0" ver="6.0.1" rel="2"/>
b72d0a
-      <rpm:entry name="super_kernel(x86-64)" flags="EQ" epoch="0" ver="6.0.1" rel="2"/>
b72d0a
-    </rpm:provides>
b72d0a
-    <rpm:requires>
b72d0a
-      <rpm:entry name="bzip2" flags="GE" epoch="0" ver="1.0.0" pre="1"/>
b72d0a
-      <rpm:entry name="expat" pre="1"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.26.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.27.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.28.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.29.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.30.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.31.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.32.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.33.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.34.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.35.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.36.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.37.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.38.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.39.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.40.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.41.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.42.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.43.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.44.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.45.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.46.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.47.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.48.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.49.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.50.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.51.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.52.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.53.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.54.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.55.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.56.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.57.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.58.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.59.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.60.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.61.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.62.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.63.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.64.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.65.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.66.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.67.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.68.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.69.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.70.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.71.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.72.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.73.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.74.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.75.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.76.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.77.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.78.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.79.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.80.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.81.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.82.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.83.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.84.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.85.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.86.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.87.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.88.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.89.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.90.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.91.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.92.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.93.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.94.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.95.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.96.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.97.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.98.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.99.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.100.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.101.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.102.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.103.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.104.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.105.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.106.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.107.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.108.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.109.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.110.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.111.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.112.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.113.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.114.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.115.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.116.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.117.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.118.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.119.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.120.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.121.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.122.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.123.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.124.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.125.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.126.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.127.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.128.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.129.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.130.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.131.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.132.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.133.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.134.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.135.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.136.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.137.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.138.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.139.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.140.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.141.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.142.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.143.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.144.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.145.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.146.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.147.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.148.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.149.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.150.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.151.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.152.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.153.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.154.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.155.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.156.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.157.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.158.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.159.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.160.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.161.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.162.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.163.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.164.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.165.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.166.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.167.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.168.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.169.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.170.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.171.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.172.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.173.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.174.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.175.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.176.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.177.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.178.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.179.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.180.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.181.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.182.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.183.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.184.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.185.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.186.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.187.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.188.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.189.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.190.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.191.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.192.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.193.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.194.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.195.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.196.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.197.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.198.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.199.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.200.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.201.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.202.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.203.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.204.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.205.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.206.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.207.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.208.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.209.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.210.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.211.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.212.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.213.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.214.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.215.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.216.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.217.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.218.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.219.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.220.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.221.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.222.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.223.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.224.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.225.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.226.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.227.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.228.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.229.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.230.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.231.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.232.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.233.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.234.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.235.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.236.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.237.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.238.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.239.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.240.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.241.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.242.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.243.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.244.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.245.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.246.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.247.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.248.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.249.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.250.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.251.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.252.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.253.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.254.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.255.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.256.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.257.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.258.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.259.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.260.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.261.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.262.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.263.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.264.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.265.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.266.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.267.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.268.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.269.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.270.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.271.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.272.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.273.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.274.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.275.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.276.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.277.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.278.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.279.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.280.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.281.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.282.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.283.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.284.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.285.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.286.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.287.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.288.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.289.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.290.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.291.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.292.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.293.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.294.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.295.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.296.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.297.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.298.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.299.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.300.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.301.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.302.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.303.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.304.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.305.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.306.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.307.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.308.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.309.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.310.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.311.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.312.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.313.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.314.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.315.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.316.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.317.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.318.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.319.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.320.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.321.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.322.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.323.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.324.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.325.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.326.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.327.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.328.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.329.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.330.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.331.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.332.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.333.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.334.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.335.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.336.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.337.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.338.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.339.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.340.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.341.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.342.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.343.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.344.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.345.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.346.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.347.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.348.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.349.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.350.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.351.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.352.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.353.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.354.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.355.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.356.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.357.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.358.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.359.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.360.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.361.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.362.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.363.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.364.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.365.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.366.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.367.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.368.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.369.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.370.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.371.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.372.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.373.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.374.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.375.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.376.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.377.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.378.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.379.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.380.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.381.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.382.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.383.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.384.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.385.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.386.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.387.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.388.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.389.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.390.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.391.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.392.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.393.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.394.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.395.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.396.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.397.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.398.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.399.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.400.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.401.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.402.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.403.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.404.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.405.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.406.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.407.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.408.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.409.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.410.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.411.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.412.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.413.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.414.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.415.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.416.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.417.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.418.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.419.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.420.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.421.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.422.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.423.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.424.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.425.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.426.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.427.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.428.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.429.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.430.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.431.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.432.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.433.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.434.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.435.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.436.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.437.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.438.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.439.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.440.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.441.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.442.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.443.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.444.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.445.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.446.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.447.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.448.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.449.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.450.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.451.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.452.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.453.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.454.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.455.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.456.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.457.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.458.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.459.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.460.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.461.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.462.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.463.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.464.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.465.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.466.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.467.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.468.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.469.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.470.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.471.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.472.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.473.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.474.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.475.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.476.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.477.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.478.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.479.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.480.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.481.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.482.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.483.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.484.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.485.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.486.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.487.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.488.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.489.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.490.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.491.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.492.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.493.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.494.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.495.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.496.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.497.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.498.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.499.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.500.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.501.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.502.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.503.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.504.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.505.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.506.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.507.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.508.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.509.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.510.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.511.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.512.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.513.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.514.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.515.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.516.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.517.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.518.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.519.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.520.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.521.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.522.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.523.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.524.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.525.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.526.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.527.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.528.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.529.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.530.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.531.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.532.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.533.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.534.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.535.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.536.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.537.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.538.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.539.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.540.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.541.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.542.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.543.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.544.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.545.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.546.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.547.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.548.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.549.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.550.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.551.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.552.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.553.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.554.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.555.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.556.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.557.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.558.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.559.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.560.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.561.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.562.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.563.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.564.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.565.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.566.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.567.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.568.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.569.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.570.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.571.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.572.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.573.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.574.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.575.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.576.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.577.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.578.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.579.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.580.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.581.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.582.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.583.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.584.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.585.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.586.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.587.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.588.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.589.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.590.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.591.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.592.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.593.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.594.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.595.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.596.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.597.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.598.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.599.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.600.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.601.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.602.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.603.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.604.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.605.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.606.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.607.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.608.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.609.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.610.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.611.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.612.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.613.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.614.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.615.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.616.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.617.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.618.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.619.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.620.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.621.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.622.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.623.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.624.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.625.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.626.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.627.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.628.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.629.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.630.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.631.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.632.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.633.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.634.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.635.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.636.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.637.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.638.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.639.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.640.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.641.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.642.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.643.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.644.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.645.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.646.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.647.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.648.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.649.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.650.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.651.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.652.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.653.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.654.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.655.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.656.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.657.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.658.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.659.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.660.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.661.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.662.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.663.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.664.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.665.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.666.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.667.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.668.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.669.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.670.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.671.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.672.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.673.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.674.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.675.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.676.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.677.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.678.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.679.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.680.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.681.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.682.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.683.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.684.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.685.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.686.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.687.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.688.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.689.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.690.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.691.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.692.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.693.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.694.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.695.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.696.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.697.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.698.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.699.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.700.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.701.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.702.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.703.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.704.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.705.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.706.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.707.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.708.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.709.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.710.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.711.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.712.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.713.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.714.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.715.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.716.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.717.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.718.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.719.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.720.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.721.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.722.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.723.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.724.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.725.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.726.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.727.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.728.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.729.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.730.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.731.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.732.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.733.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.734.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.735.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.736.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.737.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.738.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.739.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.740.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.741.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.742.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.743.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.744.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.745.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.746.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.747.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.748.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.749.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.750.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.751.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.752.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.753.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.754.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.755.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.756.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.757.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.758.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.759.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.760.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.761.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.762.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.763.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.764.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.765.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.766.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.767.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.768.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.769.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.770.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.771.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.772.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.773.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.774.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.775.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.776.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.777.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.778.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.779.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.780.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.781.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.782.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.783.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.784.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.785.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.786.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.787.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.788.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.789.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.790.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.791.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.792.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.793.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.794.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.795.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.796.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.797.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.798.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.799.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.800.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.801.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.802.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.803.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.804.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.805.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.806.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.807.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.808.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.809.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.810.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.811.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.812.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.813.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.814.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.815.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.816.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.817.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.818.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.819.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.820.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.821.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.822.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.823.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.824.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.825.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.826.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.827.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.828.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.829.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.830.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.831.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.832.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.833.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.834.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.835.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.836.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.837.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.838.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.839.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.840.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.841.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.842.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.843.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.844.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.845.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.846.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.847.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.848.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.849.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.850.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.851.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.852.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.853.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.854.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.855.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.856.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.857.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.858.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.859.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.860.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.861.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.862.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.863.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.864.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.865.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.866.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.867.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.868.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.869.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.870.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.871.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.872.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.873.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.874.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.875.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.876.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.877.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.878.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.879.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.880.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.881.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.882.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.883.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.884.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.885.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.886.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.887.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.888.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.889.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.890.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.891.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.892.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.893.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.894.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.895.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.896.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.897.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.898.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.899.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.900.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.901.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.902.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.903.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.904.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.905.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.906.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.907.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.908.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.909.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.910.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.911.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.912.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.913.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.914.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.915.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.916.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.917.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.918.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.919.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.920.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.921.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.922.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.923.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.924.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.925.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.926.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.927.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.928.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.929.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.930.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.931.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.932.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.933.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.934.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.935.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.936.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.937.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.938.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.939.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.940.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.941.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.942.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.943.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.944.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.945.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.946.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.947.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.948.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.949.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.950.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.951.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.952.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.953.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.954.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.955.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.956.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.957.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.958.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.959.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.960.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.961.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.962.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.963.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.964.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.965.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.966.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.967.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.968.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.969.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.970.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.971.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.972.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.973.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.974.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.975.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.976.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.977.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.978.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.979.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.980.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.981.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.982.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.983.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.984.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.985.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.986.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.987.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.988.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.989.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.990.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.991.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.992.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.993.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.994.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.995.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.996.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.997.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.998.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.999.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1000.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1001.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1002.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1003.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1004.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1005.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1006.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1007.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1008.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1009.0"/>
b72d0a
-      <rpm:entry name="glib" flags="GE" epoch="0" ver="2.1010.0"/>
b72d0a
-      <rpm:entry name="zlib"/>
b72d0a
-    </rpm:requires>
b72d0a
-    <rpm:conflicts>
b72d0a
-      <rpm:entry name="kernel"/>
b72d0a
-      <rpm:entry name="super_kernel" flags="EQ" epoch="0" ver="5.0.0"/>
b72d0a
-      <rpm:entry name="super_kernel" flags="LT" epoch="0" ver="4.0.0"/>
b72d0a
-    </rpm:conflicts>
b72d0a
-    <rpm:obsoletes>
b72d0a
-      <rpm:entry name="kernel"/>
b72d0a
-      <rpm:entry name="super_kernel" flags="EQ" epoch="0" ver="5.9.0"/>
b72d0a
-    </rpm:obsoletes>
b72d0a
-    <file>/usr/bin/super_kernel</file>
b72d0a
-  </format>
b72d0a
-</package>
b72d0a
-</metadata>
b72d0a
diff --git a/tests/testdata/modified_repo_files/repo_02_different_order_filelists.xml b/tests/testdata/modified_repo_files/repo_02_different_order_filelists.xml
b72d0a
deleted file mode 100644
b72d0a
index 4953c95..0000000
b72d0a
--- a/tests/testdata/modified_repo_files/repo_02_different_order_filelists.xml
b72d0a
+++ /dev/null
b72d0a
@@ -1,16 +0,0 @@
b72d0a
-
b72d0a
-<filelists xmlns="http://linux.duke.edu/metadata/filelists" packages="2">
b72d0a
-<package pkgid="6d43a638af70ef899933b1fd86a866f18f65b0e0e17dcbf2e42bfd0cdd7c63c3" name="super_kernel" arch="x86_64">
b72d0a
-    <version epoch="0" ver="6.0.1" rel="2"/>
b72d0a
-
b72d0a
-    <file>/usr/bin/super_kernel</file>
b72d0a
-    <file>/usr/share/man/super_kernel.8.gz</file>
b72d0a
-</package>
b72d0a
-
b72d0a
-<package pkgid="90f61e546938a11449b710160ad294618a5bd3062e46f8cf851fd0088af184b7" name="fake_bash" arch="x86_64">
b72d0a
-    <version epoch="0" ver="1.1.1" rel="1"/>
b72d0a
-
b72d0a
-    <file>/usr/bin/fake_bash</file>
b72d0a
-</package>
b72d0a
-
b72d0a
-</filelists>
b72d0a
-- 
b72d0a
2.35.1
b72d0a
b72d0a
b72d0a
From 16f3c1f1abe995fc1c0023f9109b7f5d520ff4b4 Mon Sep 17 00:00:00 2001
b72d0a
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
b72d0a
Date: Wed, 9 Mar 2022 15:24:05 +0100
b72d0a
Subject: [PATCH 5/5] Revert "Add c API for parsing metadata together"
b72d0a
b72d0a
This reverts commit ff0912d2a89722700f001ef462abd730dacaa8e7.
b72d0a
---
b72d0a
 src/CMakeLists.txt                      |   1 -
b72d0a
 src/xml_parser.h                        |  39 --
b72d0a
 src/xml_parser_main_metadata_together.c | 468 ------------------------
b72d0a
 3 files changed, 508 deletions(-)
b72d0a
 delete mode 100644 src/xml_parser_main_metadata_together.c
b72d0a
b72d0a
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
b72d0a
index b3ca9e6..64de052 100644
b72d0a
--- a/src/CMakeLists.txt
b72d0a
+++ b/src/CMakeLists.txt
b72d0a
@@ -31,7 +31,6 @@ SET (createrepo_c_SRCS
b72d0a
      xml_parser_primary.c
b72d0a
      xml_parser_repomd.c
b72d0a
      xml_parser_updateinfo.c
b72d0a
-     xml_parser_main_metadata_together.c
b72d0a
      koji.c)
b72d0a
 
b72d0a
 SET(headers
b72d0a
diff --git a/src/xml_parser.h b/src/xml_parser.h
b72d0a
index 5ce7c0e..a31718d 100644
b72d0a
--- a/src/xml_parser.h
b72d0a
+++ b/src/xml_parser.h
b72d0a
@@ -278,45 +278,6 @@ cr_xml_parse_updateinfo(const char *path,
b72d0a
                         void *warningcb_data,
b72d0a
                         GError **err);
b72d0a
 
b72d0a
-/** Parse all 3 main metadata types (primary, filelists and other) at the same time.
b72d0a
- * Once a package is fully parsed pkgcb is called which transfers ownership of the package
b72d0a
- * to the user, cr_xml_parse_main_metadata_together no longer needs it and it can be freed.
b72d0a
- * This means we don't have store all the packages in memory at the same time, which
b72d0a
- * significantly reduces the memory footprint.
b72d0a
- * Input metadata files can be compressed.
b72d0a
- * @param primary_path       Path to a primary xml file.
b72d0a
- * @param filelists_path     Path to a filelists xml file.
b72d0a
- * @param other_path         Path to an other xml file.
b72d0a
- * @param newpkgcb           Callback for a new package. Called when the new package
b72d0a
- *                           xml chunk is found and a package object to store
b72d0a
- *                           the data is needed.
b72d0a
- * @param newpkgcb_data      User data for the newpkgcb.
b72d0a
- * @param pkgcb              Package callback. Called when a package is completely
b72d0a
- *                           parsed containing information from all 3 main metadata
b72d0a
- *                           files. Could be NULL if newpkgcb is not NULL.
b72d0a
- * @param pkgcb_data         User data for the pkgcb.
b72d0a
- * @param warningcb          Callback for warning messages.
b72d0a
- * @param warningcb_data     User data for the warningcb.
b72d0a
- * @param allow_out_of_order Whether we should allow different order of packages
b72d0a
- *                           among the main metadata files. If allowed, the more
b72d0a
- *                           the order varies the more memory we will need to
b72d0a
- *                           store all the started but unfinished packages.
b72d0a
- * @param err                GError **
b72d0a
- * @return                   cr_Error code.
b72d0a
- */
b72d0a
-int
b72d0a
-cr_xml_parse_main_metadata_together(const char *primary_path,
b72d0a
-                                    const char *filelists_path,
b72d0a
-                                    const char *other_path,
b72d0a
-                                    cr_XmlParserNewPkgCb newpkgcb,
b72d0a
-                                    void *newpkgcb_data,
b72d0a
-                                    cr_XmlParserPkgCb pkgcb,
b72d0a
-                                    void *pkgcb_data,
b72d0a
-                                    cr_XmlParserWarningCb warningcb,
b72d0a
-                                    void *warningcb_data,
b72d0a
-                                    gboolean allow_out_of_order,
b72d0a
-                                    GError **err);
b72d0a
-
b72d0a
 /** @} */
b72d0a
 
b72d0a
 #ifdef __cplusplus
b72d0a
diff --git a/src/xml_parser_main_metadata_together.c b/src/xml_parser_main_metadata_together.c
b72d0a
deleted file mode 100644
b72d0a
index 9347c79..0000000
b72d0a
--- a/src/xml_parser_main_metadata_together.c
b72d0a
+++ /dev/null
b72d0a
@@ -1,468 +0,0 @@
b72d0a
-/*
b72d0a
- * Copyright (C) 2021 Red Hat, Inc.
b72d0a
- *
b72d0a
- * Licensed under the GNU Lesser General Public License Version 2.1
b72d0a
- *
b72d0a
- * This library is free software; you can redistribute it and/or
b72d0a
- * modify it under the terms of the GNU Lesser General Public
b72d0a
- * License as published by the Free Software Foundation; either
b72d0a
- * version 2.1 of the License, or (at your option) any later version.
b72d0a
- *
b72d0a
- * This library is distributed in the hope that it will be useful,
b72d0a
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
b72d0a
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
b72d0a
- * Lesser General Public License for more details.
b72d0a
- *
b72d0a
- * You should have received a copy of the GNU Lesser General Public
b72d0a
- * License along with this library; if not, write to the Free Software
b72d0a
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
b72d0a
- */
b72d0a
-
b72d0a
-#include <glib.h>
b72d0a
-#include <glib/gprintf.h>
b72d0a
-#include <assert.h>
b72d0a
-#include <errno.h>
b72d0a
-#include "error.h"
b72d0a
-#include "xml_parser.h"
b72d0a
-#include "xml_parser_internal.h"
b72d0a
-#include "package_internal.h"
b72d0a
-#include "misc.h"
b72d0a
-
b72d0a
-#define ERR_DOMAIN      CREATEREPO_C_ERROR
b72d0a
-
b72d0a
-typedef struct {
b72d0a
-    GHashTable           *in_progress_pkgs_hash; //used only when allowing out of order pkgs
b72d0a
-    GSList               *in_progress_pkgs_list; // used only when not allowing out of order pkgs
b72d0a
-    int                  in_progress_count_primary;
b72d0a
-    int                  in_progress_count_filelists;
b72d0a
-    int                  in_progress_count_other;
b72d0a
-    cr_XmlParserNewPkgCb newpkgcb;      // newpkgcb passed in from user
b72d0a
-    void                 *newpkgcb_data;// newpkgcb data passed in from user
b72d0a
-    cr_XmlParserPkgCb    pkgcb;         // pkgcb passed in from user
b72d0a
-    void                 *pkgcb_data;   // pkgcb data passed in from user
b72d0a
-} cr_CbData;
b72d0a
-
b72d0a
-static int
b72d0a
-call_user_callback_if_package_finished(cr_Package *pkg, cr_CbData *cb_data, GError **err)
b72d0a
-{
b72d0a
-    if (pkg && (pkg->loadingflags & CR_PACKAGE_LOADED_PRI) && (pkg->loadingflags & CR_PACKAGE_LOADED_OTH) &&
b72d0a
-        (pkg->loadingflags & CR_PACKAGE_LOADED_FIL))
b72d0a
-    {
b72d0a
-        if (cb_data->in_progress_pkgs_hash) {
b72d0a
-            g_hash_table_remove(cb_data->in_progress_pkgs_hash, pkg->pkgId);
b72d0a
-        } else {
b72d0a
-            //remove first element in the list
b72d0a
-            cb_data->in_progress_pkgs_list = cb_data->in_progress_pkgs_list->next;
b72d0a
-        }
b72d0a
-
b72d0a
-        // One package was fully finished
b72d0a
-        cb_data->in_progress_count_primary--;
b72d0a
-        cb_data->in_progress_count_filelists--;
b72d0a
-        cb_data->in_progress_count_other--;
b72d0a
-
b72d0a
-        // call user package callback
b72d0a
-        GError *tmp_err = NULL;
b72d0a
-        if (cb_data->pkgcb && cb_data->pkgcb(pkg, cb_data->pkgcb_data, &tmp_err)) {
b72d0a
-            if (tmp_err)
b72d0a
-                g_propagate_prefixed_error(err, tmp_err, "Parsing interrupted: ");
b72d0a
-            else
b72d0a
-                g_set_error(err, ERR_DOMAIN, CRE_CBINTERRUPTED, "Parsing interrupted");
b72d0a
-            return CR_CB_RET_ERR;
b72d0a
-        } else {
b72d0a
-            // If callback return CRE_OK but it simultaneously set
b72d0a
-            // the tmp_err then it's a programming error.
b72d0a
-            assert(tmp_err == NULL);
b72d0a
-        };
b72d0a
-    }
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static cr_Package*
b72d0a
-find_in_progress_pkg(cr_CbData *cb_data, const char *pkgId, int in_progress_pkg_index, GError **err)
b72d0a
-{
b72d0a
-    gpointer pval = NULL;
b72d0a
-    if (cb_data->in_progress_pkgs_hash) {
b72d0a
-        if (!g_hash_table_lookup_extended(cb_data->in_progress_pkgs_hash, pkgId, NULL, &pval)) {
b72d0a
-            pval = NULL;
b72d0a
-        }
b72d0a
-    } else {
b72d0a
-        // This is checking out of order pkgs because if we don't have in_progress_pkgs_hash -> we enforce
b72d0a
-        // order by using a list
b72d0a
-        pval = g_slist_nth_data(cb_data->in_progress_pkgs_list, in_progress_pkg_index);
b72d0a
-        if (pval && g_strcmp0(((cr_Package *) pval)->pkgId, pkgId)) {
b72d0a
-            g_set_error(err, ERR_DOMAIN, CRE_XMLPARSER,
b72d0a
-                        "Out of order metadata: %s vs %s.", ((cr_Package *) pval)->pkgId, pkgId);
b72d0a
-            pval = NULL;
b72d0a
-        }
b72d0a
-    }
b72d0a
-
b72d0a
-    return pval;
b72d0a
-}
b72d0a
-
b72d0a
-static void
b72d0a
-store_in_progress_pkg(cr_CbData *cb_data, cr_Package *pkg, const char *pkgId)
b72d0a
-{
b72d0a
-    if (!pkg) {
b72d0a
-        return;
b72d0a
-    }
b72d0a
-    if (cb_data->in_progress_pkgs_hash) {
b72d0a
-        g_hash_table_insert(cb_data->in_progress_pkgs_hash, g_strdup(pkgId), pkg);
b72d0a
-    } else {
b72d0a
-        cb_data->in_progress_pkgs_list = g_slist_append(cb_data->in_progress_pkgs_list, pkg);
b72d0a
-    }
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkgcb_primary(cr_Package **pkg,
b72d0a
-                    G_GNUC_UNUSED const char *pkgId,
b72d0a
-                    G_GNUC_UNUSED const char *name,
b72d0a
-                    G_GNUC_UNUSED const char *arch,
b72d0a
-                    G_GNUC_UNUSED void *cbdata,
b72d0a
-                    GError **err)
b72d0a
-{
b72d0a
-    assert(pkg && *pkg == NULL);
b72d0a
-    assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    // This callback is called when parsing of the opening element of a package
b72d0a
-    // is done. However because the opening element doesn't contain pkgId
b72d0a
-    // (instead it looks like: <package type="rpm">) we cannot check if we
b72d0a
-    // already have this package.
b72d0a
-    // The only option is to create a new package and after its fully
b72d0a
-    // parsed (in pkgcb_primary) either use this package or copy its data
b72d0a
-    // into an already existing one.
b72d0a
-    // Filelists and other have pkgId present in the opening element so we can
b72d0a
-    // avoid this overhead.
b72d0a
-    *pkg = cr_package_new();
b72d0a
-
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkg_general(cr_Package **pkg,
b72d0a
-                 const char *pkgId,
b72d0a
-                 const char *name,
b72d0a
-                 const char *arch,
b72d0a
-                 void *cbdata,
b72d0a
-                 int in_progress_count,
b72d0a
-                 GError **err)
b72d0a
-{
b72d0a
-    assert(pkg && *pkg == NULL);
b72d0a
-    assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-
b72d0a
-    GError *out_of_order_err = NULL;
b72d0a
-    *pkg = find_in_progress_pkg(cb_data, pkgId, in_progress_count, &out_of_order_err);
b72d0a
-
b72d0a
-    if (!*pkg) {
b72d0a
-        // we are handling never before seen package
b72d0a
-
b72d0a
-        if (cb_data->newpkgcb) {
b72d0a
-            // user specified their own new function: call it
b72d0a
-            if (cb_data->newpkgcb(pkg, pkgId, name, arch, cb_data->newpkgcb_data, err)) {
b72d0a
-                return CR_CB_RET_ERR;
b72d0a
-            }
b72d0a
-            if (!*pkg) {
b72d0a
-                // when the user callback doesn't return a pkg we should skip it,
b72d0a
-                // this means out of order error doesn't apply
b72d0a
-                g_clear_error(&out_of_order_err);
b72d0a
-            }
b72d0a
-        } else {
b72d0a
-            *pkg = cr_package_new();
b72d0a
-        }
b72d0a
-
b72d0a
-        store_in_progress_pkg(cb_data, *pkg, pkgId);
b72d0a
-    }
b72d0a
-
b72d0a
-    if (*err) {
b72d0a
-        return CR_CB_RET_ERR;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (out_of_order_err) {
b72d0a
-        g_propagate_error(err, out_of_order_err);
b72d0a
-        return CR_CB_RET_ERR;
b72d0a
-    }
b72d0a
-
b72d0a
-    return CR_CB_RET_OK;
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkgcb_filelists(cr_Package **pkg,
b72d0a
-                   const char *pkgId,
b72d0a
-                   G_GNUC_UNUSED const char *name,
b72d0a
-                   G_GNUC_UNUSED const char *arch,
b72d0a
-                   void *cbdata,
b72d0a
-                   GError **err)
b72d0a
-{
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-    return newpkg_general(pkg, pkgId, name, arch, cbdata, cb_data->in_progress_count_filelists, err);
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-newpkgcb_other(cr_Package **pkg,
b72d0a
-               const char *pkgId,
b72d0a
-               G_GNUC_UNUSED const char *name,
b72d0a
-               G_GNUC_UNUSED const char *arch,
b72d0a
-               void *cbdata,
b72d0a
-               GError **err)
b72d0a
-{
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-    return newpkg_general(pkg, pkgId, name, arch, cbdata, cb_data->in_progress_count_other, err);
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-pkgcb_filelists(cr_Package *pkg, void *cbdata, G_GNUC_UNUSED GError **err)
b72d0a
-{
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-    cb_data->in_progress_count_filelists++;
b72d0a
-    pkg->loadingflags |= CR_PACKAGE_LOADED_FIL;
b72d0a
-    return call_user_callback_if_package_finished(pkg, cb_data, err);
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-pkgcb_other(cr_Package *pkg, void *cbdata, G_GNUC_UNUSED GError **err)
b72d0a
-{
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-    cb_data->in_progress_count_other++;
b72d0a
-    pkg->loadingflags |= CR_PACKAGE_LOADED_OTH;
b72d0a
-    return call_user_callback_if_package_finished(pkg, cb_data, err);
b72d0a
-}
b72d0a
-
b72d0a
-static int
b72d0a
-pkgcb_primary(cr_Package *pkg, void *cbdata, G_GNUC_UNUSED GError **err)
b72d0a
-{
b72d0a
-    cr_CbData *cb_data = cbdata;
b72d0a
-
b72d0a
-    GError *out_of_order_err = NULL;
b72d0a
-    cr_Package *in_progress_pkg = find_in_progress_pkg(cb_data, pkg->pkgId, cb_data->in_progress_count_primary,
b72d0a
-                                                       &out_of_order_err);
b72d0a
-    if (in_progress_pkg) {
b72d0a
-        // package was already encountered in some other metadata type
b72d0a
-
b72d0a
-        cr_package_copy_into(pkg, in_progress_pkg);
b72d0a
-        cr_package_free(pkg);
b72d0a
-        pkg = in_progress_pkg;
b72d0a
-    } else {
b72d0a
-        // we are handling never before seen package
b72d0a
-
b72d0a
-        if (cb_data->newpkgcb) {
b72d0a
-            // user specified their own new function: call it and copy package data into user_created_pkg
b72d0a
-            cr_Package *user_created_pkg = NULL;
b72d0a
-            if (cb_data->newpkgcb(&user_created_pkg, pkg->pkgId, pkg->name, pkg->arch, cb_data->newpkgcb_data, err)) {
b72d0a
-                return CR_CB_RET_ERR;
b72d0a
-            } else {
b72d0a
-                if (user_created_pkg) {
b72d0a
-                    cr_package_copy_into(pkg, user_created_pkg);
b72d0a
-                }
b72d0a
-                // user_created_pkg can be NULL if newpkgcb returns OK but
b72d0a
-                // not an allocated pkg -> this means we should skip it
b72d0a
-                store_in_progress_pkg(cb_data, user_created_pkg, pkg->pkgId);
b72d0a
-                cr_package_free(pkg);
b72d0a
-                pkg = user_created_pkg;
b72d0a
-            }
b72d0a
-            if (!pkg) {
b72d0a
-                // when the user callback doesn't return a pkg we should skip it,
b72d0a
-                // this means out of order error doesn't apply
b72d0a
-                g_clear_error(&out_of_order_err);
b72d0a
-            }
b72d0a
-        } else {
b72d0a
-            store_in_progress_pkg(cb_data, pkg, pkg->pkgId);
b72d0a
-        }
b72d0a
-
b72d0a
-    }
b72d0a
-
b72d0a
-    if (*err) {
b72d0a
-        return CR_CB_RET_ERR;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (out_of_order_err) {
b72d0a
-        g_propagate_error(err, out_of_order_err);
b72d0a
-        return CR_CB_RET_ERR;
b72d0a
-    }
b72d0a
-
b72d0a
-
b72d0a
-    if (pkg) {
b72d0a
-        cb_data->in_progress_count_primary++;
b72d0a
-        pkg->loadingflags |= CR_PACKAGE_LOADED_PRI;
b72d0a
-        pkg->loadingflags |= CR_PACKAGE_FROM_XML;
b72d0a
-    }
b72d0a
-
b72d0a
-    return call_user_callback_if_package_finished(pkg, cb_data, err);
b72d0a
-}
b72d0a
-
b72d0a
-static gboolean
b72d0a
-parse_next_section(CR_FILE *target_file, const char *path, cr_ParserData *pd, GError **err)
b72d0a
-{
b72d0a
-    char buf[XML_BUFFER_SIZE];
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-    int parsed_len = cr_read(target_file, buf, XML_BUFFER_SIZE, &tmp_err);
b72d0a
-    if (tmp_err) {
b72d0a
-        g_critical("%s: Error while reading xml '%s': %s", __func__, path, tmp_err->message);
b72d0a
-        g_propagate_prefixed_error(err, tmp_err, "Read error: ");
b72d0a
-        return FALSE;
b72d0a
-    }
b72d0a
-    int done = parsed_len == 0;
b72d0a
-    if (xmlParseChunk(pd->parser, buf, parsed_len, done)) {
b72d0a
-        xmlErrorPtr xml_err = xmlCtxtGetLastError(pd->parser);
b72d0a
-        g_critical("%s: parsing error '%s': %s", __func__, path,
b72d0a
-                   (xml_err) ? xml_err->message : "UNKNOWN_ERROR");
b72d0a
-        g_set_error(err, ERR_DOMAIN, CRE_XMLPARSER,
b72d0a
-                    "Parse error '%s' at line: %d (%s)",
b72d0a
-                    path,
b72d0a
-                    (xml_err) ? (int) xml_err->line : 0,
b72d0a
-                    (xml_err) ? (char *) xml_err->message : "UNKNOWN_ERROR");
b72d0a
-        return FALSE;
b72d0a
-    }
b72d0a
-
b72d0a
-    if (pd->err) {
b72d0a
-        g_propagate_error(err, pd->err);
b72d0a
-        return FALSE;
b72d0a
-    }
b72d0a
-
b72d0a
-    return done;
b72d0a
-}
b72d0a
-
b72d0a
-//TODO(amatej): there is quite some overlap with this and cr_load_xml_files,
b72d0a
-//              we could use this api and just wrap it in cr_loax_xml_files?
b72d0a
-int cr_xml_parse_main_metadata_together(const char *primary_path,
b72d0a
-                                        const char *filelists_path,
b72d0a
-                                        const char *other_path,
b72d0a
-                                        cr_XmlParserNewPkgCb newpkgcb,
b72d0a
-                                        void *newpkgcb_data,
b72d0a
-                                        cr_XmlParserPkgCb pkgcb,
b72d0a
-                                        void *pkgcb_data,
b72d0a
-                                        cr_XmlParserWarningCb warningcb,
b72d0a
-                                        void *warningcb_data,
b72d0a
-                                        gboolean allow_out_of_order,
b72d0a
-                                        GError **err)
b72d0a
-{
b72d0a
-    int ret = CRE_OK;
b72d0a
-    CR_FILE *primary_f = NULL;
b72d0a
-    CR_FILE *filelists_f = NULL;
b72d0a
-    CR_FILE *other_f = NULL;
b72d0a
-    GError *tmp_err = NULL;
b72d0a
-
b72d0a
-    cr_CbData cbdata;
b72d0a
-    cbdata.in_progress_pkgs_list = NULL;
b72d0a
-    cbdata.in_progress_pkgs_hash = NULL;
b72d0a
-    cbdata.newpkgcb = newpkgcb;
b72d0a
-    cbdata.newpkgcb_data = newpkgcb_data;
b72d0a
-    cbdata.pkgcb = pkgcb;
b72d0a
-    cbdata.pkgcb_data = pkgcb_data;
b72d0a
-
b72d0a
-    if (allow_out_of_order) {
b72d0a
-        cbdata.in_progress_pkgs_hash = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, NULL);
b72d0a
-    }
b72d0a
-
b72d0a
-    assert(primary_path);
b72d0a
-    assert(filelists_path);
b72d0a
-    assert(other_path);
b72d0a
-    assert(newpkgcb || pkgcb);
b72d0a
-    assert(!err || *err == NULL);
b72d0a
-
b72d0a
-    cr_ParserData *primary_pd = NULL;
b72d0a
-    cr_ParserData *filelists_pd = NULL;
b72d0a
-    cr_ParserData *other_pd = NULL;
b72d0a
-
b72d0a
-    primary_f = cr_open(primary_path, CR_CW_MODE_READ, CR_CW_AUTO_DETECT_COMPRESSION, &tmp_err);
b72d0a
-    if (tmp_err) {
b72d0a
-        ret = tmp_err->code;
b72d0a
-        g_propagate_prefixed_error(err, tmp_err, "Cannot open %s: ", primary_path);
b72d0a
-        g_clear_error(&tmp_err);
b72d0a
-        goto out;
b72d0a
-    }
b72d0a
-    filelists_f = cr_open(filelists_path, CR_CW_MODE_READ, CR_CW_AUTO_DETECT_COMPRESSION, &tmp_err);
b72d0a
-    if (tmp_err) {
b72d0a
-        ret = tmp_err->code;
b72d0a
-        g_propagate_prefixed_error(err, tmp_err, "Cannot open %s: ", filelists_path);
b72d0a
-        g_clear_error(&tmp_err);
b72d0a
-        goto out;
b72d0a
-    }
b72d0a
-    other_f = cr_open(other_path, CR_CW_MODE_READ, CR_CW_AUTO_DETECT_COMPRESSION, &tmp_err);
b72d0a
-    if (tmp_err) {
b72d0a
-        ret = tmp_err->code;
b72d0a
-        g_propagate_prefixed_error(err, tmp_err, "Cannot open %s: ", other_path);
b72d0a
-        g_clear_error(&tmp_err);
b72d0a
-        goto out;
b72d0a
-    }
b72d0a
-
b72d0a
-    //TODO(amatej): In the future we could make filelists/other optional if there is a need for it. That would mean we
b72d0a
-    //              should replace the last 0 in primary_parser_data_new depending on whether we have filelists or not.
b72d0a
-    primary_pd = primary_parser_data_new(newpkgcb_primary, &cbdata, pkgcb_primary, &cbdata, warningcb, warningcb_data, 0);
b72d0a
-    filelists_pd = filelists_parser_data_new(newpkgcb_filelists, &cbdata, pkgcb_filelists, &cbdata, warningcb, warningcb_data);
b72d0a
-    other_pd = other_parser_data_new(newpkgcb_other, &cbdata, pkgcb_other, &cbdata, warningcb, warningcb_data);
b72d0a
-
b72d0a
-    gboolean primary_is_done = 0;
b72d0a
-    gboolean filelists_is_done = 0;
b72d0a
-    gboolean other_is_done = 0;
b72d0a
-    cbdata.in_progress_count_primary = 0;
b72d0a
-    cbdata.in_progress_count_filelists = 0;
b72d0a
-    cbdata.in_progress_count_other = 0;
b72d0a
-    while (!primary_is_done || !filelists_is_done || !other_is_done) {
b72d0a
-        while ((cbdata.in_progress_count_primary <= cbdata.in_progress_count_filelists ||
b72d0a
-                cbdata.in_progress_count_primary <= cbdata.in_progress_count_other) &&
b72d0a
-               !primary_is_done)
b72d0a
-        {
b72d0a
-            primary_is_done = parse_next_section(primary_f, primary_path, primary_pd, err);
b72d0a
-            if (*err) {
b72d0a
-                ret = (*err)->code;
b72d0a
-                goto out;
b72d0a
-            }
b72d0a
-
b72d0a
-        }
b72d0a
-
b72d0a
-        while ((cbdata.in_progress_count_filelists <= cbdata.in_progress_count_primary ||
b72d0a
-                cbdata.in_progress_count_filelists <= cbdata.in_progress_count_other) &&
b72d0a
-               !filelists_is_done)
b72d0a
-        {
b72d0a
-            filelists_is_done = parse_next_section(filelists_f, filelists_path, filelists_pd, err);
b72d0a
-            if (*err) {
b72d0a
-                ret = (*err)->code;
b72d0a
-                goto out;
b72d0a
-            }
b72d0a
-        }
b72d0a
-
b72d0a
-        while ((cbdata.in_progress_count_other <= cbdata.in_progress_count_filelists ||
b72d0a
-                cbdata.in_progress_count_other <= cbdata.in_progress_count_primary) &&
b72d0a
-               !other_is_done)
b72d0a
-        {
b72d0a
-            other_is_done = parse_next_section(other_f, other_path, other_pd, err);
b72d0a
-            if (*err) {
b72d0a
-                ret = (*err)->code;
b72d0a
-                goto out;
b72d0a
-            }
b72d0a
-        }
b72d0a
-    }
b72d0a
-
b72d0a
-out:
b72d0a
-    if (ret != CRE_OK) {
b72d0a
-        // An error already encountered
b72d0a
-        // just close the file without error checking
b72d0a
-        cr_close(primary_f, NULL);
b72d0a
-        cr_close(filelists_f, NULL);
b72d0a
-        cr_close(other_f, NULL);
b72d0a
-    } else {
b72d0a
-        // No error encountered yet
b72d0a
-        cr_close(primary_f, &tmp_err);
b72d0a
-        if (!tmp_err)
b72d0a
-            cr_close(filelists_f, &tmp_err);
b72d0a
-        if (!tmp_err)
b72d0a
-            cr_close(other_f, &tmp_err);
b72d0a
-        if (tmp_err) {
b72d0a
-            ret = tmp_err->code;
b72d0a
-            g_propagate_prefixed_error(err, tmp_err, "Error while closing: ");
b72d0a
-        }
b72d0a
-    }
b72d0a
-
b72d0a
-    cr_xml_parser_data_free(primary_pd);
b72d0a
-    cr_xml_parser_data_free(filelists_pd);
b72d0a
-    cr_xml_parser_data_free(other_pd);
b72d0a
-
b72d0a
-    if (allow_out_of_order) {
b72d0a
-        g_hash_table_destroy(cbdata.in_progress_pkgs_hash);
b72d0a
-    } else {
b72d0a
-        cr_slist_free_full(cbdata.in_progress_pkgs_list, (GDestroyNotify) cr_package_free);
b72d0a
-    }
b72d0a
-
b72d0a
-    return ret;
b72d0a
-}
b72d0a
-- 
b72d0a
2.35.1
b72d0a