зеркало из https://github.com/github/codeql.git
1155 строки
27 KiB
Python
1155 строки
27 KiB
Python
"""
|
|
Schema description
|
|
|
|
This file should be kept simple:
|
|
* no flow control
|
|
* no aliases
|
|
* only class definitions with annotations and `include` calls
|
|
|
|
For how documentation of generated QL code works, please read schema_documentation.md.
|
|
"""
|
|
|
|
from misc.codegen.lib.schemadefs import *
|
|
|
|
include("prefix.dbscheme")
|
|
|
|
@qltest.skip
|
|
class Element:
|
|
is_unknown: predicate | cpp.skip
|
|
|
|
@qltest.collapse_hierarchy
|
|
class File(Element):
|
|
name: string
|
|
|
|
@qltest.skip
|
|
@qltest.collapse_hierarchy
|
|
class Location(Element):
|
|
file: File
|
|
start_line: int
|
|
start_column: int
|
|
end_line: int
|
|
end_column: int
|
|
|
|
@qltest.skip
|
|
class Locatable(Element):
|
|
location: optional[Location] | cpp.skip | doc("location associated with this element in the code")
|
|
|
|
@qltest.collapse_hierarchy
|
|
@qltest.skip
|
|
class ErrorElement(Locatable):
|
|
"""The superclass of all elements indicating some kind of error."""
|
|
pass
|
|
|
|
@use_for_null
|
|
class UnspecifiedElement(ErrorElement):
|
|
parent: optional[Element]
|
|
property: string
|
|
index: optional[int]
|
|
error: string
|
|
|
|
class Comment(Locatable):
|
|
text: string
|
|
|
|
class Diagnostics(Locatable):
|
|
text: string
|
|
kind: int
|
|
|
|
class DbFile(File):
|
|
pass
|
|
|
|
class DbLocation(Location):
|
|
pass
|
|
|
|
@synth.on_arguments()
|
|
class UnknownFile(File):
|
|
pass
|
|
|
|
@synth.on_arguments()
|
|
class UnknownLocation(Location):
|
|
pass
|
|
|
|
class AstNode(Locatable):
|
|
pass
|
|
|
|
@group("type")
|
|
class Type(Element):
|
|
name: string
|
|
canonical_type: "Type"
|
|
|
|
@group("decl")
|
|
class Decl(AstNode):
|
|
module: "ModuleDecl"
|
|
members: list["Decl"] | child
|
|
|
|
@group("expr")
|
|
class Expr(AstNode):
|
|
"""The base class for all expressions in Swift."""
|
|
type: optional[Type]
|
|
|
|
@group("pattern")
|
|
class Pattern(AstNode):
|
|
pass
|
|
|
|
@group("stmt")
|
|
class Stmt(AstNode):
|
|
pass
|
|
|
|
@group("decl")
|
|
class GenericContext(Element):
|
|
generic_type_params: list["GenericTypeParamDecl"] | child
|
|
|
|
class EnumCaseDecl(Decl):
|
|
elements: list["EnumElementDecl"]
|
|
|
|
class ExtensionDecl(GenericContext, Decl):
|
|
extended_type_decl: "NominalTypeDecl"
|
|
protocols: list["ProtocolDecl"]
|
|
|
|
class IfConfigDecl(Decl):
|
|
active_elements: list[AstNode]
|
|
|
|
class ImportDecl(Decl):
|
|
is_exported: predicate
|
|
imported_module: optional["ModuleDecl"]
|
|
declarations: list["ValueDecl"]
|
|
|
|
@qltest.skip
|
|
class MissingMemberDecl(Decl):
|
|
"""A placeholder for missing declarations that can arise on object deserialization."""
|
|
name: string
|
|
|
|
class OperatorDecl(Decl):
|
|
name: string
|
|
|
|
class PatternBindingDecl(Decl):
|
|
inits: list[optional[Expr]] | child
|
|
patterns: list[Pattern] | child
|
|
|
|
class PoundDiagnosticDecl(Decl):
|
|
""" A diagnostic directive, which is either `#error` or `#warning`."""
|
|
kind: int | desc("""This is 1 for `#error` and 2 for `#warning`.""")
|
|
message: "StringLiteralExpr" | child
|
|
|
|
class PrecedenceGroupDecl(Decl):
|
|
pass
|
|
|
|
class TopLevelCodeDecl(Decl):
|
|
body: "BraceStmt" | child
|
|
|
|
class ValueDecl(Decl):
|
|
interface_type: Type
|
|
|
|
class AbstractStorageDecl(ValueDecl):
|
|
accessor_decls: list["AccessorDecl"] | child
|
|
|
|
class VarDecl(AbstractStorageDecl):
|
|
"""
|
|
A declaration of a variable such as
|
|
* a local variable in a function:
|
|
```
|
|
func foo() {
|
|
var x = 42 // <-
|
|
let y = "hello" // <-
|
|
...
|
|
}
|
|
```
|
|
* a member of a `struct` or `class`:
|
|
```
|
|
struct S {
|
|
var size : Int // <-
|
|
}
|
|
```
|
|
* ...
|
|
"""
|
|
name: string
|
|
type: Type
|
|
attached_property_wrapper_type: optional[Type]
|
|
parent_pattern: optional[Pattern]
|
|
parent_initializer: optional[Expr]
|
|
property_wrapper_backing_var_binding: optional[PatternBindingDecl] | child | desc("""
|
|
This is the synthesized binding introducing the property wrapper backing variable for this
|
|
variable, if any. See `getPropertyWrapperBackingVar`.
|
|
""")
|
|
property_wrapper_backing_var: optional["VarDecl"] | child | desc("""
|
|
This is the compiler synthesized variable holding the property wrapper for this variable, if any.
|
|
|
|
For a property wrapper like
|
|
```
|
|
@propertyWrapper struct MyWrapper { ... }
|
|
|
|
struct S {
|
|
@MyWrapper var x : Int = 42
|
|
}
|
|
```
|
|
the compiler synthesizes a variable in `S` along the lines of
|
|
```
|
|
var _x = MyWrapper(wrappedValue: 42)
|
|
```
|
|
This predicate returns such variable declaration.
|
|
""")
|
|
property_wrapper_projection_var_binding: optional[PatternBindingDecl] | child | desc("""
|
|
This is the synthesized binding introducing the property wrapper projection variable for this
|
|
variable, if any. See `getPropertyWrapperProjectionVar`.
|
|
""")
|
|
property_wrapper_projection_var: optional["VarDecl"] | child | desc("""
|
|
If this variable has a property wrapper with a projected value, this is the corresponding
|
|
synthesized variable holding that projected value, accessible with this variable's name
|
|
prefixed with `$`.
|
|
|
|
For a property wrapper like
|
|
```
|
|
@propertyWrapper struct MyWrapper {
|
|
var projectedValue : Bool
|
|
...
|
|
}
|
|
|
|
struct S {
|
|
@MyWrapper var x : Int = 42
|
|
}
|
|
```
|
|
```
|
|
the compiler synthesizes a variable in `S` along the lines of
|
|
```
|
|
var $x : Bool { ... }
|
|
```
|
|
This predicate returns such variable declaration.
|
|
""")
|
|
|
|
class ParamDecl(VarDecl):
|
|
is_inout: predicate | doc("this is an `inout` parameter")
|
|
property_wrapper_local_wrapped_var_binding: optional[PatternBindingDecl] | child | desc("""
|
|
This is the synthesized binding introducing the property wrapper local wrapped projection
|
|
variable for this variable, if any.
|
|
""")
|
|
property_wrapper_local_wrapped_var: optional["VarDecl"] | child | desc("""
|
|
This is the synthesized local wrapped value, shadowing this parameter declaration in case it
|
|
has a property wrapper.
|
|
""")
|
|
|
|
class Callable(Element):
|
|
name: optional[string] | doc("name of this callable")
|
|
self_param: optional[ParamDecl] | child
|
|
params: list[ParamDecl] | child
|
|
body: optional["BraceStmt"] | child | desc("The body is absent within protocol declarations.")
|
|
captures: list["CapturedDecl"] | child
|
|
|
|
class AbstractFunctionDecl(GenericContext, ValueDecl, Callable):
|
|
pass
|
|
|
|
class EnumElementDecl(ValueDecl):
|
|
name: string
|
|
params: list[ParamDecl] | child
|
|
|
|
class InfixOperatorDecl(OperatorDecl):
|
|
precedence_group: optional[PrecedenceGroupDecl]
|
|
|
|
class PostfixOperatorDecl(OperatorDecl):
|
|
pass
|
|
|
|
class PrefixOperatorDecl(OperatorDecl):
|
|
pass
|
|
|
|
class TypeDecl(ValueDecl):
|
|
name: string
|
|
base_types: list[Type]
|
|
|
|
class AbstractTypeParamDecl(TypeDecl):
|
|
pass
|
|
|
|
class ConstructorDecl(AbstractFunctionDecl):
|
|
pass
|
|
|
|
class DestructorDecl(AbstractFunctionDecl):
|
|
pass
|
|
|
|
class FuncDecl(AbstractFunctionDecl):
|
|
pass
|
|
|
|
class GenericTypeDecl(GenericContext, TypeDecl):
|
|
pass
|
|
|
|
class ModuleDecl(TypeDecl):
|
|
is_builtin_module: predicate | doc("this module is the built-in one")
|
|
is_system_module: predicate | doc("this module is a system one")
|
|
imported_modules: list["ModuleDecl"]
|
|
exported_modules: list["ModuleDecl"]
|
|
|
|
class SubscriptDecl(AbstractStorageDecl, GenericContext):
|
|
params: list[ParamDecl] | child
|
|
element_type: Type
|
|
element_type: Type
|
|
|
|
class AccessorDecl(FuncDecl):
|
|
is_getter: predicate | doc('this accessor is a getter')
|
|
is_setter: predicate | doc('this accessor is a setter')
|
|
is_will_set: predicate | doc('this accessor is a `willSet`, called before the property is set')
|
|
is_did_set: predicate | doc('this accessor is a `didSet`, called after the property is set')
|
|
is_read: predicate | doc('this accessor is a `_read` coroutine, yielding a borrowed value of the property')
|
|
is_modify: predicate | doc('this accessor is a `_modify` coroutine, yielding an inout value of the property')
|
|
is_unsafe_address: predicate | doc('this accessor is an `unsafeAddress` immutable addressor')
|
|
is_unsafe_mutable_address: predicate | doc('this accessor is an `unsafeMutableAddress` mutable addressor')
|
|
|
|
class AssociatedTypeDecl(AbstractTypeParamDecl):
|
|
pass
|
|
|
|
class ConcreteFuncDecl(FuncDecl):
|
|
pass
|
|
|
|
class ConcreteVarDecl(VarDecl):
|
|
introducer_int: int | doc("introducer enumeration value") | desc("""
|
|
This is 0 if the variable was introduced with `let` and 1 if it was introduced with `var`.
|
|
""")
|
|
|
|
class GenericTypeParamDecl(AbstractTypeParamDecl):
|
|
pass
|
|
|
|
class NominalTypeDecl(GenericTypeDecl):
|
|
type: Type
|
|
|
|
class OpaqueTypeDecl(GenericTypeDecl):
|
|
"""
|
|
A declaration of an opaque type, that is formally equivalent to a given type but abstracts it
|
|
away.
|
|
|
|
Such a declaration is implicitly given when a declaration is written with an opaque result type,
|
|
for example
|
|
```
|
|
func opaque() -> some SignedInteger { return 1 }
|
|
```
|
|
See https://docs.swift.org/swift-book/LanguageGuide/OpaqueTypes.html.
|
|
"""
|
|
naming_declaration: ValueDecl
|
|
opaque_generic_params: list["GenericTypeParamType"]
|
|
opaque_generic_params: list["GenericTypeParamType"]
|
|
|
|
class TypeAliasDecl(GenericTypeDecl):
|
|
pass
|
|
|
|
class ClassDecl(NominalTypeDecl):
|
|
pass
|
|
|
|
class EnumDecl(NominalTypeDecl):
|
|
pass
|
|
|
|
class ProtocolDecl(NominalTypeDecl):
|
|
pass
|
|
|
|
class StructDecl(NominalTypeDecl):
|
|
pass
|
|
|
|
@group("expr")
|
|
class Argument(Locatable):
|
|
label: string
|
|
expr: Expr | child
|
|
|
|
class AbstractClosureExpr(Expr, Callable):
|
|
pass
|
|
|
|
class AnyTryExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class AppliedPropertyWrapperExpr(Expr):
|
|
"""An implicit application of a property wrapper on the argument of a call."""
|
|
kind: int | desc("This is 1 for a wrapped value and 2 for a projected one.")
|
|
value: Expr | child | desc("The value on which the wrapper is applied.")
|
|
param: ParamDecl | doc("parameter declaration owning this wrapper application")
|
|
|
|
class ApplyExpr(Expr):
|
|
function: Expr | child | doc("function being applied")
|
|
arguments: list[Argument] | child | doc("arguments passed to the applied function")
|
|
|
|
class AssignExpr(Expr):
|
|
dest: Expr | child
|
|
source: Expr | child
|
|
|
|
class BindOptionalExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class CapturedDecl(Decl):
|
|
decl: ValueDecl | doc("the declaration captured by the parent closure")
|
|
is_direct: predicate
|
|
is_escaping: predicate
|
|
|
|
class CaptureListExpr(Expr):
|
|
binding_decls: list[PatternBindingDecl] | child
|
|
closure_body: "ClosureExpr" | child
|
|
|
|
class CollectionExpr(Expr):
|
|
pass
|
|
|
|
class DeclRefExpr(Expr):
|
|
decl: Decl
|
|
replacement_types: list[Type]
|
|
has_direct_to_storage_semantics: predicate
|
|
has_direct_to_implementation_semantics: predicate
|
|
has_ordinary_semantics: predicate
|
|
has_distributed_thunk_semantics: predicate
|
|
|
|
class DefaultArgumentExpr(Expr):
|
|
param_decl: ParamDecl
|
|
param_index: int
|
|
caller_side_default: optional[Expr]
|
|
|
|
class DiscardAssignmentExpr(Expr):
|
|
pass
|
|
|
|
class DotSyntaxBaseIgnoredExpr(Expr):
|
|
qualifier: Expr | child
|
|
sub_expr: Expr | child
|
|
|
|
class DynamicTypeExpr(Expr):
|
|
base: Expr | child
|
|
|
|
class EnumIsCaseExpr(Expr):
|
|
sub_expr: Expr | child
|
|
element: EnumElementDecl
|
|
|
|
@qltest.skip
|
|
class ErrorExpr(Expr, ErrorElement):
|
|
pass
|
|
|
|
class ExplicitCastExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class ForceValueExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
@qltest.collapse_hierarchy
|
|
class IdentityExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class IfExpr(Expr):
|
|
condition: Expr | child
|
|
then_expr: Expr | child
|
|
else_expr: Expr | child
|
|
|
|
@qltest.collapse_hierarchy
|
|
class ImplicitConversionExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class InOutExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class KeyPathApplicationExpr(Expr):
|
|
base: Expr | child
|
|
key_path: Expr | child
|
|
|
|
class KeyPathDotExpr(Expr):
|
|
pass
|
|
|
|
class KeyPathExpr(Expr):
|
|
root: optional["TypeRepr"] | child
|
|
parsed_path: optional[Expr] | child
|
|
|
|
class LazyInitializerExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class LiteralExpr(Expr):
|
|
pass
|
|
|
|
class LookupExpr(Expr):
|
|
base: Expr | child
|
|
member: optional[Decl]
|
|
|
|
class MakeTemporarilyEscapableExpr(Expr):
|
|
escaping_closure: "OpaqueValueExpr" | child
|
|
nonescaping_closure: Expr | child
|
|
sub_expr: Expr | child
|
|
|
|
@qltest.skip
|
|
class ObjCSelectorExpr(Expr):
|
|
sub_expr: Expr | child
|
|
method: AbstractFunctionDecl
|
|
|
|
class OneWayExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class OpaqueValueExpr(Expr):
|
|
pass
|
|
|
|
class OpenExistentialExpr(Expr):
|
|
sub_expr: Expr | child
|
|
existential: Expr | child
|
|
opaque_expr: OpaqueValueExpr | child
|
|
|
|
class OptionalEvaluationExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class OtherConstructorDeclRefExpr(Expr):
|
|
constructor_decl: ConstructorDecl
|
|
|
|
class PropertyWrapperValuePlaceholderExpr(Expr):
|
|
"""
|
|
A placeholder substituting property initializations with `=` when the property has a property
|
|
wrapper with an initializer.
|
|
"""
|
|
wrapped_value: optional[Expr]
|
|
placeholder: OpaqueValueExpr
|
|
|
|
class RebindSelfInConstructorExpr(Expr):
|
|
sub_expr: Expr | child
|
|
self: VarDecl
|
|
|
|
@qltest.skip
|
|
class SequenceExpr(Expr):
|
|
elements: list[Expr] | child
|
|
|
|
class SuperRefExpr(Expr):
|
|
self: VarDecl
|
|
|
|
class TapExpr(Expr):
|
|
sub_expr: optional[Expr] | child
|
|
body: "BraceStmt" | child
|
|
var: VarDecl
|
|
|
|
class TupleElementExpr(Expr):
|
|
sub_expr: Expr | child
|
|
index: int
|
|
|
|
class TupleExpr(Expr):
|
|
elements: list[Expr] | child
|
|
|
|
class TypeExpr(Expr):
|
|
type_repr: optional["TypeRepr"] | child
|
|
class UnresolvedDeclRefExpr(Expr, ErrorElement):
|
|
name: optional[string]
|
|
class UnresolvedDotExpr(Expr, ErrorElement):
|
|
base: Expr | child
|
|
name: string
|
|
class UnresolvedMemberExpr(Expr, ErrorElement):
|
|
name: string
|
|
class UnresolvedPatternExpr(Expr, ErrorElement):
|
|
sub_pattern: Pattern | child
|
|
class UnresolvedSpecializeExpr(Expr, ErrorElement):
|
|
sub_expr: Expr | child
|
|
|
|
class VarargExpansionExpr(Expr):
|
|
sub_expr: Expr | child
|
|
|
|
class AnyHashableErasureExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class ArchetypeToSuperExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class ArrayExpr(CollectionExpr):
|
|
elements: list[Expr] | child
|
|
|
|
class ArrayToPointerExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class AutoClosureExpr(AbstractClosureExpr):
|
|
pass
|
|
|
|
class AwaitExpr(IdentityExpr):
|
|
pass
|
|
|
|
class BinaryExpr(ApplyExpr):
|
|
pass
|
|
|
|
@qltest.skip
|
|
class BridgeFromObjCExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
@qltest.skip
|
|
class BridgeToObjCExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class BuiltinLiteralExpr(LiteralExpr):
|
|
pass
|
|
|
|
class CallExpr(ApplyExpr):
|
|
pass
|
|
|
|
class CheckedCastExpr(ExplicitCastExpr):
|
|
pass
|
|
|
|
class ClassMetatypeToObjectExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class ClosureExpr(AbstractClosureExpr):
|
|
pass
|
|
|
|
class CoerceExpr(ExplicitCastExpr):
|
|
pass
|
|
|
|
class CollectionUpcastConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
@qltest.skip
|
|
class ConditionalBridgeFromObjCExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class CovariantFunctionConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class CovariantReturnConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class DerivedToBaseExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class DestructureTupleExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class DictionaryExpr(CollectionExpr):
|
|
elements: list[Expr] | child
|
|
|
|
class DifferentiableFunctionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class DifferentiableFunctionExtractOriginalExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class DotSelfExpr(IdentityExpr):
|
|
pass
|
|
|
|
@qltest.collapse_hierarchy
|
|
class DynamicLookupExpr(LookupExpr):
|
|
pass
|
|
|
|
class ErasureExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class ExistentialMetatypeToObjectExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class ForceTryExpr(AnyTryExpr):
|
|
pass
|
|
|
|
class ForeignObjectConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class FunctionConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class InOutToPointerExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class InjectIntoOptionalExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class InterpolatedStringLiteralExpr(LiteralExpr):
|
|
interpolation_expr: optional[OpaqueValueExpr]
|
|
interpolation_count_expr: optional[Expr] | child
|
|
literal_capacity_expr: optional[Expr] | child
|
|
appending_expr: optional[TapExpr] | child
|
|
|
|
class LinearFunctionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class LinearFunctionExtractOriginalExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class LinearToDifferentiableFunctionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class LoadExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class MemberRefExpr(LookupExpr):
|
|
has_direct_to_storage_semantics: predicate
|
|
has_direct_to_implementation_semantics: predicate
|
|
has_ordinary_semantics: predicate
|
|
has_distributed_thunk_semantics: predicate
|
|
|
|
class MetatypeConversionExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class NilLiteralExpr(LiteralExpr):
|
|
pass
|
|
|
|
class ObjectLiteralExpr(LiteralExpr):
|
|
"""
|
|
An instance of `#fileLiteral`, `#imageLiteral` or `#colorLiteral` expressions, which are used in playgrounds.
|
|
"""
|
|
kind: int | desc("""This is 0 for `#fileLiteral`, 1 for `#imageLiteral` and 2 for `#colorLiteral`.""")
|
|
arguments: list[Argument] | child
|
|
|
|
class OptionalTryExpr(AnyTryExpr):
|
|
pass
|
|
|
|
class OverloadedDeclRefExpr(Expr, ErrorElement):
|
|
"""
|
|
An ambiguous expression that might refer to multiple declarations. This will be present only
|
|
for failing compilations.
|
|
"""
|
|
possible_declarations: list[ValueDecl]
|
|
|
|
class ParenExpr(IdentityExpr):
|
|
pass
|
|
|
|
class PointerToPointerExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class PostfixUnaryExpr(ApplyExpr):
|
|
pass
|
|
|
|
class PrefixUnaryExpr(ApplyExpr):
|
|
pass
|
|
|
|
class ProtocolMetatypeToObjectExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
@ql.default_doc_name("regular expression")
|
|
class RegexLiteralExpr(LiteralExpr):
|
|
"""A regular expression literal which is checked at compile time, for example `/a(a|b)*b/`."""
|
|
pattern: string
|
|
version: int | doc(
|
|
"version of the internal regular expression language being used by Swift")
|
|
|
|
|
|
@ql.internal
|
|
class SelfApplyExpr(ApplyExpr):
|
|
"""
|
|
An internal raw instance of method lookups like `x.foo` in `x.foo()`.
|
|
This is completely replaced by the synthesized type `MethodLookupExpr`.
|
|
"""
|
|
base: Expr
|
|
|
|
class StringToPointerExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class SubscriptExpr(LookupExpr):
|
|
arguments: list[Argument] | child
|
|
has_direct_to_storage_semantics: predicate
|
|
has_direct_to_implementation_semantics: predicate
|
|
has_ordinary_semantics: predicate
|
|
has_distributed_thunk_semantics: predicate
|
|
|
|
class TryExpr(AnyTryExpr):
|
|
pass
|
|
|
|
class UnderlyingToOpaqueExpr(ImplicitConversionExpr):
|
|
pass
|
|
|
|
class UnevaluatedInstanceExpr(ImplicitConversionExpr):
|
|
pass
|
|
class UnresolvedMemberChainResultExpr(IdentityExpr, ErrorElement):
|
|
pass
|
|
class UnresolvedTypeConversionExpr(ImplicitConversionExpr, ErrorElement):
|
|
pass
|
|
class BooleanLiteralExpr(BuiltinLiteralExpr):
|
|
value: boolean
|
|
|
|
class ConditionalCheckedCastExpr(CheckedCastExpr):
|
|
pass
|
|
|
|
class ConstructorRefCallExpr(SelfApplyExpr):
|
|
pass
|
|
|
|
class DotSyntaxCallExpr(SelfApplyExpr):
|
|
pass
|
|
|
|
@synth.from_class(SelfApplyExpr)
|
|
class MethodLookupExpr(LookupExpr):
|
|
method_ref: Expr | child | doc("the underlying method declaration reference expression")
|
|
|
|
class DynamicMemberRefExpr(DynamicLookupExpr):
|
|
pass
|
|
|
|
class DynamicSubscriptExpr(DynamicLookupExpr):
|
|
pass
|
|
|
|
class ForcedCheckedCastExpr(CheckedCastExpr):
|
|
pass
|
|
|
|
class IsExpr(CheckedCastExpr):
|
|
pass
|
|
|
|
class MagicIdentifierLiteralExpr(BuiltinLiteralExpr):
|
|
kind: string
|
|
|
|
class NumberLiteralExpr(BuiltinLiteralExpr):
|
|
pass
|
|
|
|
class StringLiteralExpr(BuiltinLiteralExpr):
|
|
value: string
|
|
|
|
class FloatLiteralExpr(NumberLiteralExpr):
|
|
string_value: string
|
|
|
|
class IntegerLiteralExpr(NumberLiteralExpr):
|
|
string_value: string
|
|
|
|
class AnyPattern(Pattern):
|
|
pass
|
|
|
|
class BindingPattern(Pattern):
|
|
sub_pattern: Pattern | child
|
|
|
|
class BoolPattern(Pattern):
|
|
value: boolean
|
|
|
|
class EnumElementPattern(Pattern):
|
|
element: EnumElementDecl
|
|
sub_pattern: optional[Pattern] | child
|
|
|
|
class ExprPattern(Pattern):
|
|
sub_expr: Expr | child
|
|
|
|
class IsPattern(Pattern):
|
|
cast_type_repr: optional["TypeRepr"] | child
|
|
sub_pattern: optional[Pattern] | child
|
|
|
|
class NamedPattern(Pattern):
|
|
name: string
|
|
|
|
class OptionalSomePattern(Pattern):
|
|
sub_pattern: Pattern | child
|
|
|
|
class ParenPattern(Pattern):
|
|
sub_pattern: Pattern | child
|
|
|
|
class TuplePattern(Pattern):
|
|
elements: list[Pattern] | child
|
|
|
|
class TypedPattern(Pattern):
|
|
sub_pattern: Pattern | child
|
|
type_repr: optional["TypeRepr"] | child
|
|
|
|
@group("stmt")
|
|
class CaseLabelItem(AstNode):
|
|
pattern: Pattern | child
|
|
guard: optional[Expr] | child
|
|
|
|
class AvailabilitySpec(AstNode):
|
|
"""
|
|
An availability spec, that is, part of an `AvailabilityInfo` condition. For example `iOS 12` and `*` in:
|
|
```
|
|
if #available(iOS 12, *)
|
|
```
|
|
"""
|
|
pass
|
|
|
|
class PlatformVersionAvailabilitySpec(AvailabilitySpec):
|
|
"""
|
|
An availability spec based on platform and version, for example `macOS 12` or `watchOS 14`
|
|
"""
|
|
platform: string
|
|
version: string
|
|
|
|
class OtherAvailabilitySpec(AvailabilitySpec):
|
|
"""
|
|
A wildcard availability spec `*`
|
|
"""
|
|
pass
|
|
|
|
class AvailabilityInfo(AstNode):
|
|
"""
|
|
An availability condition of an `if`, `while`, or `guard` statements.
|
|
|
|
Examples:
|
|
```
|
|
if #available(iOS 12, *) {
|
|
// Runs on iOS 12 and above
|
|
} else {
|
|
// Runs only anything below iOS 12
|
|
}
|
|
if #unavailable(macOS 10.14, *) {
|
|
// Runs only on macOS 10 and below
|
|
}
|
|
```
|
|
"""
|
|
is_unavailable: predicate | doc("it is #unavailable as opposed to #available")
|
|
specs: list[AvailabilitySpec] | child
|
|
|
|
@group("stmt")
|
|
class ConditionElement(AstNode):
|
|
boolean: optional[Expr] | child
|
|
pattern: optional[Pattern] | child
|
|
initializer: optional[Expr] | child
|
|
availability: optional[AvailabilityInfo] | child
|
|
|
|
@group("stmt")
|
|
class StmtCondition(AstNode):
|
|
elements: list[ConditionElement] | child
|
|
|
|
class BraceStmt(Stmt):
|
|
elements: list[AstNode] | child
|
|
|
|
class BreakStmt(Stmt):
|
|
target_name: optional[string]
|
|
target: optional[Stmt]
|
|
|
|
class CaseStmt(Stmt):
|
|
body: Stmt | child
|
|
labels: list[CaseLabelItem] | child
|
|
variables: list[VarDecl]
|
|
|
|
class ContinueStmt(Stmt):
|
|
target_name: optional[string]
|
|
target: optional[Stmt]
|
|
|
|
class DeferStmt(Stmt):
|
|
body: BraceStmt | child
|
|
|
|
class FailStmt(Stmt):
|
|
pass
|
|
|
|
class FallthroughStmt(Stmt):
|
|
fallthrough_source: CaseStmt
|
|
fallthrough_dest: CaseStmt
|
|
|
|
class LabeledStmt(Stmt):
|
|
label: optional[string]
|
|
|
|
class PoundAssertStmt(Stmt):
|
|
condition: Expr
|
|
message: string
|
|
|
|
class ReturnStmt(Stmt):
|
|
result: optional[Expr] | child
|
|
|
|
class ThrowStmt(Stmt):
|
|
sub_expr: Expr | child
|
|
|
|
class YieldStmt(Stmt):
|
|
results: list[Expr] | child
|
|
|
|
class DoCatchStmt(LabeledStmt):
|
|
body: Stmt | child
|
|
catches: list[CaseStmt] | child
|
|
|
|
class DoStmt(LabeledStmt):
|
|
body: BraceStmt | child
|
|
|
|
class ForEachStmt(LabeledStmt):
|
|
pattern: Pattern | child
|
|
sequence: Expr | child
|
|
where: optional[Expr] | child
|
|
body: BraceStmt | child
|
|
|
|
class LabeledConditionalStmt(LabeledStmt):
|
|
condition: StmtCondition | child
|
|
|
|
class RepeatWhileStmt(LabeledStmt):
|
|
condition: Expr | child
|
|
body: Stmt | child
|
|
|
|
class SwitchStmt(LabeledStmt):
|
|
expr: Expr | child
|
|
cases: list[CaseStmt] | child
|
|
|
|
class GuardStmt(LabeledConditionalStmt):
|
|
body: BraceStmt | child
|
|
|
|
class IfStmt(LabeledConditionalStmt):
|
|
then: Stmt | child
|
|
else_: optional[Stmt] | child
|
|
|
|
class WhileStmt(LabeledConditionalStmt):
|
|
body: Stmt | child
|
|
|
|
@group("type")
|
|
class TypeRepr(AstNode):
|
|
type: Type
|
|
|
|
@ql.default_doc_name("function type")
|
|
class AnyFunctionType(Type):
|
|
result: Type
|
|
param_types: list[Type]
|
|
param_labels: list[optional[string]]
|
|
is_throwing: predicate | doc("this type refers to a throwing function")
|
|
is_async: predicate | doc("this type refers to an `async` function")
|
|
|
|
class AnyGenericType(Type):
|
|
parent: optional[Type]
|
|
declaration: GenericTypeDecl
|
|
|
|
class AnyMetatypeType(Type):
|
|
pass
|
|
|
|
@qltest.collapse_hierarchy
|
|
class BuiltinType(Type):
|
|
pass
|
|
|
|
class DependentMemberType(Type):
|
|
base_type: Type
|
|
associated_type_decl: AssociatedTypeDecl
|
|
|
|
class DynamicSelfType(Type):
|
|
static_self_type: Type
|
|
class ErrorType(Type, ErrorElement):
|
|
pass
|
|
|
|
class ExistentialType(Type):
|
|
constraint: Type
|
|
|
|
class InOutType(Type):
|
|
object_type: Type
|
|
|
|
class LValueType(Type):
|
|
object_type: Type
|
|
|
|
class ModuleType(Type):
|
|
module: ModuleDecl
|
|
|
|
class ProtocolCompositionType(Type):
|
|
members: list[Type]
|
|
|
|
class ReferenceStorageType(Type):
|
|
referent_type: Type
|
|
|
|
class SubstitutableType(Type):
|
|
pass
|
|
|
|
class SugarType(Type):
|
|
pass
|
|
|
|
class TupleType(Type):
|
|
types: list[Type]
|
|
names: list[optional[string]]
|
|
class UnresolvedType(Type, ErrorElement):
|
|
pass
|
|
class AnyBuiltinIntegerType(BuiltinType):
|
|
pass
|
|
|
|
class ArchetypeType(SubstitutableType):
|
|
interface_type: Type
|
|
superclass: optional[Type]
|
|
protocols: list[ProtocolDecl]
|
|
|
|
class BuiltinBridgeObjectType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinDefaultActorStorageType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinExecutorType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinFloatType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinJobType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinNativeObjectType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinRawPointerType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinRawUnsafeContinuationType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinUnsafeValueBufferType(BuiltinType):
|
|
pass
|
|
|
|
class BuiltinVectorType(BuiltinType):
|
|
pass
|
|
|
|
class ExistentialMetatypeType(AnyMetatypeType):
|
|
pass
|
|
|
|
class FunctionType(AnyFunctionType):
|
|
pass
|
|
|
|
class GenericFunctionType(AnyFunctionType):
|
|
""" The type of a generic function with type parameters """
|
|
generic_params: list["GenericTypeParamType"] | doc("type {parameters} of this generic type")
|
|
|
|
class GenericTypeParamType(SubstitutableType):
|
|
pass
|
|
|
|
class MetatypeType(AnyMetatypeType):
|
|
pass
|
|
|
|
class NominalOrBoundGenericNominalType(AnyGenericType):
|
|
pass
|
|
|
|
class ParenType(SugarType):
|
|
type: Type
|
|
|
|
class SyntaxSugarType(SugarType):
|
|
pass
|
|
|
|
class TypeAliasType(SugarType):
|
|
decl: TypeAliasDecl
|
|
|
|
class UnboundGenericType(AnyGenericType):
|
|
pass
|
|
|
|
class UnmanagedStorageType(ReferenceStorageType):
|
|
pass
|
|
|
|
class UnownedStorageType(ReferenceStorageType):
|
|
pass
|
|
|
|
class WeakStorageType(ReferenceStorageType):
|
|
pass
|
|
|
|
class BoundGenericType(NominalOrBoundGenericNominalType):
|
|
arg_types: list[Type]
|
|
|
|
class BuiltinIntegerLiteralType(AnyBuiltinIntegerType):
|
|
pass
|
|
|
|
@qltest.uncollapse_hierarchy
|
|
class BuiltinIntegerType(AnyBuiltinIntegerType):
|
|
width: optional[int]
|
|
|
|
class DictionaryType(SyntaxSugarType):
|
|
key_type: Type
|
|
value_type: Type
|
|
|
|
class NominalType(NominalOrBoundGenericNominalType):
|
|
pass
|
|
|
|
class OpaqueTypeArchetypeType(ArchetypeType):
|
|
"""An opaque type, that is a type formally equivalent to an underlying type but abstracting it away.
|
|
|
|
See https://docs.swift.org/swift-book/LanguageGuide/OpaqueTypes.html."""
|
|
declaration: OpaqueTypeDecl
|
|
|
|
class OpenedArchetypeType(ArchetypeType):
|
|
pass
|
|
|
|
class PrimaryArchetypeType(ArchetypeType):
|
|
pass
|
|
class UnarySyntaxSugarType(SyntaxSugarType):
|
|
base_type: Type
|
|
|
|
class ArraySliceType(UnarySyntaxSugarType):
|
|
pass
|
|
|
|
class BoundGenericClassType(BoundGenericType):
|
|
pass
|
|
|
|
class BoundGenericEnumType(BoundGenericType):
|
|
pass
|
|
|
|
class BoundGenericStructType(BoundGenericType):
|
|
pass
|
|
|
|
class ClassType(NominalType):
|
|
pass
|
|
|
|
class EnumType(NominalType):
|
|
pass
|
|
|
|
class OptionalType(UnarySyntaxSugarType):
|
|
pass
|
|
|
|
class ProtocolType(NominalType):
|
|
pass
|
|
|
|
class StructType(NominalType):
|
|
pass
|
|
|
|
class VariadicSequenceType(UnarySyntaxSugarType):
|
|
pass
|
|
|
|
class ParameterizedProtocolType(Type):
|
|
"""
|
|
A sugar type of the form `P<X>` with `P` a protocol.
|
|
|
|
If `P` has primary associated type `A`, then `T: P<X>` is a shortcut for `T: P where T.A == X`.
|
|
"""
|
|
base: ProtocolType
|
|
args: list[Type]
|
|
|
|
class AbiSafeConversionExpr(ImplicitConversionExpr):
|
|
pass
|