|
@@ -409,7 +409,7 @@ protected:
|
|
|
}
|
|
|
|
|
|
// Use dali to resolve subfile into physical file info
|
|
|
- static IResolvedFile *resolveLFNusingDaliOrLocal(const char *fileName, bool useCache, bool cacheResult, bool writeAccess, bool alwaysCreate)
|
|
|
+ static IResolvedFile *resolveLFNusingDaliOrLocal(const char *fileName, bool useCache, bool cacheResult, bool writeAccess, bool alwaysCreate, bool resolveLocal)
|
|
|
{
|
|
|
// MORE - look at alwaysCreate... This may be useful to implement earlier locking semantics.
|
|
|
if (traceLevel > 9)
|
|
@@ -449,7 +449,7 @@ protected:
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
- if (!result)
|
|
|
+ if (!result && resolveLocal)
|
|
|
{
|
|
|
StringBuffer useName;
|
|
|
if (strstr(fileName,"::"))
|
|
@@ -486,7 +486,7 @@ protected:
|
|
|
{
|
|
|
IResolvedFile *result = lookupFile(fileName, useCache, cacheResult, writeAccess, alwaysCreate);
|
|
|
if (!result && (!checkCompulsory || !isCompulsory()))
|
|
|
- result = resolveLFNusingDaliOrLocal(fileName, useCache, cacheResult, writeAccess, alwaysCreate);
|
|
|
+ result = resolveLFNusingDaliOrLocal(fileName, useCache, cacheResult, writeAccess, alwaysCreate, resolveLocally());
|
|
|
return result;
|
|
|
}
|
|
|
|
|
@@ -611,7 +611,7 @@ public:
|
|
|
expandLogicalFilename(fileName, _fileName, wu, false);
|
|
|
Owned<IResolvedFile> resolved = lookupFile(fileName, false, false, true, true);
|
|
|
if (!resolved)
|
|
|
- resolved.setown(resolveLFNusingDaliOrLocal(fileName, false, false, true, true));
|
|
|
+ resolved.setown(resolveLFNusingDaliOrLocal(fileName, false, false, true, true, resolveLocally()));
|
|
|
if (resolved)
|
|
|
{
|
|
|
if (resolved->exists())
|
|
@@ -666,6 +666,10 @@ public:
|
|
|
{
|
|
|
return CPackageNode::isCompulsory();
|
|
|
}
|
|
|
+ virtual bool resolveLocally() const
|
|
|
+ {
|
|
|
+ return CPackageNode::resolveLocally();
|
|
|
+ }
|
|
|
};
|
|
|
|
|
|
CResolvedFileCache CRoxiePackageNode::daliFiles;
|