A dynamic interface definition.
A dynamic interface definition has the following components:
annotations
,dynamic
keyword,,name
,body
.Examples (multi-line):
shared dynamic Document { shared formal String xmlVersion; shared formal StyleSheetList styleSheets; shared formal String documentURI; // ... } shared dynamic Promise { shared formal Promise \ithen(void onFulfilled(dynamic result) => noop(), void onRejected(dynamic error) => noop()); shared formal Promise catch(void onRejected(dynamic error) => noop()); }
Anything
no subtypes hierarchy
Initializer |
DynamicInterfaceDefinition(UIdentifier name, InterfaceBody body, CaseTypes? caseTypes = null, SatisfiedTypes? satisfiedTypes = null, TypeParameters? typeParameters = null, TypeConstraint[] typeConstraints = [], Annotations annotations = ...) Parameters:
|
Attributes | |
annotations | shared actual Annotations annotations The annotations of the interface. Refines Declaration.annotations |
body | shared actual InterfaceBody body The body of the interface. Refines AnyInterfaceDefinition.body |
caseTypes | shared actual CaseTypes? caseTypes The case types of the interface, if present. Refines ClassOrInterface.caseTypes |
children | shared actual <Annotations|UIdentifier|TypeParameters|CaseTypes|SatisfiedTypes|TypeConstraint|InterfaceBody>[] children The child nodes of this node. Refines Node.children |
hash | shared actual Integer hash The hash value of the value, which allows the value to be an element of a hash-based set or key of a hash-based map. Implementations must respect the constraint that:
Therefore, a class which refines In general, Note that when executing on a Java Virtual Machine, the
64-bit Refines Object.hash |
name | shared actual UIdentifier name The name of the interface. |
satisfiedTypes | shared actual SatisfiedTypes? satisfiedTypes The satisfied types of the interface, if present. Refines ClassOrInterface.satisfiedTypes |
typeConstraints | shared actual TypeConstraint[] typeConstraints The type constraints of the interface, if any. Refines TypeDeclaration.typeConstraints |
typeParameters | shared actual TypeParameters? typeParameters The type parameters of the interface, if present. Refines TypeDeclaration.typeParameters |
Inherited Attributes |
Attributes inherited from: AnyInterfaceDefinition |
Attributes inherited from: ClassOrInterface |
Attributes inherited from: Declaration |
Attributes inherited from: Node |
Attributes inherited from: Object hash , string |
Attributes inherited from: TypeDeclaration |
Methods | |
copy | shared DynamicInterfaceDefinition copy(UIdentifier name = ..., InterfaceBody body = ..., CaseTypes? caseTypes = ..., SatisfiedTypes? satisfiedTypes = ..., TypeParameters? typeParameters = ..., TypeConstraint[] typeConstraints = ..., Annotations annotations = ...) Parameters:
|
equals | shared actual Boolean equals(Object that) Determine if two values are equal. Implementations should respect the constraints that:
Furthermore it is recommended that implementations
ensure that if A class which explicitly refines Note that an implementation of Refines Object.equals |
transform | shared actual Result transform<out Result>(Transformer<Result> transformer) Transform this node with the given If you have a Refines Node.transform |
visit | shared actual void visit(Visitor visitor) Visit this node with the given Refines Node.visit |
Inherited Methods |
Methods inherited from: Node |
Methods inherited from: Object equals |