Parsing

This section contains definitions declared in the chpl::parsing namespace.

namespace parsing

Typedefs

using ConfigSettingsList = std::vector<std::pair<std::string, std::string>>
using AttributeToolNamesList = std::vector<UniqueString>
using ModuleVec = std::vector<const uast::Module*>

Functions

const FileContents &fileText(Context *context, std::string path)

This query returns the contents of a file as the string field in the FileContents. In case there is an error reading the file, the error is stored in the error field of the FileContents.

const FileContents &fileText(Context *context, UniqueString path)

Convenience function to call fileText given a UniqueString.

void setFileText(Context *context, std::string path, FileContents result)

This function sets the FileContents that will be returned by the fileText query above.

void setFileText(Context *context, std::string path, std::string text)

This function sets the string that will be returned by the fileText query above. The FileContents stored will have an empty ErrorMessage field.

void setFileText(Context *context, UniqueString path, std::string text)

This function sets the string that will be returned by the fileText query above. The FileContents stored will have an empty ErrorMessage field.

bool hasFileText(Context *context, const std::string &path)

This function returns true if the current revision already has contents stored in the fileText query for the given path.

const uast::BuilderResult &parseFileToBuilderResult(Context *context, UniqueString path, UniqueString parentSymbolPath)

This query reads a file (with the fileText query) and then parses it.

The ‘parentSymbolPath’ is relevant for submodules that are in separate files with ‘module include’. When parsing the included module for a ‘module include’, ‘parentSymbolPath’ should match the symbolPath of the ID of the module containing the ‘module include’ statement.

When parsing a toplevel module, ‘parentSymbolPath’ should be “”.

const uast::BuilderResult &parseFileToBuilderResultAndCheck(Context *context, UniqueString path, UniqueString parentSymbolPath)

Like parseFileToBuilderResult but also runs post-parse checks on the resulting builder result.

std::vector<const uast::AstNode*> introspectParsedTopLevelExpressions(Context *context)
std::vector<UniqueString> introspectParsedFiles(Context *context)
const uast::BuilderResult *parseFileContainingIdToBuilderResult(Context *context, ID id, UniqueString *setParentSymbolPath = nullptr)

Like parseFileToBuilderResult but parses whatever file contained ‘id’. Useful for projection queries.

If setParentSymbolPath is not nullptr, sets it to the parentSymbolPath used when creating the BuilderResult.

void countTokens(Context *context, UniqueString path, ParserStats *parseStats)

A function for counting the tokens when parsing

const Location &locateId(Context *context, ID id)

This query returns the Location where a particular ID appeared. It cannot be used for Comments because Comments don’t have IDs set. If Locations for Comments are needed, use uast::BuilderResult::commentToLocation

const Location &locateAst(Context *context, const uast::AstNode *ast)

This function just runs locateId on ast->id(). Similarly to locateID, it cannot be used to get a Location for a Comment.

const ModuleVec &parse(Context *context, UniqueString path, UniqueString parentSymbolPath)

This query returns a vector of parsed modules given a file path.

The ‘parentSymbolPath’ is relevant for submodules that are in separate files with ‘module include’. When parsing the included module for a ‘module include’, ‘parentSymbolPath’ should match the symbolPath of the ID of the module containing the ‘module include’ statement.

When parsing a toplevel module, ‘parentSymbolPath’ should be “”.

Unlike ‘parseFileToBuilderResult’ this query will report any errors encountered while parsing to the context.

const ModuleVec &parseToplevel(Context *context, UniqueString path)

Convenience function to parse a file with parentSymbolPath=””. Any errors encountered while parsing are reported to the context.

const std::vector<ID> &toplevelModulesInFile(Context *context, UniqueString path)

Parse a file (with parentSymbolPath=””, so not a submodule) and return the IDs of the top-level modules that it contains.

ID findProcMainInModule(Context *context, ID modId)

Given a module ID, returns the ID of a ‘main’ function provided in that module, or the empty ID if none was present.

