from misc.codegen.lib.schemadefs import * include("../shared/tree-sitter-extractor/src/generator/prefix.dbscheme") include("prefix.dbscheme") File = imported("File", "codeql.files.FileSystem") @qltest.skip class Element: pass @qltest.skip class Locatable(Element): pass @qltest.skip class AstNode(Locatable): pass @qltest.skip class Token(AstNode): """ The base class for all tokens. """ pass class Comment(Token): """ A comment. For example: ```rust // this is a comment /// This is a doc comment ``` """ parent: AstNode text: string @qltest.skip class Unextracted(Element): """ The base class marking everything that was not properly extracted for some reason, such as: * syntax errors * insufficient context information * yet unimplemented parts of the extractor """ pass @qltest.skip class Missing(Unextracted): """ The base class marking errors during parsing or resolution. """ @qltest.skip class Unimplemented(Unextracted): """ The base class for unimplemented nodes. This is used to mark nodes that are not yet extracted. """ pass class Callable(AstNode): """ A callable. Either a `Function` or a `ClosureExpr`. """ param_list: optional["ParamList"] | child attrs: list["Attr"] | child params: list["Param"] | synth body: optional["Expr"] | synth class Addressable(AstNode): """ Something that can be addressed by a path. TODO: This does not yet include all possible cases. """ class PathAstNode(AstNode): """ An AST element wrapping a path (`PathExpr`, `RecordExpr`, `PathPat`, `RecordPat`, `TupleStructPat`). """ path: optional["Path"] | child @qltest.skip @ql.internal class ExtractorStep(Element): action: string file: optional[File] duration_ms: int class Crate(Locatable): name: optional[string] version: optional[string] cfg_options: list[string] named_dependencies: list["NamedCrate"] | ql.internal @qltest.skip @ql.internal class NamedCrate(Element): name: string crate: "Crate"