]> git.saurik.com Git - apt.git/commitdiff
rename edspwriter to straight edsp in toplevel as it does more than
authorDavid Kalnischkies <kalnischkies@gmail.com>
Thu, 31 Mar 2011 13:10:13 +0000 (15:10 +0200)
committerDavid Kalnischkies <kalnischkies@gmail.com>
Thu, 31 Mar 2011 13:10:13 +0000 (15:10 +0200)
just writing stuff… it also reads and can work for both:
- APT talking to an external solver
- an external solver (understanding EDSP) talking to APT

apt-pkg/algorithms.cc
apt-pkg/edsp.cc [new file with mode: 0644]
apt-pkg/edsp.h [new file with mode: 0644]
apt-pkg/edsp/edspwriter.cc [deleted file]
apt-pkg/edsp/edspwriter.h [deleted file]
apt-pkg/makefile

index b55ff2897ad9df37c42f06bd21456228fa6c4985..00f558420480b34acefc87da4057447ca5d760c1 100644 (file)
@@ -20,7 +20,7 @@
 #include <apt-pkg/version.h>
 #include <apt-pkg/sptr.h>
 #include <apt-pkg/acquire-item.h>
-#include <apt-pkg/edspwriter.h>
+#include <apt-pkg/edsp.h>
 
 #include <apti18n.h>
 #include <sys/types.h>
@@ -743,15 +743,15 @@ bool pkgProblemResolver::Resolve(bool BrokenFix)
    if (solver != "internal")
    {
       FILE* output = fopen("/tmp/scenario.log", "w");
-      edspWriter::WriteScenario(Cache, output);
+      EDSP::WriteScenario(Cache, output);
       fclose(output);
       output = fopen("/tmp/request.log", "w");
-      edspWriter::WriteRequest(Cache, output);
+      EDSP::WriteRequest(Cache, output);
       fclose(output);
       if (ResolveInternal(BrokenFix) == false)
         return false;
       output = fopen("/tmp/solution.log", "w");
-      edspWriter::WriteSolution(Cache, output);
+      EDSP::WriteSolution(Cache, output);
       fclose(output);
       return true;
    }