If there were multiple ‘main’ functions in that module, this function returns the first one. Other parts of compilation should produce a compilation error in that case.

ID findMainModule(Context *context, std::vector<ID> commandLineModules, UniqueString requestedMainModuleName, bool libraryMode)

Given the modules from files named on the command line, determine which module is the main module, and return it.

requestedMainModuleName can be “”, but if it is not, it should be the name of a module in commandLineModules.

If libraryMode is set, most errors in determining the main module will be ignored. This mode is useful for library compilation, where the main module concept does not make sense.

std::vector<ID> findMainAndCommandLineModules(Context *context, std::vector<UniqueString> paths, UniqueString requestedMainModuleName, bool libraryMode, ID &mainModule)

Convenience function to compute the main module ID and command-line module IDs based upon paths provided at the command line.

Returns the command-line module IDs and sets mainModule to the main module ID.

const std::vector<UniqueString> &moduleSearchPath(Context *context)

Return the current module search path.

void setModuleSearchPath(Context *context, std::vector<UniqueString> searchPath)

Sets the current module search path.

const std::vector<UniqueString> &prependedInternalModulePath(Context *context)

Return a list of paths to be prepended to the internal module path. This is likely to be empty unless using &#8212;prepend-internal-module-dir when compiling

void setPrependedInternalModulePath(Context *context, std::vector<UniqueString> paths)

Set a list of paths to be prepended to the internal module path. This is typically set using the compiler flag &#8212;prepend-internal-module-dir and will be called during setupModuleSearchPaths

const std::vector<UniqueString> &prependedStandardModulePath(Context *context)

Return a list of paths to be prepended to the standard module path. This is likely to be empty unless using &#8212;prepend-standard-module-dir when compiling

void setPrependedStandardModulePath(Context *context, std::vector<UniqueString> paths)

Set a list of paths to be prepended to the standard module path. This is typically set using the compiler flag &#8212;prepend-standard-module-dir and will be called during setupModuleSearchPaths

UniqueString internalModulePath(Context *context)

Return the current internal module path, i.e. CHPL_HOME/modules/internal/

void setInternalModulePath(Context *context, UniqueString path)

Set the current internal modules directory, i.e. CHPL_HOME/modules/internal/ This should be formed in a consistent manner with setModuleSearchPath, so that this is a prefix for some module search paths.

UniqueString bundledModulePath(Context *context)

Return the current standard module path, i.e. CHPL_HOME/modules/

void setBundledModulePath(Context *context, UniqueString path)

Set the current bundled modules directory, i.e. CHPL_HOME/modules/ This should be formed in a consistent manner with setModuleSearchPath, so that this is a prefix for some module search paths.

void setupModuleSearchPaths(Context *context, const std::string &chplHome, bool minimalModules, const std::string &chplLocaleModel, bool enableTaskTracking, const std::string &chplTasks, const std::string &chplComm, const std::string &chplSysModulesSubdir, const std::string &chplModulePath, const std::vector<std::string> &prependInternalModulePaths, const std::vector<std::string> &prependStandardModulePaths, const std::vector<std::string> &cmdLinePaths, const std::vector<std::string> &inputFilenames)

Helper to call setModuleSearchPath, setInternalModulePath, standardModulePath. This function accepts the path to CHPL_HOME, and any additional module path components (from environment variable and command line).

Most of these arguments have corresponding env / printchplenv settings: chplHome &#8212; CHPL_HOME chplLocaleModel &#8212; CHPL_LOCALE_MODEL chplTasks &#8212; CHPL_TASKS chplComm &#8212; CHPL_COMM chplSysModulesSubdir &#8212; CHPL_SYS_MODULES_SUBDIR chplModulePath &#8212; CHPL_MODULE_PATH

The arguments ‘prependInternalModulePaths’ and ‘prependStandardModulePaths’, if non-empty, allow one to override where the context will search for internal and standard modules, respectively. It will search each successive path in the vector before consulting the default locations.

