An item such as a function, struct, enum, etc.
For example:
fn foo() {}
struct S;
enum E {}
INTERNAL: Do not reference the Generated::Item class directly.
Use the subclass Item, where the following predicates are available.
Import path
import codeql.rust.elements.internal.generated.ItemDirect supertypes
Indirect supertypes
Known direct subtypes
Predicates
| getAttributeMacroExpansion | Gets the attribute macro expansion of this item, if it exists. |
| hasAttributeMacroExpansion | Holds if |
Inherited predicates
| fromSource | Holds if this element is from source code. | from Locatable |
| getACfgNode | Gets a control flow node for this AST node, if any. | from AstNode |
| getAPrimaryQlClass | Gets the name of a primary CodeQL class to which this element belongs. | from Element |
| getCanonicalPath | Gets the canonical path of this item, if any. | from Addressable |
| getCanonicalPath | Gets the canonical path of this item, if any. | from Addressable |
| getEnclosingBlock | Gets the block that encloses this node, if any. | from AstNode |
| getEnclosingCallable | Gets the immediately enclosing callable of this node, if any. | from AstNode |
| getEnclosingCfgScope | Gets the CFG scope that encloses this node, if any. | from AstNode |
| getFile | Gets the primary file where this element occurs. | from Locatable |
| getLocation | from Locatable | |
| getParentNode | Gets the nearest enclosing parent of this node, which is also an | from AstNode |
| getPrimaryQlClasses | Gets a comma-separated list of the names of the primary CodeQL classes to which this element belongs. | from Element |
| getResolveStep | Gets the most immediate element that should substitute this element in the explicit AST, if any. Classes can override this to indicate this node should be in the “hidden” AST, mostly reserved for conversions and syntactic sugar nodes like parentheses. | from Element |
| hasCanonicalPath | Holds if this item has a canonical path. | from Addressable |
| hasEnclosingCfgScope | Holds if this node is inside a CFG scope. | from AstNode |
| isFromMacroExpansion | Holds if this node exists only as the result of a macro expansion. | from AstNode |
| isInMacroExpansion | Holds if this node is inside a macro expansion. | from AstNode |
| isUnknown | from Element | |
| resolve | Gets the element that should substitute this element in the explicit AST, applying | from Element |
| toAbbreviatedString | INTERNAL: Do not use. | from Element |
| toString | Gets the string representation of this element. | from Element |
| toStringImpl | INTERNAL: Do not use. | from Element |