mirror of
https://github.com/znc/znc.git
synced 2026-05-08 14:24:45 +02:00
Added ability to set paths to include-only which will not be used for the root file but only the INC'd ones
git-svn-id: https://znc.svn.sourceforge.net/svnroot/znc/trunk@1740 726aef4b-f618-498e-8847-2d620e286838
This commit is contained in:
+37
-23
@@ -90,26 +90,30 @@ void CTemplate::Init() {
|
||||
}
|
||||
*/
|
||||
|
||||
ClearPath();
|
||||
ClearPaths();
|
||||
m_pParent = NULL;
|
||||
}
|
||||
|
||||
CString CTemplate::ExpandFile(const CString& sFilename) {
|
||||
if (sFilename.Left(1) == "/" || sFilename.Left(2) == "./") {
|
||||
CString CTemplate::ExpandFile(const CString& sFilename, bool bFromInc) {
|
||||
/*if (sFilename.Left(1) == "/" || sFilename.Left(2) == "./") {
|
||||
return sFilename;
|
||||
}
|
||||
}*/
|
||||
|
||||
CString sFile(ResolveLiteral(sFilename));
|
||||
CString sFile(ResolveLiteral(sFilename).TrimLeft_n("/"));
|
||||
|
||||
for (LCString::iterator it = m_lsPaths.begin(); it != m_lsPaths.end(); it++) {
|
||||
CString sRoot = *it;
|
||||
for (list<pair<CString, bool> >::iterator it = m_lsbPaths.begin(); it != m_lsbPaths.end(); it++) {
|
||||
if (it->second && !bFromInc) {
|
||||
continue;
|
||||
}
|
||||
|
||||
CString sRoot = it->first;
|
||||
CString sFilePath(CDir::ChangeDir(sRoot, sFile));
|
||||
|
||||
if (CFile::Exists(sFilePath)) {
|
||||
// This only works if sRoot got a trailing slash! The
|
||||
// code which adds paths makes sure this is true.
|
||||
if (sRoot.empty() || sFilePath.Left(sRoot.length()) == sRoot) {
|
||||
//DEBUG("\t\tFound [" + sFilePath + "]\n");
|
||||
DEBUG("\t\tFound [" + sFilePath + "]\n");
|
||||
return sFilePath;
|
||||
} else {
|
||||
DEBUG("\t\tOutside of root [" + sFilePath + "] !~ [" + sRoot + "]");
|
||||
@@ -119,15 +123,15 @@ CString CTemplate::ExpandFile(const CString& sFilename) {
|
||||
}
|
||||
}
|
||||
|
||||
switch (m_lsPaths.size()) {
|
||||
switch (m_lsbPaths.size()) {
|
||||
case 0:
|
||||
DEBUG("Unable to find [" + sFile + "] using the current directory");
|
||||
break;
|
||||
case 1:
|
||||
DEBUG("Unable to find [" + sFile + "] in the defined path [" + *m_lsPaths.begin());
|
||||
DEBUG("Unable to find [" + sFile + "] in the defined path [" + m_lsbPaths.begin()->first + "]");
|
||||
break;
|
||||
default:
|
||||
DEBUG("Unable to find [" + sFile + "] in any of the " + CString(m_lsPaths.size()) + " defined paths");
|
||||
DEBUG("Unable to find [" + sFile + "] in any of the " + CString(m_lsbPaths.size()) + " defined paths");
|
||||
}
|
||||
|
||||
return "";
|
||||
@@ -138,32 +142,40 @@ void CTemplate::SetPath(const CString& sPaths) {
|
||||
sPaths.Split(":", vsDirs, false);
|
||||
|
||||
for (size_t a = 0; a < vsDirs.size(); a++) {
|
||||
AppendPath(vsDirs[a]);
|
||||
AppendPath(vsDirs[a], false);
|
||||
}
|
||||
}
|
||||
|
||||
void CTemplate::PrependPath(const CString& sPath) {
|
||||
void CTemplate::PrependPath(const CString& sPath, bool bIncludesOnly) {
|
||||
DEBUG("CTemplate::PrependPath(" + sPath + ") == [" + CDir::ChangeDir("./", sPath + "/") + "]");
|
||||
m_lsPaths.push_front(CDir::ChangeDir("./", sPath + "/"));
|
||||
m_lsbPaths.push_front(make_pair(CDir::ChangeDir("./", sPath + "/"), bIncludesOnly));
|
||||
}
|
||||
|
||||
void CTemplate::AppendPath(const CString& sPath) {
|
||||
void CTemplate::AppendPath(const CString& sPath, bool bIncludesOnly) {
|
||||
DEBUG("CTemplate::AppendPath(" + sPath + ") == [" + CDir::ChangeDir("./", sPath + "/") + "]");
|
||||
m_lsPaths.push_back(CDir::ChangeDir("./", sPath + "/"));
|
||||
m_lsbPaths.push_back(make_pair(CDir::ChangeDir("./", sPath + "/"), bIncludesOnly));
|
||||
}
|
||||
|
||||
void CTemplate::RemovePath(const CString& sPath) {
|
||||
DEBUG("CTemplate::RemovePath(" + sPath + ") == [" + CDir::ChangeDir("./", sPath + "/") + "]");
|
||||
m_lsPaths.remove(CDir::ChangeDir("./", sPath + "/"));
|
||||
//m_lsbPaths.remove(CDir::ChangeDir("./", sPath + "/"));
|
||||
|
||||
for (list<pair<CString, bool> >::iterator it = m_lsbPaths.begin(); it != m_lsbPaths.end(); it++) {
|
||||
if (it->first == sPath) {
|
||||
m_lsbPaths.remove(*it);
|
||||
RemovePath(sPath);
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void CTemplate::ClearPath() {
|
||||
m_lsPaths.clear();
|
||||
void CTemplate::ClearPaths() {
|
||||
m_lsbPaths.clear();
|
||||
}
|
||||
|
||||
bool CTemplate::SetFile(const CString& sFileName) {
|
||||
m_sFileName = ExpandFile(sFileName);
|
||||
PrependPath(sFileName + "/..");
|
||||
m_sFileName = ExpandFile(sFileName, false);
|
||||
//PrependPath(sFileName + "/..");
|
||||
|
||||
if (sFileName.empty()) {
|
||||
DEBUG("CTemplate::SetFile() - Filename is empty");
|
||||
@@ -230,6 +242,7 @@ bool CTemplate::PrintString(CString& sRet) {
|
||||
}
|
||||
|
||||
bool CTemplate::Print(ostream& oOut) {
|
||||
DEBUG("== Print(o) m_sFileName = [" + m_sFileName + "]");
|
||||
return Print(m_sFileName, oOut);
|
||||
}
|
||||
|
||||
@@ -311,7 +324,8 @@ bool CTemplate::Print(const CString& sFileName, ostream& oOut) {
|
||||
|
||||
if (!uSkip) {
|
||||
if (sAction.Equals("INC")) {
|
||||
if (!Print(ExpandFile(sArgs), oOut)) {
|
||||
if (!Print(ExpandFile(sArgs, true), oOut)) {
|
||||
DEBUG("Unable to print INC'd file [" + sArgs + "]");
|
||||
return false;
|
||||
}
|
||||
} else if (sAction.Equals("SETOPTION")) {
|
||||
@@ -365,7 +379,7 @@ bool CTemplate::Print(const CString& sFileName, ostream& oOut) {
|
||||
sSetBlockVar = sArgs;
|
||||
bInSetBlock = true;
|
||||
} else if (sAction.Equals("EXPAND")) {
|
||||
sOutput += ExpandFile(sArgs);
|
||||
sOutput += ExpandFile(sArgs, true);
|
||||
} else if (sAction.Equals("VAR")) {
|
||||
sOutput += GetValue(sArgs);
|
||||
} else if (sAction.Equals("LT")) {
|
||||
|
||||
+5
-5
@@ -145,14 +145,14 @@ public:
|
||||
void Init();
|
||||
|
||||
CTemplate* GetParent(bool bRoot);
|
||||
CString ExpandFile(const CString& sFilename);
|
||||
CString ExpandFile(const CString& sFilename, bool bFromInc = false);
|
||||
bool SetFile(const CString& sFileName);
|
||||
|
||||
void SetPath(const CString& sPath); // Sets the dir:dir:dir type path to look at for templates, as of right now no ../../.. protection
|
||||
void PrependPath(const CString& sPath);
|
||||
void AppendPath(const CString& sPath);
|
||||
void PrependPath(const CString& sPath, bool bIncludesOnly = false);
|
||||
void AppendPath(const CString& sPath, bool bIncludesOnly = false);
|
||||
void RemovePath(const CString& sPath);
|
||||
void ClearPath();
|
||||
void ClearPaths();
|
||||
CString ResolvePath(const CString& sPath, const CString& sFilename);
|
||||
bool PrintString(CString& sRet);
|
||||
bool Print(ostream& oOut = cout);
|
||||
@@ -175,7 +175,7 @@ public:
|
||||
private:
|
||||
CTemplate* m_pParent;
|
||||
CString m_sFileName;
|
||||
LCString m_lsPaths;
|
||||
list<pair<CString, bool> > m_lsbPaths;
|
||||
map<CString, vector<CTemplate*> > m_mvLoops;
|
||||
vector<CTemplateLoopContext*> m_vLoopContexts;
|
||||
CSmartPtr<CTemplateOptions> m_spOptions;
|
||||
|
||||
Reference in New Issue
Block a user