diff --git a/apt-pkg/edsp.cc b/apt-pkg/edsp.cc
new file mode 100644 (file)
index 0000000..1af5aed
--- /dev/null
@@ -0,0 +1,160 @@
+// -*- mode: cpp; mode: fold -*-
+// Description                                                         /*{{{*/
+/* ######################################################################
+   Set of methods to help writing and reading everything needed for EDSP
+   ##################################################################### */
+                                                                       /*}}}*/
+// Include Files                                                       /*{{{*/
+#include <apt-pkg/edsp.h>
+#include <apt-pkg/error.h>
+#include <apt-pkg/configuration.h>
+#include <apt-pkg/version.h>
+#include <apt-pkg/policy.h>
+
+#include <apti18n.h>
+#include <limits>
+
+#include <stdio.h>
+                                                                       /*}}}*/
+
+// EDSP::WriteScenario - to the given file descriptor                  /*{{{*/
+bool EDSP::WriteScenario(pkgDepCache &Cache, FILE* output)
+{
+   // we could use pkgCache::DepType and ::Priority, but these would be lokalized strings…
+   const char * const PrioMap[] = {0, "important", "required", "standard",
+                                  "optional", "extra"};
+   const char * const DepMap[] = {"", "Depends", "PreDepends", "Suggests",
+                                 "Recommends" , "Conflicts", "Replaces",
+                                 "Obsoletes", "Breaks", "Enhances"};
+
+   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
+   {
+      for (pkgCache::VerIterator Ver = Pkg.VersionList(); Ver.end() == false; ++Ver)
+      {
+        fprintf(output, "Package: %s\n", Pkg.Name());
+        fprintf(output, "Architecture: %s\n", Ver.Arch());
+        fprintf(output, "Version: %s\n", Ver.VerStr());
+        if (Pkg.CurrentVer() == Ver)
+           fprintf(output, "Installed: yes\n");
+        if (Pkg->SelectedState == pkgCache::State::Hold)
+           fprintf(output, "Hold: yes\n");
+        fprintf(output, "APT-ID: %u\n", Ver->ID);
+        fprintf(output, "Priority: %s\n", PrioMap[Ver->Priority]);
+        if ((Pkg->Flags & pkgCache::Flag::Essential) == pkgCache::Flag::Essential)
+           fprintf(output, "Essential: yes\n");
+        fprintf(output, "Section: %s\n", Ver.Section());
+        if (Ver->MultiArch == pkgCache::Version::Allowed || Ver->MultiArch == pkgCache::Version::AllAllowed)
+           fprintf(output, "Multi-Arch: allowed\n");
+        else if (Ver->MultiArch == pkgCache::Version::Foreign || Ver->MultiArch == pkgCache::Version::AllForeign)
+           fprintf(output, "Multi-Arch: foreign\n");
+        else if (Ver->MultiArch == pkgCache::Version::Same)
+           fprintf(output, "Multi-Arch: same\n");
+        signed short Pin = std::numeric_limits<signed short>::min();
+        for (pkgCache::VerFileIterator File = Ver.FileList(); File.end() == false; ++File) {
+           signed short const p = Cache.GetPolicy().GetPriority(File.File());
+           if (Pin < p)
+              Pin = p;
+        }
+        fprintf(output, "APT-Pin: %d\n", Pin);
+        if (Cache.GetCandidateVer(Pkg) == Ver)
+           fprintf(output, "APT-Candidate: yes\n");
+        if ((Cache[Pkg].Flags & pkgCache::Flag::Auto) == pkgCache::Flag::Auto)
+           fprintf(output, "APT-Automatic: yes\n");
+        std::string dependencies[pkgCache::Dep::Enhances + 1];
+        bool orGroup = false;
+        for (pkgCache::DepIterator Dep = Ver.DependsList(); Dep.end() == false; ++Dep)
+        {
+           // Ignore implicit dependencies for multiarch here
+           if (strcmp(Pkg.Arch(), Dep.TargetPkg().Arch()) != 0)
+              continue;
+           if (orGroup == false)
+              dependencies[Dep->Type].append(", ");
+           dependencies[Dep->Type].append(Dep.TargetPkg().Name());
+           if (Dep->Version != 0)
+              dependencies[Dep->Type].append(" (").append(pkgCache::CompTypeDeb(Dep->CompareOp)).append(" ").append(Dep.TargetVer()).append(")");
+           if ((Dep->CompareOp & pkgCache::Dep::Or) == pkgCache::Dep::Or)
+           {
+              dependencies[Dep->Type].append(" | ");
+              orGroup = true;
+           }
+           else
+              orGroup = false;
+        }
+        for (int i = 1; i < pkgCache::Dep::Enhances + 1; ++i)
+           if (dependencies[i].empty() == false)
+              fprintf(output, "%s: %s\n", DepMap[i], dependencies[i].c_str()+2);
+        string provides;
+        for (pkgCache::PrvIterator Prv = Ver.ProvidesList(); Prv.end() == false; ++Prv)
+        {
+           // Ignore implicit provides for multiarch here
+           if (strcmp(Pkg.Arch(), Prv.ParentPkg().Arch()) != 0 || strcmp(Pkg.Name(),Prv.Name()) == 0)
+              continue;
+           provides.append(", ").append(Prv.Name());
+        }
+        if (provides.empty() == false)
+           fprintf(output, "Provides: %s\n", provides.c_str()+2);
+
+
+        fprintf(output, "\n");
+      }
+   }
+   return true;
+}
+                                                                       /*}}}*/
+// EDSP::WriteRequest - to the given file descriptor                   /*{{{*/
+bool EDSP::WriteRequest(pkgDepCache &Cache, FILE* output)
+{
+   string del, inst, upgrade;
+   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
+   {
+      string* req;
+      if (Cache[Pkg].Delete() == true)
+        req = &del;
+      else if (Cache[Pkg].NewInstall() == true)
+        req = &inst;
+      else if (Cache[Pkg].Upgrade() == true)
+        req = &upgrade;
+      else
+        continue;
+      req->append(", ").append(Pkg.FullName());
+   }
+   if (del.empty() == false)
+      fprintf(output, "Remove: %s\n", del.c_str()+2);
+   if (inst.empty() == false)
+      fprintf(output, "Install: %s\n", inst.c_str()+2);
+   if (upgrade.empty() == false)
+      fprintf(output, "Upgrade: %s\n", upgrade.c_str()+2);
+
+   return true;
+}
+                                                                       /*}}}*/
+bool EDSP::ReadResponse(FILE* input, pkgDepCache &Cache) { return false; }
+
+bool EDSP::ReadRequest(FILE* input, std::list<std::string> &install,
+                       std::list<std::string> &remove)
+{ return false; }
+bool EDSP::ApplyRequest(std::list<std::string> const &install,
+                        std::list<std::string> const &remove,
+                        pkgDepCache &Cache)
+{ return false; }
+// EDSP::WriteSolution - to the given file descriptor                  /*{{{*/
+bool EDSP::WriteSolution(pkgDepCache &Cache, FILE* output)
+{
+   bool const Debug = _config->FindB("Debug::EDSPWriter::WriteSolution", false);
+   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
+   {
+      if (Cache[Pkg].Delete() == true)
+        fprintf(output, "Remove: %d\n", Cache.GetCandidateVer(Pkg)->ID);
+      else if (Cache[Pkg].NewInstall() == true || Cache[Pkg].Upgrade() == true)
+        fprintf(output, "Install: %d\n", Cache.GetCandidateVer(Pkg)->ID);
+      else
+        continue;
+      if (Debug == true)
+        fprintf(output, "Package: %s\nVersion: %s\n", Pkg.FullName().c_str(), Cache.GetCandidateVer(Pkg).VerStr());
+      fprintf(output, "\n");
+   }
+
+   return true;
+}
+                                                                       /*}}}*/
+bool EDSP::WriteError(std::string const &message, FILE* output) { return false; }
diff --git a/apt-pkg/edsp.h b/apt-pkg/edsp.h
new file mode 100644 (file)
index 0000000..ef137b8
--- /dev/null
@@ -0,0 +1,32 @@
+// -*- mode: cpp; mode: fold -*-
+// Description                                                         /*{{{*/
+/* ######################################################################
+   Set of methods to help writing and reading everything needed for EDSP
+   ##################################################################### */
+                                                                       /*}}}*/
+#ifndef PKGLIB_EDSP_H
+#define PKGLIB_EDSP_H
+
+#include <apt-pkg/depcache.h>
+
+#include <string>
+
+class EDSP                                                             /*{{{*/
+{
+public:
+       bool static WriteRequest(pkgDepCache &Cache, FILE* output);
+       bool static WriteScenario(pkgDepCache &Cache, FILE* output);
+       bool static ReadResponse(FILE* input, pkgDepCache &Cache);
+
+       // ReadScenario is provided by the listparser infrastructure
+       bool static ReadRequest(FILE* input, std::list<std::string> &install,
+                               std::list<std::string> &remove);
+       bool static ApplyRequest(std::list<std::string> const &install,
+                                std::list<std::string> const &remove,
+                                pkgDepCache &Cache);
+       bool static WriteSolution(pkgDepCache &Cache, FILE* output);
+       bool static WriteError(std::string const &message, FILE* output);
+
+};
+                                                                       /*}}}*/
+#endif
diff --git a/apt-pkg/edsp/edspwriter.cc b/apt-pkg/edsp/edspwriter.cc
deleted file mode 100644 (file)
index 2f6bde5..0000000
+++ /dev/null
@@ -1,160 +0,0 @@
-// -*- mode: cpp; mode: fold -*-
-// Description                                                         /*{{{*/
-/* ######################################################################
-   Set of methods to help writing and reading everything needed for EDSP
-   ##################################################################### */
-                                                                       /*}}}*/
-// Include Files                                                       /*{{{*/
-#include <apt-pkg/edspwriter.h>
-#include <apt-pkg/error.h>
-#include <apt-pkg/configuration.h>
-#include <apt-pkg/version.h>
-#include <apt-pkg/policy.h>
-
-#include <apti18n.h>
-#include <limits>
-
-#include <stdio.h>
-                                                                       /*}}}*/
-
-// edspWriter::WriteScenario - to the given file descriptor            /*{{{*/
-bool edspWriter::WriteScenario(pkgDepCache &Cache, FILE* output)
-{
-   // we could use pkgCache::DepType and ::Priority, but these would be lokalized strings…
-   const char * const PrioMap[] = {0, "important", "required", "standard",
-                                  "optional", "extra"};
-   const char * const DepMap[] = {"", "Depends", "PreDepends", "Suggests",
-                                 "Recommends" , "Conflicts", "Replaces",
-                                 "Obsoletes", "Breaks", "Enhances"};
-
-   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
-   {
-      for (pkgCache::VerIterator Ver = Pkg.VersionList(); Ver.end() == false; ++Ver)
-      {
-        fprintf(output, "Package: %s\n", Pkg.Name());
-        fprintf(output, "Architecture: %s\n", Ver.Arch());
-        fprintf(output, "Version: %s\n", Ver.VerStr());
-        if (Pkg.CurrentVer() == Ver)
-           fprintf(output, "Installed: yes\n");
-        if (Pkg->SelectedState == pkgCache::State::Hold)
-           fprintf(output, "Hold: yes\n");
-        fprintf(output, "APT-ID: %u\n", Ver->ID);
-        fprintf(output, "Priority: %s\n", PrioMap[Ver->Priority]);
-        if ((Pkg->Flags & pkgCache::Flag::Essential) == pkgCache::Flag::Essential)
-           fprintf(output, "Essential: yes\n");
-        fprintf(output, "Section: %s\n", Ver.Section());
-        if (Ver->MultiArch == pkgCache::Version::Allowed || Ver->MultiArch == pkgCache::Version::AllAllowed)
-           fprintf(output, "Multi-Arch: allowed\n");
-        else if (Ver->MultiArch == pkgCache::Version::Foreign || Ver->MultiArch == pkgCache::Version::AllForeign)
-           fprintf(output, "Multi-Arch: foreign\n");
-        else if (Ver->MultiArch == pkgCache::Version::Same)
-           fprintf(output, "Multi-Arch: same\n");
-        signed short Pin = std::numeric_limits<signed short>::min();
-        for (pkgCache::VerFileIterator File = Ver.FileList(); File.end() == false; ++File) {
-           signed short const p = Cache.GetPolicy().GetPriority(File.File());
-           if (Pin < p)
-              Pin = p;
-        }
-        fprintf(output, "APT-Pin: %d\n", Pin);
-        if (Cache.GetCandidateVer(Pkg) == Ver)
-           fprintf(output, "APT-Candidate: yes\n");
-        if ((Cache[Pkg].Flags & pkgCache::Flag::Auto) == pkgCache::Flag::Auto)
-           fprintf(output, "APT-Automatic: yes\n");
-        std::string dependencies[pkgCache::Dep::Enhances + 1];
-        bool orGroup = false;
-        for (pkgCache::DepIterator Dep = Ver.DependsList(); Dep.end() == false; ++Dep)
-        {
-           // Ignore implicit dependencies for multiarch here
-           if (strcmp(Pkg.Arch(), Dep.TargetPkg().Arch()) != 0)
-              continue;
-           if (orGroup == false)
-              dependencies[Dep->Type].append(", ");
-           dependencies[Dep->Type].append(Dep.TargetPkg().Name());
-           if (Dep->Version != 0)
-              dependencies[Dep->Type].append(" (").append(pkgCache::CompTypeDeb(Dep->CompareOp)).append(" ").append(Dep.TargetVer()).append(")");
-           if ((Dep->CompareOp & pkgCache::Dep::Or) == pkgCache::Dep::Or)
-           {
-              dependencies[Dep->Type].append(" | ");
-              orGroup = true;
-           }
-           else
-              orGroup = false;
-        }
-        for (int i = 1; i < pkgCache::Dep::Enhances + 1; ++i)
-           if (dependencies[i].empty() == false)
-              fprintf(output, "%s: %s\n", DepMap[i], dependencies[i].c_str()+2);
-        string provides;
-        for (pkgCache::PrvIterator Prv = Ver.ProvidesList(); Prv.end() == false; ++Prv)
-        {
-           // Ignore implicit provides for multiarch here
-           if (strcmp(Pkg.Arch(), Prv.ParentPkg().Arch()) != 0 || strcmp(Pkg.Name(),Prv.Name()) == 0)
-              continue;
-           provides.append(", ").append(Prv.Name());
-        }
-        if (provides.empty() == false)
-           fprintf(output, "Provides: %s\n", provides.c_str()+2);
-
-
-        fprintf(output, "\n");
-      }
-   }
-   return true;
-}
-                                                                       /*}}}*/
-// edspWriter::WriteRequest - to the given file descriptor             /*{{{*/
-bool edspWriter::WriteRequest(pkgDepCache &Cache, FILE* output)
-{
-   string del, inst, upgrade;
-   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
-   {
-      string* req;
-      if (Cache[Pkg].Delete() == true)
-        req = &del;
-      else if (Cache[Pkg].NewInstall() == true)
-        req = &inst;
-      else if (Cache[Pkg].Upgrade() == true)
-        req = &upgrade;
-      else
-        continue;
-      req->append(", ").append(Pkg.FullName());
-   }
-   if (del.empty() == false)
-      fprintf(output, "Remove: %s\n", del.c_str()+2);
-   if (inst.empty() == false)
-      fprintf(output, "Install: %s\n", inst.c_str()+2);
-   if (upgrade.empty() == false)
-      fprintf(output, "Upgrade: %s\n", upgrade.c_str()+2);
-
-   return true;
-}
-                                                                       /*}}}*/
-bool edspWriter::ReadResponse(FILE* input, pkgDepCache &Cache) { return false; }
-
-bool edspWriter::ReadRequest(FILE* input, std::list<std::string> &install,
-                       std::list<std::string> &remove)
-{ return false; }
-bool edspWriter::ApplyRequest(std::list<std::string> const &install,
-                        std::list<std::string> const &remove,
-                        pkgDepCache &Cache)
-{ return false; }
-// edspWriter::WriteSolution - to the given file descriptor            /*{{{*/
-bool edspWriter::WriteSolution(pkgDepCache &Cache, FILE* output)
-{
-   bool const Debug = _config->FindB("Debug::EDSPWriter::WriteSolution", false);
-   for (pkgCache::PkgIterator Pkg = Cache.PkgBegin(); Pkg.end() == false; ++Pkg)
-   {
-      if (Cache[Pkg].Delete() == true)
-        fprintf(output, "Remove: %d\n", Cache.GetCandidateVer(Pkg)->ID);
-      else if (Cache[Pkg].NewInstall() == true || Cache[Pkg].Upgrade() == true)
-        fprintf(output, "Install: %d\n", Cache.GetCandidateVer(Pkg)->ID);
-      else
-        continue;
-      if (Debug == true)
-        fprintf(output, "Package: %s\nVersion: %s\n", Pkg.FullName().c_str(), Cache.GetCandidateVer(Pkg).VerStr());
-      fprintf(output, "\n");
-   }
-
-   return true;
-}
-                                                                       /*}}}*/
-bool edspWriter::WriteError(std::string const &message, FILE* output) { return false; }
diff --git a/apt-pkg/edsp/edspwriter.h b/apt-pkg/edsp/edspwriter.h
deleted file mode 100644 (file)
index c5eed78..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-// -*- mode: cpp; mode: fold -*-
-// Description                                                         /*{{{*/
-/* ######################################################################
-   Set of methods to help writing and reading everything needed for EDSP
-   ##################################################################### */
-                                                                       /*}}}*/
-#ifndef PKGLIB_EDSPWRITER_H
-#define PKGLIB_EDSPWRITER_H
-
-#include <apt-pkg/depcache.h>
-
-#include <string>
-
-class edspWriter                                                               /*{{{*/
-{
-public:
-       bool static WriteRequest(pkgDepCache &Cache, FILE* output);
-       bool static WriteScenario(pkgDepCache &Cache, FILE* output);
-       bool static ReadResponse(FILE* input, pkgDepCache &Cache);
-
-       // ReadScenario is provided by the listparser infrastructure
-       bool static ReadRequest(FILE* input, std::list<std::string> &install,
-                               std::list<std::string> &remove);
-       bool static ApplyRequest(std::list<std::string> const &install,
-                                std::list<std::string> const &remove,
-                                pkgDepCache &Cache);
-       bool static WriteSolution(pkgDepCache &Cache, FILE* output);
-       bool static WriteError(std::string const &message, FILE* output);
-
-};
-                                                                       /*}}}*/
-#endif
index a7880e81cd2defea21094e137ce9f305fd981d6b..e6bcf852470dc158f2b21d72136a382c2e92c899 100644 (file)
@@ -35,7 +35,7 @@ SOURCE+= pkgcache.cc version.cc depcache.cc \
         srcrecords.cc cachefile.cc versionmatch.cc policy.cc \
         pkgsystem.cc indexfile.cc pkgcachegen.cc acquire-item.cc \
         indexrecords.cc vendor.cc vendorlist.cc cdrom.cc indexcopy.cc \
