-
Notifications
You must be signed in to change notification settings - Fork 26
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Strange behavior of &&
operator (maybe also exists with other logic operation)
#37
Comments
Given a method that accepts a call-by-name parameter, it means the method decides when and how many times the parameter evaluates.
Instead, the only thing {
val monad$macro$1: scalaz.Traverse[Option] with scalaz.MonadPlus[Option] with scalaz.Each[Option] with scalaz.Index[Option] with scalaz.Length[Option] with scalaz.Cozip[Option] with scalaz.Zip[Option] with scalaz.Unzip[Option] with scalaz.Align[Option] with scalaz.IsEmpty[Option] with scalaz.Cobind[Option] with scalaz.Optional[Option]{def point[A](a: => A): Some[A]; def cojoin[A](a: Option[A]): Option[Some[A]]} = scalaz.std.option.optionInstance;
monad$macro$1.bind(com.thoughtworks.each.Monadic.EachOps[Some, Int](scala.Some.apply[Int](1)).underlying)(((element$macro$2: Int) => {
val i: Boolean = element$macro$2.<(0);
monad$macro$1.map({
scala.this.Predef.println("foo");
monad$macro$1.map(com.thoughtworks.each.Monadic.EachOps[Some, Int](scala.Some.apply[Int](2)).underlying)(((element$macro$3: Int) => element$macro$3.>(0)))
})(((element$macro$4: Boolean) => i.&&(element$macro$4)))
}))
} In brief, there is no way to pass a monadic expression to a method that accept call-by-name parameters and still keep the same behavior as the behavior when passing a direct expression. No way, even if you manually create the monadic expression without using Each library. |
In order to achieve the correspond behavior with a monadic expression, you must replace call-by-name parameter // Monadic version of Boolean.&&
def monadicBooleanAnd[M[_] : Monad](leftHandSide: Boolean, rightHandSide: () => M[Boolean]): M[Boolean] = {
if (leftHandSide) {
rightHandSide()
} else {
Monad[M].point(false)
}
}
monadic[Option] { val i = Some(1).each < 0; monadicBooleanAnd(i, { () => monadic[Option] { println("foo"); Some(2).each > 0 } }).each } |
We should point this out in the val decreased = account.decrease(xxx).each
val recordAdded = decreased && transfer.addRecord(xxx).each |
Could you create a Pull Request to the |
How do you think if we translate |
That seems reasonable. And it will be better if we can raise an warning for other |
I think it's better to disable The following code should not compile any more
|
@Atry Can't agree anymore |
👍 |
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Code
Output
The text was updated successfully, but these errors were encountered: