skip incompatible archs
authorKlaus Kaempf <kkaempf@suse.de>
Sun, 2 Apr 2006 20:14:05 +0000 (20:14 +0000)
committerKlaus Kaempf <kkaempf@suse.de>
Sun, 2 Apr 2006 20:14:05 +0000 (20:14 +0000)
zypp/parser/yum/YUMPrimaryParser.cc
zypp/parser/yum/YUMPrimaryParser.h
zypp/source/yum/YUMSourceImpl.cc

index 2c0313e1da41fa570c1be8d0d6020b6c68b7658f..8bdf51860234a35c699bf69edc04862e904e521a 100644 (file)
@@ -20,7 +20,7 @@
 #include <zypp/parser/LibXMLHelper.h>
 #include <zypp/base/Logger.h>
 #include <zypp/parser/yum/schemanames.h>
-
+#include <zypp/ZYppFactory.h>
 
 using namespace std;
 namespace zypp {
@@ -30,6 +30,7 @@ namespace zypp {
       
       YUMPrimaryParser::YUMPrimaryParser(istream &is, const string& baseUrl)
         : XMLNodeIterator<YUMPrimaryData_Ptr>(is, baseUrl,PRIMARYSCHEMA)
+       , _zypp_architecture( getZYpp()->architecture() )
       {
        if (is.fail()) {
            ERR << "Bad stream" << endl;
@@ -38,10 +39,12 @@ namespace zypp {
       }
       
       YUMPrimaryParser::YUMPrimaryParser()
+       : _zypp_architecture( getZYpp()->architecture() )
       { }
       
       YUMPrimaryParser::YUMPrimaryParser(YUMPrimaryData_Ptr& entry)
       : XMLNodeIterator<YUMPrimaryData_Ptr>(entry)
+       , _zypp_architecture( getZYpp()->architecture() )
       { }
       
       
@@ -76,7 +79,8 @@ namespace zypp {
         
         for (xmlNodePtr child = dataNode->children; 
              child != 0;
-             child = child->next) {
+             child = child->next)
+       {
           if (_helper.isElement(child)) {
             string name = _helper.name(child);
             if (name == "name") {
@@ -84,6 +88,18 @@ namespace zypp {
             }
             else if (name == "arch") {
               dataPtr->arch = _helper.content(child);
+             try {
+               if (!Arch(dataPtr->arch).compatibleWith( _zypp_architecture )) {
+                   dataPtr = NULL;                     // skip <package>, incompatible architecture
+                   break;
+               }
+             }
+             catch( const Exception & excpt_r ) {
+               ZYPP_CAUGHT( excpt_r );
+               DBG << "Skipping malformed " << dataPtr->arch << endl;
+               dataPtr = NULL;
+               break;
+             }
             }
             else if (name == "version") {
               dataPtr->epoch = _helper.attribute(child,"epoch");
@@ -137,6 +153,7 @@ namespace zypp {
       YUMPrimaryParser::parseFormatNode(YUMPrimaryData_Ptr dataPtr,
                                               xmlNodePtr formatNode)
       {
+       if (dataPtr == NULL) return;                    // skipping
         xml_assert(formatNode);
         dataPtr->installOnly = false;
         for (xmlNodePtr child = formatNode->children; 
index e99411848d25718b7947c1cf3c74106f17691d0a..c39814a3aa8bba6de72144af0e82bfa662fe3bca 100644 (file)
@@ -18,6 +18,7 @@
 #include <zypp/parser/yum/YUMParserData.h>
 #include <zypp/parser/XMLNodeIterator.h>
 #include <zypp/parser/LibXMLHelper.h>
+#include <zypp/Arch.h>
 #include <list>
 
 namespace zypp {
@@ -71,6 +72,7 @@ namespace zypp {
                                  xmlNodePtr node);
     
         LibXMLHelper _helper;
+       Arch _zypp_architecture;
       };
     } // namespace yum
   } // namespace parser
index fbba3f9482cfe63f6701c8799acb5577a19c57f4..64b9fca4c5e981c3c41f3741f6c624233fa03510 100644 (file)
@@ -416,7 +416,9 @@ namespace zypp
                  !prim.atEnd();
                  ++prim)
            {
-              MIL << "found package "<< (*prim)->name << std::endl;
+             if (*prim == NULL) continue;      // incompatible arch detected during parsing
+
+//              MIL << "found package "<< (*prim)->name << std::endl;
               
                 Arch arch;
                 if (!(*prim)->arch.empty())
@@ -446,7 +448,7 @@ namespace zypp
                );
                ImplAndPackage iap = { impl, p };
                _package_impl[nvra] = iap;
-                MIL << "inserting package "<< p->name() << std::endl;
+//                MIL << "inserting package "<< p->name() << std::endl;
                _store.insert (p);
            }
            if (prim.errorStatus())