These arguments facilitate support for frontend flags with similar names, allowing users to diagnose problems with internal/standard modules in the field. Instead of upgrading their Chapel installation, patched versions of problematic modules can be swapped in instead.

void setupModuleSearchPaths(Context *context, bool minimalModules, bool enableTaskTracking, const std::vector<std::string> &cmdLinePaths, const std::vector<std::string> &inputFilenames)

Overload of the more general setupModuleSearchPaths that uses the context’s stored chplHome and chplEnv to determine the values of most arguments.

bool idIsInInternalModule(Context *context, ID id)

Returns true if the ID corresponds to something in an internal module. If the internal module path is empty, this function returns false.

Also considers paths from &#8212;prepend-internal-module-dir, if any.

bool idIsInBundledModule(Context *context, ID id)

Returns true if the ID corresponds to something in a bundled module. If the bundled module path is empty, this function returns false.

Also considers paths, if any, from &#8212;prepend-internal-module-dir and &#8212;prepend-standard-module-dir.

bool idIsInStandardModule(Context *context, ID id)

Returns true if the ID corresponds to something in a standard module. A standard module is a bundled module, but it is not a package module (which may be contributed by users and are not subject to the same constraints as standard modules) and not an internal module.

If the bundled module path is empty, this function returns false.

Also considers paths from &#8212;prepend-standard-module-dir, if any.

bool filePathIsInInternalModule(Context *context, UniqueString filePath)

Returns true if the file path refers to the internal modules. (Typically, that would be if it begins with $CHPL_HOME/modules/internal). If the internal module path is empty, this function returns false.

Also considers paths from &#8212;prepend-internal-module-dir, if any.

bool filePathIsInStandardModule(Context *context, UniqueString filePath)

Returns true if the file path corresponds to the standard modules. A standard module is a bundled module, but it is not a package module (which may be contributed by users and are not subject to the same constraints as standard modules) and not an internal module. (So, in other words, it would typically be a standard module if it begins with $CHPL_HOME/modules/ but doesn’t begin with $CHPL_HOME/modules/internal or $CHPL_HOME/modules/packages; this will include $CHPL_HOME/modules/standard and $CHPL_HOME/modules/dists).

If the bundled module path is empty, this function returns false.

Also considers paths from &#8212;prepend-standard-module-dir, if any.

bool filePathIsInBundledModule(Context *context, UniqueString filePath)

Returns true if the file path corresponds to the bundled modules. (Typically, that would be if it begins with $CHPL_HOME/modules/). If the bundled module path is empty, this function returns false.

Also considers paths, if any, from &#8212;prepend-internal-module-dir and &#8212;prepend-standard-module-dir.

bool checkFileExists(Context *context, std::string path, bool requireFileCaseMatches)

Check if a file exists. This is a query, so that duplicate checks can be avoided. Returns true if the file exists, false otherwise.

requireFileCaseMatches helps with case-insensitive filesystems:

‘requireFileCaseMatches=true’ causes this function to work with a directory listing & if the filename component of ‘path’ isn’t found in its parent directory listing, this function returns ‘false’.

‘requireFileCaseMatches=false’ allows a case-insensitive filesystem to indicate that ‘AA’ exists if the filesystem has the file ‘Aa’.

std::string getExistingFileAtPath(Context *context, std::string path)

This helper function checks if a file exists at a particular path. If it does, it returns a normalized form of the path to that file. If not, it returns the empty string.

std::string getExistingFileInModuleSearchPath(Context *context, const std::string &fname)

This helper function checks the module search path for an existing file named fname.

If multiple such files exist in different directories, it will choose the first and emit an ambiguity warning.

This function uses case-sensitive matching against the directory listings, so ‘use Module’ refers to ‘Module.chpl’ even on case-insensitive filesystems.

If nothing is found, returns the empty string.

const uast::Module *getToplevelModule(Context *context, UniqueString name)

