A type bound in a trait or generic parameter.
For example:
fn foo<T: Debug>(t: T) {}
// ^^^^^
fn bar(value: impl for<'a> From<&'a str>) {}
// ^^^^^^^^^^^^^^^^^^^^^
INTERNAL: Do not reference the Generated::TypeBound class directly.
Use the subclass TypeBound, where the following predicates are available.
Import path
import codeql.rust.elements.internal.generated.TypeBoundDirect supertypes
Known direct subtypes
Predicates
| getAPrimaryQlClass | Gets the name of a primary CodeQL class to which this element belongs. |
| getForBinder | Gets the for binder of this type bound, if it exists. |
| getLifetime | Gets the lifetime of this type bound, if it exists. |
| getTypeRepr | Gets the type representation of this type bound, if it exists. |
| getUseBoundGenericArgs | Gets the use bound generic arguments of this type bound, if it exists. |
| hasForBinder | Holds if |
| hasLifetime | Holds if |
| hasTypeRepr | Holds if |
| hasUseBoundGenericArgs | Holds if |
| isAsync | Holds if this type bound is async. |
| isConst | Holds if this type bound is const. |
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 |
| 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 |
| 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 |