It seems the in operator compiles to the wrong order of its parameters in pattern matching. I have code like this
a={'Test'}
addpattern def f({'t': t `(. in a)`}):
print t
or alternatively
a={'Test'}
addpattern def f({'t': t `(in)` a}):
print t
In both cases I'd expect the call f({'t': 'Test'}) to pass the pattern matching and reach the print statement. Instead, TypeError: 'in <string>' requires string as left operand, not set is raised.
It seems that the (. in a) gets compiled with the arguments switched around to:
>>> import coconut.convenience as c
>>> "`(. in a)`" |> c.parse$(mode="block") |> print
(_coconut_partial(_coconut.operator.contains, {1: a}, 2, ())))()
>>> ((\_coconut_partial(\_coconut.operator.contains, {1: a}, 2, ())))
<built-in function contains>$(?, {'Test'})
In the last line you can see the problem: the contains function takes the container as the first arguments, and the test subject as the second, so it needs its parameters switched compared to other operator functions.
Interestingly. the not in variant doesn't suffer this problem as the _coconut_not_in function it gets compiled to takes the container as its second argument.
Coconut: Version 3.0.0-a_dev19 running on Python 3.11.2 and Cython cPyparsing v2.4.7.1.2.0
It seems the
in
operator compiles to the wrong order of its parameters in pattern matching. I have code like thisor alternatively
In both cases I'd expect the call
f({'t': 'Test'})
to pass the pattern matching and reach the print statement. Instead,TypeError: 'in <string>' requires string as left operand, not set
is raised.It seems that the
(. in a)
gets compiled with the arguments switched around to:In the last line you can see the problem: the
contains
function takes the container as the first arguments, and the test subject as the second, so it needs its parameters switched compared to other operator functions. Interestingly. thenot in
variant doesn't suffer this problem as the_coconut_not_in
function it gets compiled to takes the container as its second argument.Coconut: Version 3.0.0-a_dev19 running on Python 3.11.2 and Cython cPyparsing v2.4.7.1.2.0