This query parses a toplevel module by name. Returns nullptr if no such toplevel module can be found in the module search path.

ID getSymbolIdFromTopLevelModule(Context *context, const char *modName, const char *symName)

Given a particular (presumably standard) module, return the ID of a symbol with the given name in that module. Beyond creating the ID, this also ensures that the standard module is parsed, and thus, that ‘idToAst’ on the returned ID will return a non-null value.

IdAndName getSymbolFromTopLevelModule(Context *context, const char *modName, const char *symName)

Like getSymbolId…, but return also contains the name of the given symbol for convenience.

const uast::Module *getIncludedSubmodule(Context *context, ID includeModuleId)

This query parses a submodule for ‘include submodule’. The ID passed should be the ID of an Include statement. Returns nullptr if no such file can be found.

const uast::AstNode *idToAst(Context *context, ID id)

Returns the uast node with the given ID.

uast::AstTag idToTag(Context *context, ID id)

Returns the tag for the node with the given ID.

bool idIsModule(Context *context, ID id)

Returns true if the ID is a module.

bool idIsModuleScopeVar(Context *context, ID id)

Returns true if the ID is a module-scope variable.

bool idIsParenlessFunction(Context *context, ID id)

Returns true if the ID is a parenless function.

bool idIsNestedFunction(Context *context, ID id)

Returns true if the ID is a nested function.

bool idIsPrivateDecl(Context *context, ID id)

Returns true if the ID refers to a private declaration.

bool idIsFunction(Context *context, ID id)

Returns true if the ID is a function.

bool idIsExtern(Context *context, ID id)

Returns true if the ID is marked ‘extern’.

bool idIsExport(Context *context, ID id)

Returns true if the ID is marked ‘export’.

bool idIsMethod(Context *context, ID id)

Returns true if the ID is a method.

UniqueString fieldIdToName(Context *context, ID id)

If the ID represents a field in a record/class/union, returns the name of that field. Otherwise, returns the empty string.

bool idIsField(Context *context, ID id)

Returns true if the ID is a field in a record/class/union.

const ID &idToParentId(Context *context, ID id)

Returns the parent ID given an ID

ID idToParentFunctionId(Context *context, ID id)

Returns the parent function ID given an ID.

const uast::AstNode *parentAst(Context *context, const uast::AstNode *node)

Returns the parent AST node given an AST node

ID idToParentModule(Context *context, ID id)

Returns the ID for the module containing the given ID, or the empty ID when given a toplevel module.

bool idIsToplevelModule(Context *context, ID id)

Returns ‘true’ if ID refers to a toplevel module.

uast::Function::ReturnIntent idToFnReturnIntent(Context *context, ID id)

Given an ID that represents a Function, get the declared return intent for that function.

bool idIsFunctionWithWhere(Context *context, ID id)

Returns ‘true’ if the passed ID represents a Function with a where clause, and ‘false’ otherwise.

ID idToContainingMultiDeclId(Context *context, ID id)

Given an ID for a Variable, returns the ID of the containing MultiDecl or TupleDecl, if any, and the ID of the variable otherwise.

bool idContainsFieldWithName(Context *context, ID typeDeclId, UniqueString fieldName)

Given an ID for a Record/Union/Class Decl, returns ‘true’ if the passed name is the name of a field contained in it.

ID fieldIdWithName(Context *context, ID typeDeclId, UniqueString fieldName)

Given an ID for a Record/Union/Class Decl, and a field name, returns the ID for the Variable declaring that field.

bool aggregateUsesForwarding(Context *context, ID typeDeclId)

Given an ID for a Record/Union/Class Decl, returns ‘true’ if that Record/Union/Class Decl directly contains one or more ‘forwarding’ declarations.

void setConfigSettings(Context *context, ConfigSettingsList keys)

Store config settings that were set from the command line using -s flags

const ConfigSettingsList &configSettings(Context *context)

Get any config settings that were set from the command line and stored

