am 1881395b: am c6752b06: Merge "vold: wildcard support for device path matching"
* commit '1881395b696017dfb40a01e718cc8dc2ea7a38e9':
vold: wildcard support for device path matching
diff --git a/DirectVolume.cpp b/DirectVolume.cpp
index 67f89ea..9de7aea 100644
--- a/DirectVolume.cpp
+++ b/DirectVolume.cpp
@@ -18,6 +18,7 @@
#include <stdlib.h>
#include <string.h>
#include <errno.h>
+#include <fnmatch.h>
#include <linux/kdev_t.h>
@@ -33,6 +34,42 @@
// #define PARTITION_DEBUG
+PathInfo::PathInfo(const char *p)
+{
+ warned = false;
+ pattern = strdup(p);
+
+ if (!strchr(pattern, '*')) {
+ patternType = prefix;
+ } else {
+ patternType = wildcard;
+ }
+}
+
+PathInfo::~PathInfo()
+{
+ free(pattern);
+}
+
+bool PathInfo::match(const char *path)
+{
+ switch (patternType) {
+ case prefix:
+ {
+ bool ret = (strncmp(path, pattern, strlen(pattern)) == 0);
+ if (!warned && ret && (strlen(pattern) != strlen(path))) {
+ SLOGW("Deprecated implied prefix pattern detected, please use '%s*' instead", pattern);
+ warned = true;
+ }
+ return ret;
+ }
+ case wildcard:
+ return fnmatch(pattern, path, 0) == 0;
+ }
+ SLOGE("Bad matching type");
+ return false;
+}
+
DirectVolume::DirectVolume(VolumeManager *vm, const fstab_rec* rec, int flags) :
Volume(vm, rec, flags) {
mPaths = new PathCollection();
@@ -62,12 +99,12 @@
PathCollection::iterator it;
for (it = mPaths->begin(); it != mPaths->end(); ++it)
- free(*it);
+ delete *it;
delete mPaths;
}
int DirectVolume::addPath(const char *path) {
- mPaths->push_back(strdup(path));
+ mPaths->push_back(new PathInfo(path));
return 0;
}
@@ -96,7 +133,7 @@
PathCollection::iterator it;
for (it = mPaths->begin(); it != mPaths->end(); ++it) {
- if (!strncmp(dp, *it, strlen(*it))) {
+ if ((*it)->match(dp)) {
/* We can handle this disk */
int action = evt->getAction();
const char *devtype = evt->findParam("DEVTYPE");
@@ -407,7 +444,7 @@
}
it = mPaths->begin();
- free(*it); /* Free the string storage */
+ delete *it; /* Free the string storage */
mPaths->erase(it); /* Remove it from the list */
addPath(new_path); /* Put the new path on the list */
diff --git a/DirectVolume.h b/DirectVolume.h
index beda7c3..b1388bb 100644
--- a/DirectVolume.h
+++ b/DirectVolume.h
@@ -21,7 +21,19 @@
#include "Volume.h"
-typedef android::List<char *> PathCollection;
+class PathInfo {
+public:
+ PathInfo(const char *pattern);
+ ~PathInfo();
+ bool match(const char *path);
+private:
+ bool warned;
+ char *pattern;
+ enum PatternType { prefix, wildcard };
+ PatternType patternType;
+};
+
+typedef android::List<PathInfo *> PathCollection;
class DirectVolume : public Volume {
public: