2
0
mirror of https://github.com/AxioDL/metaforce.git synced 2025-10-25 06:50:24 +00:00

Glob path fixes

This commit is contained in:
Jack Andersen 2016-09-20 19:41:06 -10:00
parent f1fcd83824
commit f6428c9407
2 changed files with 12 additions and 23 deletions

View File

@ -74,7 +74,7 @@ void ProjectPath::assign(Database::Project& project, const SystemString& path)
else else
usePath = path; usePath = path;
m_relPath = CanonRelPath(usePath); m_relPath = CanonRelPath(usePath, project.getProjectRootPath());
m_absPath = project.getProjectRootPath().getAbsolutePath() + _S('/') + m_relPath; m_absPath = project.getProjectRootPath().getAbsolutePath() + _S('/') + m_relPath;
SanitizePath(m_relPath); SanitizePath(m_relPath);
SanitizePath(m_absPath); SanitizePath(m_absPath);
@ -134,11 +134,7 @@ ProjectPath ProjectPath::getCookedPath(const Database::DataSpecEntry& spec) cons
ProjectPath::Type ProjectPath::getPathType() const ProjectPath::Type ProjectPath::getPathType() const
{ {
if (std::regex_search(m_absPath, regGLOB)) if (std::regex_search(m_absPath, regGLOB))
{ return Type::Glob;
std::vector<ProjectPath> globResults;
getGlobResults(globResults);
return globResults.size() ? Type::Glob : Type::None;
}
Sstat theStat; Sstat theStat;
if (hecl::Stat(m_absPath.c_str(), &theStat)) if (hecl::Stat(m_absPath.c_str(), &theStat))
return Type::None; return Type::None;
@ -165,6 +161,7 @@ Time ProjectPath::getModtime() const
latestTime = theStat.st_mtime; latestTime = theStat.st_mtime;
} }
} }
return Time(latestTime);
} }
if (!hecl::Stat(m_absPath.c_str(), &theStat)) if (!hecl::Stat(m_absPath.c_str(), &theStat))
{ {
@ -192,22 +189,22 @@ Time ProjectPath::getModtime() const
static void _recursiveGlob(Database::Project& proj, static void _recursiveGlob(Database::Project& proj,
std::vector<ProjectPath>& outPaths, std::vector<ProjectPath>& outPaths,
size_t level, const SystemString& remPath,
const SystemRegexMatch& pathCompMatches,
const SystemString& itStr, const SystemString& itStr,
bool needSlash) bool needSlash)
{ {
if (level >= pathCompMatches.size()) SystemRegexMatch matches;
if (!std::regex_search(remPath, matches, regPATHCOMP))
return; return;
SystemString comp = pathCompMatches.str(level); const SystemString& comp = matches[1];
if (!std::regex_search(comp, regGLOB)) if (!std::regex_search(comp, regGLOB))
{ {
SystemString nextItStr = itStr; SystemString nextItStr = itStr;
if (needSlash) if (needSlash)
nextItStr += _S('/'); nextItStr += _S('/');
nextItStr += comp; nextItStr += comp;
_recursiveGlob(proj, outPaths, level+1, pathCompMatches, nextItStr, true); _recursiveGlob(proj, outPaths, matches.suffix(), nextItStr, true);
return; return;
} }
@ -229,7 +226,7 @@ static void _recursiveGlob(Database::Project& proj,
continue; continue;
if (ent.m_isDir) if (ent.m_isDir)
_recursiveGlob(proj, outPaths, level+1, pathCompMatches, nextItStr, true); _recursiveGlob(proj, outPaths, matches.suffix(), nextItStr, true);
else else
outPaths.emplace_back(proj, nextItStr); outPaths.emplace_back(proj, nextItStr);
} }
@ -262,9 +259,7 @@ void ProjectPath::getGlobResults(std::vector<ProjectPath>& outPaths) const
SystemString itStr = _S("/"); SystemString itStr = _S("/");
#endif #endif
SystemRegexMatch pathCompMatches; _recursiveGlob(*m_proj, outPaths, m_absPath, itStr, false);
if (std::regex_search(m_absPath, pathCompMatches, regPATHCOMP))
_recursiveGlob(*m_proj, outPaths, 1, pathCompMatches, itStr, false);
} }
ProjectRootPath SearchForProject(const SystemString& path) ProjectRootPath SearchForProject(const SystemString& path)

View File

@ -139,16 +139,10 @@ bool IsPathPNG(const hecl::ProjectPath& path)
bool IsPathBlend(const hecl::ProjectPath& path) bool IsPathBlend(const hecl::ProjectPath& path)
{ {
hecl::ProjectPath usePath; const SystemChar* lastCompExt = path.getLastComponentExt();
if (path.getPathType() == hecl::ProjectPath::Type::Glob)
usePath = path.getWithExtension(_S(".blend"), true);
else
usePath = path;
const SystemChar* lastCompExt = usePath.getLastComponentExt();
if (!lastCompExt || hecl::StrCmp(lastCompExt, _S("blend"))) if (!lastCompExt || hecl::StrCmp(lastCompExt, _S("blend")))
return false; return false;
FILE* fp = hecl::Fopen(usePath.getAbsolutePath().c_str(), _S("rb")); FILE* fp = hecl::Fopen(path.getAbsolutePath().c_str(), _S("rb"));
if (!fp) if (!fp)
return false; return false;
uint32_t buf; uint32_t buf;