Merged logic between main- and sub- script import.

This commit is contained in:
arookas 2015-12-10 17:51:21 -05:00
parent 85d85695e2
commit 0c973514d9

View file

@ -20,6 +20,7 @@ namespace arookas
List<sunScriptFile> imports = new List<sunScriptFile>(10); List<sunScriptFile> imports = new List<sunScriptFile>(10);
Stack<sunScriptFile> current = new Stack<sunScriptFile>(5); Stack<sunScriptFile> current = new Stack<sunScriptFile>(5);
string rootDirectory, currentDirectory; string rootDirectory, currentDirectory;
string CurrentDirectory { get { return current.Count > 0 ? Path.GetDirectoryName(current.Peek().Name) : currentDirectory; } }
public sunDefaultImportResolver() public sunDefaultImportResolver()
{ {
@ -44,24 +45,12 @@ namespace arookas
} }
else else
{ {
if (current.Count > 0) // check if the file exists relative to the current one;
// if it's not there, check the root directory
fullPath = Path.Combine(CurrentDirectory, name);
if (!File.Exists(fullPath))
{ {
// check if the file exists relative to the current one; fullPath = Path.Combine(rootDirectory, name);
// if it's not there, check the root directory
fullPath = Path.Combine(Path.GetDirectoryName(current.Peek().Name), name);
if (!File.Exists(fullPath))
{
fullPath = Path.Combine(rootDirectory, name);
if (!File.Exists(fullPath))
{
return sunImportResult.Missing;
}
}
}
else
{
// if this is the main script file (i.e. current stack is empty), just use the current directory
fullPath = Path.Combine(currentDirectory, name);
if (!File.Exists(fullPath)) if (!File.Exists(fullPath))
{ {
return sunImportResult.Missing; return sunImportResult.Missing;