]> git.saurik.com Git - apt.git/commitdiff
* lp:~mvo/apt/add-glob-function:
authorMichael Vogt <egon@debian-devbox>
Wed, 17 Oct 2012 08:27:50 +0000 (10:27 +0200)
committerMichael Vogt <egon@debian-devbox>
Wed, 17 Oct 2012 08:27:50 +0000 (10:27 +0200)
  -  add Glob() to fileutl.{cc,h}

apt-pkg/contrib/fileutl.cc
apt-pkg/contrib/fileutl.h
debian/changelog
test/libapt/fileutl_test.cc [new file with mode: 0644]
test/libapt/makefile

index 4c224337ebb4d1af86bd739249faa3d4d362477f..a31a8a141986e54a560936b24580b2cd4287bf7f 100644 (file)
@@ -41,6 +41,8 @@
 #include <dirent.h>
 #include <signal.h>
 #include <errno.h>
+#include <glob.h>
+
 #include <set>
 #include <algorithm>
 
@@ -1778,3 +1780,32 @@ bool FileFd::Sync()
                                                                        /*}}}*/
 
 gzFile FileFd::gzFd() { return (gzFile) d->gz; }
+
+
+// Glob - wrapper around "glob()"                                      /*{{{*/
+// ---------------------------------------------------------------------
+/* */
+std::vector<std::string> Glob(std::string const &pattern, int flags)
+{
+   std::vector<std::string> result;
+   glob_t globbuf;
+   int glob_res, i;
+
+   glob_res = glob(pattern.c_str(),  flags, NULL, &globbuf);
+
+   if (glob_res != 0)
+   {
+      if(glob_res != GLOB_NOMATCH) {
+         _error->Errno("glob", "Problem with glob");
+         return result;
+      }
+   }
+
+   // append results
+   for(i=0;i<globbuf.gl_pathc;i++)
+      result.push_back(string(globbuf.gl_pathv[i]));
+
+   globfree(&globbuf);
+   return result;
+}
+                                                                       /*}}}*/
index 510b1c984c2921519d108bb64592063f2ea1bd2b..4d933a30737e93986e7d956d9396d353019cbc47 100644 (file)
@@ -190,6 +190,7 @@ std::string flNoLink(std::string File);
 std::string flExtension(std::string File);
 std::string flCombine(std::string Dir,std::string File);
 
-
+// simple c++ glob
+std::vector<std::string> Glob(std::string const &pattern, int flags=0);
 
 #endif
index 2688a2686c251bc5299db08a0be654701fbc3a47..e93ed51ae85ac6cfe418704c5cc659b894d062d6 100644 (file)
@@ -9,6 +9,8 @@ apt (0.9.8~exp1) UNRELEASED; urgency=low
     - fix invalid InRelease file download checking and add regression
       test to server broken files to the buildin test webserver
   * stop exporting the accidently exported parsenetrc() symbol
+  * lp:~mvo/apt/add-glob-function:
+    -  add Glob() to fileutl.{cc,h}
 
  -- David Kalnischkies <kalnischkies@gmail.com>  Mon, 09 Jul 2012 17:36:40 +0200
 
diff --git a/test/libapt/fileutl_test.cc b/test/libapt/fileutl_test.cc
new file mode 100644 (file)
index 0000000..b6b8ac5
--- /dev/null
@@ -0,0 +1,42 @@
+#include <apt-pkg/error.h>
+#include <apt-pkg/fileutl.h>
+
+#include "assert.h"
+#include <string>
+#include <vector>
+
+#include <stdio.h>
+#include <iostream>
+#include <stdlib.h>
+
+
+int main(int argc,char *argv[])
+{
+   std::vector<std::string> files;
+
+   // normal match
+   files = Glob("*.lst");
+   if (files.size() != 1)
+   {
+      _error->DumpErrors();
+      return 1;
+   }
+
+   // not there
+   files = Glob("xxxyyyzzz");
+   if (files.size() != 0 || _error->PendingError())
+   {
+      _error->DumpErrors();
+      return 1;
+   }
+
+   // many matches (number is a bit random)
+   files = Glob("*.cc");
+   if (files.size() < 10)
+   {
+      _error->DumpErrors();
+      return 1;
+   }
+
+   return 0;
+}
index 5e225f2404880bedbaf25e9e7e48d0a779ff9e25..578f2da4d2de98c4f49760b6dd07e4d26c7855ba 100644 (file)
@@ -97,4 +97,9 @@ include $(PROGRAM_H)
 PROGRAM = IndexCopyToSourceList${BASENAME}
 SLIBS = -lapt-pkg
 SOURCE = indexcopytosourcelist_test.cc
+
+# test fileutls
+PROGRAM = FileUtl${BASENAME}
+SLIBS = -lapt-pkg 
+SOURCE = fileutl_test.cc
 include $(PROGRAM_H)