mirror of
https://github.com/github/codeql.git
synced 2026-02-08 11:11:06 +01:00
`Merge branch 'main' into type-expr-resolution
This commit is contained in:
@@ -219,6 +219,8 @@ class TypeExpr extends TType, AstNode {
|
||||
result.(InlineCast).getType() = this
|
||||
or
|
||||
result.(Class).getAliasType() = this
|
||||
or
|
||||
result.(Class).getUnionMember() = this
|
||||
}
|
||||
|
||||
Type getResolvedType() { resolveTypeExpr(this, result) }
|
||||
@@ -327,6 +329,11 @@ class Class extends TClass, AstNode, ModuleMember {
|
||||
TypeExpr getAliasType() {
|
||||
toGenerated(result) = cls.getChild(_).(Generated::TypeAliasBody).getChild()
|
||||
}
|
||||
|
||||
/** Gets the type of one of the members that this class is defined to be a union of. */
|
||||
Type getUnionMember() {
|
||||
toGenerated(result) = cls.getChild(_).(Generated::TypeUnionBody).getChild(_)
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -962,4 +969,11 @@ class ModuleExpr extends TModuleExpr, ModuleRef {
|
||||
final override FileOrModule getResolvedModule() { resolveModuleExpr(this, result) }
|
||||
|
||||
final override string toString() { result = this.getName() }
|
||||
|
||||
override string getAPrimaryQlClass() { result = "ModuleExpr" }
|
||||
|
||||
override AstNode getParent() {
|
||||
result = super.getParent() or
|
||||
result.(PredicateCall).getQualifier() = this
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user