-        aptconfiguration.cc cachefilter.cc cacheset.cc
+        aptconfiguration.cc cachefilter.cc cacheset.cc edsp.cc
 HEADERS+= algorithms.h depcache.h pkgcachegen.h cacheiterators.h \
          orderlist.h sourcelist.h packagemanager.h tagfile.h \
          init.h pkgcache.h version.h progress.h pkgrecords.h \
@@ -43,7 +43,7 @@ HEADERS+= algorithms.h depcache.h pkgcachegen.h cacheiterators.h \
          clean.h srcrecords.h cachefile.h versionmatch.h policy.h \
          pkgsystem.h indexfile.h metaindex.h indexrecords.h vendor.h \
          vendorlist.h cdrom.h indexcopy.h aptconfiguration.h \
-         cachefilter.h cacheset.h
+         cachefilter.h cacheset.h edsp.h
 
 # Source code for the debian specific components
 # In theory the deb headers do not need to be exported..
@@ -54,9 +54,8 @@ HEADERS+= debversion.h debsrcrecords.h dpkgpm.h debrecords.h \
          deblistparser.h debsystem.h debindexfile.h debmetaindex.h
 
 # Source code for the APT resolver interface specific components
-SOURCE+= edsp/edsplistparser.cc edsp/edspindexfile.cc edsp/edspsystem.cc \
-        edsp/edspwriter.cc
-HEADERS+= edsplistparser.h edspindexfile.h edspsystem.h edspwriter.h
+SOURCE+= edsp/edsplistparser.cc edsp/edspindexfile.cc edsp/edspsystem.cc
+HEADERS+= edsplistparser.h edspindexfile.h edspsystem.h
 
 HEADERS := $(addprefix apt-pkg/,$(HEADERS))