role Metamodel::ParametricRoleHOW
class Metamodel::ParametricRoleHOW
does Metamodel::Naming
does Metamodel::Documenting
does Metamodel::Versioning
does Metamodel::MethodContainer
does Metamodel::PrivateMethodContainer
does Metamodel::MultiMethodContainer
does Metamodel::AttributeContainer
does Metamodel::RoleContainer
does Metamodel::MultipleInheritance
does Metamodel::Stashing
does Metamodel::TypePretense
does Metamodel::RolePunning
does Metamodel::ArrayType {}
Warning: this class is part of the Rakudo implementation, and is not a part of the language specification.
A Metamodel::ParametricRoleHOW
represents a non-instantiated, possibly
parameterized, role:
(role Zape[::T] {}).HOW.say;# OUTPUT: «Perl6::Metamodel::ParametricRoleHOW.new»
(role Zape {}).HOW.say; # OUTPUT: «Perl6::Metamodel::ParametricRoleHOW.new»
As usual, .new_type
will create a new object of this class.
my \zipi := Metamodel::ParametricRoleHOW.new_type( name => "zape", group => "Zape");
say zipi.HOW; # OUTPUT: «Perl6::Metamodel::ParametricRoleHOW.new»
The extra group
argument will need to be used to integrate it in a parametric
role group, which will need to be defined in advance.
Note: As most of the Metamodel
classes, this one is here mainly for
illustration purposes and it's not intended for the final user to instantiate,
unless their intention is really to create a parametric role group.