diff options
Diffstat (limited to 'source/Symbol/CompileUnit.cpp')
-rw-r--r-- | source/Symbol/CompileUnit.cpp | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/source/Symbol/CompileUnit.cpp b/source/Symbol/CompileUnit.cpp index 6483258..d43ef44 100644 --- a/source/Symbol/CompileUnit.cpp +++ b/source/Symbol/CompileUnit.cpp @@ -149,9 +149,9 @@ CompileUnit::GetFunctionAtIndex (size_t idx) } //---------------------------------------------------------------------- -// Find functions using the a Mangled::Tokens token list. This -// function currently implements an interative approach designed to find -// all instances of certain functions. It isn't designed to the the +// Find functions using the Mangled::Tokens token list. This +// function currently implements an interactive approach designed to find +// all instances of certain functions. It isn't designed to the // quickest way to lookup functions as it will need to iterate through // all functions and see if they match, though it does provide a powerful // and context sensitive way to search for all functions with a certain @@ -292,7 +292,7 @@ CompileUnit::FindLineEntry (uint32_t start_idx, uint32_t line, const FileSpec* f else { // All the line table entries actually point to the version of the Compile - // Unit that is in the support files (the one at 0 was artifically added.) + // Unit that is in the support files (the one at 0 was artificially added.) // So prefer the one further on in the support files if it exists... FileSpecList &support_files = GetSupportFiles(); const bool full = true; @@ -436,6 +436,23 @@ CompileUnit::SetVariableList(VariableListSP &variables) m_variables = variables; } +const std::vector<ConstString> & +CompileUnit::GetImportedModules () +{ + if (m_imported_modules.empty() && + m_flags.IsClear(flagsParsedImportedModules)) + { + m_flags.Set(flagsParsedImportedModules); + if (SymbolVendor *symbol_vendor = GetModule()->GetSymbolVendor()) + { + SymbolContext sc; + CalculateSymbolContext(&sc); + symbol_vendor->ParseImportedModules(sc, m_imported_modules); + } + } + return m_imported_modules; +} + FileSpecList& CompileUnit::GetSupportFiles () { |