class ComplexStr is Allomorph is Complex {}
ComplexStr
is a dual value type, a subclass of both Allomorph
, hence Str
, and Complex
.
See Allomorph
for further details.
my $complex-str = <42+0i>; say $complex-str.^name; # OUTPUT: «ComplexStr» my Complex $complex = $complex-str; # OK! my Str $str = $complex-str; # OK! # ∈ operator cares about object identity say 42+0i ∈ <42+0i 55 1>; # OUTPUT: «False»
Methods§
method new§
method new(Complex $i, Str $s)
The constructor requires both the Complex
and the Str
value, when constructing one directly the values can be whatever is required:
my $f = ComplexStr.new(42+0i, "forty two (but complicated)"); say +$f; # OUTPUT: «42+0i» say ~$f; # OUTPUT: «"forty two (but complicated)"»
method Capture§
method Capture(ComplexStr:D: --> Capture:D)
Equivalent to Mu.Capture
.
method Complex§
method Complex
Returns the Complex
value of the ComplexStr
.
method Numeric§
multi method Numeric(ComplexStr:D: --> Complex:D) multi method Numeric(ComplexStr:U: --> Complex:D)
The :D
variant returns the numeric portion of the invocant. The :U
variant issues a warning about using an uninitialized value in numeric context and then returns value <0+0i>
.
method Real§
multi method Real(ComplexStr:D: --> Num:D) multi method Real(ComplexStr:U: --> Num:D)
Coerces the numeric portion of the invocant to Num
. If the imaginary part isn't approximately zero, coercion fails with X::Numeric::Real
.
The :D
variant returns the result of that coercion. The :U
variant issues a warning about using an uninitialized value in numeric context and then returns value 0e0
.
Operators§
infix ===
§
multi infix:<===>(ComplexStr:D $a, ComplexStr:D $b)
ComplexStr
Value identity operator. Returns True
if the Complex
values of $a
and $b
are identical and their Str
values are also identical. Returns False
otherwise.