12345678910111213141516171819202122232425262728293031(* Copyright (C) 2025 Petter A. Urkedal <paurkedal@gmail.com>
*
* This library is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at your
* option) any later version, with the LGPL-3.0 Linking Exception.
*
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* and the LGPL-3.0 Linking Exception along with this library. If not, see
* <http://www.gnu.org/licenses/> and <https://spdx.org>, respectively.
*)moduleMonad_syntax(Monad:System_sig.FIBER)=structopenMonad.Infixlet(let*)=(>>=)let(let+)=(>|=)let(>>=?)mf=m>>=functionOkx->fx|Error_asr->Monad.returnrlet(>|=?)mf=m>|=functionOkx->Ok(fx)|Error_asr->rlet(let*?)=(>>=?)let(let+?)=(>|=?)end