initial work for HighLevelHFSDispatch

This commit is contained in:
Kelvin Sherlock 2013-02-24 23:23:05 -05:00
parent 6ae8b870a0
commit c5f07d4706
2 changed files with 68 additions and 2 deletions

View File

@ -610,7 +610,7 @@ const char *TrapName(uint16_t trap)
*/ */
case 0xAA52: return "_HighLevelFSDispatch"; case 0xAA52: return "_HighLevelHFSDispatch";
/* /*

View File

@ -1,9 +1,10 @@
#include <string>
#include <cerrno> #include <cerrno>
#include <cctype> #include <cctype>
#include <ctime> #include <ctime>
#include <algorithm> #include <algorithm>
#include <chrono> #include <chrono>
#include <deque>
#include <string>
#include <sys/xattr.h> #include <sys/xattr.h>
#include <sys/stat.h> #include <sys/stat.h>
@ -93,6 +94,71 @@ namespace {
return s.substr(pos + 1); return s.substr(pos + 1);
} }
// FSSpec garbage
class FSSpecManager
{
public:
const std::string &pathForID(int32_t id);
int32_t idForPath(const std::string &path, bool insert = true);
private:
struct Entry
{
#if 0
Entry(std::string &&p) : path(p), hash(std::hash(path))
{}
Entry(const std::string &p) : path(p), hash(std::hash(path))
{}
#endif
Entry(const std::string &&p, size_t h) :
path(p), hash(h)
{}
std::string path;
size_t hash;
};
std::deque<Entry> _pathQueue;
};
int32_t FSSpecManager::idForPath(const std::string &path, bool insert)
{
char buffer[PATH_MAX + 1];
char *cp = realpath(path.c_str(), buffer);
if (!cp) return -1;
std::string s(cp);
std::hash<std::string> hasher;
size_t hash = hasher(s);
int i = 1;
for (const auto &e : _pathQueue)
{
if (e.hash == hash && e.path == s) return i;
++i;
}
if (!insert) return -1;
_pathQueue.emplace_back(Entry(std::move(s), hash));
return _pathQueue.size();
}
const std::string &FSSpecManager::pathForID(int32_t id)
{
static std::string NullString;
if (id < 1) return NullString;
if (id > _pathQueue.size()) return NullString;
return _pathQueue[id - 1].path;
}
} }
namespace OS namespace OS