void setAttributeToolNames(Context *context, AttributeToolNamesList keys)
const AttributeToolNamesList &AttributeToolNames(Context *context)
const uast::AttributeGroup *idToAttributeGroup(Context *context, ID id)

Given an ID, returns the attributes associated with the ID. This is important to use or else attributes for children of MultiDecls or TupleDecls will not be found.

const uast::AttributeGroup *astToAttributeGroup(Context *context, const uast::AstNode *node)

Given an AstNode, returns the attributes associated with it. This is important to use or else attributes for children of MultiDecls or TupleDecls will not be found.

void reportDeprecationWarningForId(Context *context, ID idMention, ID idTarget)

Given an ID ‘idMention’ representing a mention of a symbol, and an ID ‘idTarget’ representing the symbol, determine if a deprecation warning should be produced for ‘idTarget’ at ‘idMention’. If so, the warning will be reported to the context.

A warning will be reported to the context only once per revision. It may not be reported if the context or compiler is configured to suppress deprecation warnings.

The ‘idMention’ may refer to any AST but will most often be an Identifier. The ‘idTarget’ should refer to a NamedDecl. If it does not, then nothing is reported.

bool shouldWarnUnstableForPath(Context *context, UniqueString filepath)

Returns the state of &#8212;warn-unstable or -internal or -standard depending on which of these applies to ‘filepath’.

bool shouldWarnUnstableForId(Context *context, const ID &id)

Returns the state of &#8212;warn-unstable or -internal or -standard depending on which of these applies to ‘id’.

void reportUnstableWarningForId(Context *context, ID idMention, ID idTarget)

Given an ID ‘idMention’ representing a mention of a symbol, and an ID ‘idTarget’ representing the symbol, determine if an unstable warning should be produced for ‘idTarget’ at ‘idMention’. If so, the warning will be reported to the context.

A warning will be reported to the context only once per revision. It may not be reported if the context or compiler is configured to suppress unstable warnings.

The ‘idMention’ may refer to any AST but will most often be an Identifier. The ‘idTarget’ should refer to a NamedDecl. If it does not, then nothing is reported.

uast::Module::Kind idToModuleKind(Context *context, ID id)
bool isSpecialMethodName(UniqueString name)
bool isCallToClassManager(const uast::FnCall *call)
const uast::BuilderResult &parseFile(Context *context, UniqueString path)
class FileContents

This class represents the result of reading a file.

Public Functions

inline FileContents()

Construct a FileContents containing empty text and no error

inline FileContents(std::string text)

Construct a FileContents containing the passed text and no error

inline FileContents(std::string text, const ErrorBase *error)

Construct a FileContents containing the passed text and error

inline const std::string &text() const

Return a reference to the contents of this file

inline const ErrorBase *error() const

Return a reference to an error encountered when reading this file

inline bool operator==(const FileContents &other) const
inline bool operator!=(const FileContents &other) const
inline void swap(FileContents &other)
void mark(Context *context) const

Public Static Functions

static inline bool update(FileContents &keep, FileContents &addin)
struct IdAndName

Public Members

ID id
UniqueString name
class Parser

A class for parsing

Public Functions

~Parser() = default
inline Context *context()

Return the AST Context used by this Parser.

uast::BuilderResult parseFile(const char *path, ParserStats *parseStats = nullptr)

Parse a file at a particular path.

uast::BuilderResult parseString(const char *path, const char *str, ParserStats *parseStats = nullptr)

Parse source code in a string. ‘path’ is only used for certain errors.

Public Static Functions

static Parser createForTopLevelModule(Context *context)

Construct a parser for parsing a top-level module

static Parser createForIncludedModule(Context *context, UniqueString parentSymbolPath)

Construct a parser for parsing an included module. ‘parentSymbolPath’ is the symbol path component of the ID of the module containing the ‘module include’ statement.

struct ParserStats

Public Functions

ParserStats()
ParserStats(bool printTokens)