More consistent treatment of Failure

This commit is contained in:
Edsko de Vries 2023-03-23 17:50:04 +01:00
parent c28efafcb6
commit 97504b714c
2 changed files with 6 additions and 29 deletions

View file

@ -16,6 +16,8 @@ module Foreign.Rust.External.JSON (
) where
import Codec.Borsh
import Foreign.Rust.Failure
import GHC.Stack
import qualified Data.Aeson as Aeson
import qualified Data.Aeson.Encoding as Aeson (unsafeToEncoding)
@ -32,13 +34,13 @@ newtype JSON = JSON Lazy.ByteString
deriving stock (Eq)
deriving newtype (BorshSize, ToBorsh, FromBorsh)
-- | Types with an external JSON renderer (typically, in Rust)
-- | Types with a Rust-side JSON renderer
class ToJSON a where
toJSON :: a -> JSON
-- | Types with an external JSON parser (typically, in Rust)
-- | Types with a Rust-side JSON parser
class FromJSON a where
fromJSON :: JSON -> Either String a
fromJSON :: HasCallStack => JSON -> Either Failure a
{-------------------------------------------------------------------------------
Deriving-via: derive Aeson instances using external (de)serialiser
@ -67,6 +69,6 @@ instance ToJSON a => Aeson.ToJSON (UseExternalJSON a) where
instance FromJSON a => Aeson.FromJSON (UseExternalJSON a) where
parseJSON val =
case fromJSON (JSON (Aeson.encode val)) of
Left failure -> Aeson.parseFail failure
Left failure -> Aeson.parseFail (show failure)
Right tx -> return $ UseExternalJSON tx

View file

@ -11,26 +11,20 @@ module Foreign.Rust.Marshall.Variable (
, Buffer -- opaque
, getVarBuffer
, withBorshVarBuffer
, withBorshFailure
, withBorshBufferOfInitSize
-- ** Pure variants
, withPureBorshVarBuffer
, withPureBorshFailure
) where
import Codec.Borsh
import Data.Bifunctor
import Data.Text (Text)
import Data.Typeable
import Foreign
import Foreign.C.Types
import GHC.Stack
import System.IO.Unsafe (unsafePerformIO)
import qualified Data.ByteString as Strict
import Foreign.Rust.Marshall.Util
import Foreign.Rust.Failure
{-------------------------------------------------------------------------------
Haskell to Rust
@ -72,16 +66,6 @@ withBorshVarBuffer :: forall a.
=> (Buffer a -> IO ()) -> IO a
withBorshVarBuffer = withBorshBufferOfInitSize 1024
-- | Wrapper around 'withBorshVarBuffer' with explicit support for failures
withBorshFailure :: forall a.
( FromBorsh a
, StaticBorshSize a ~ 'HasVariableSize
, Typeable a
, HasCallStack
)
=> (Buffer (Either Text a) -> IO ()) -> IO (Either Failure a)
withBorshFailure = fmap (first mkFailure) . withBorshVarBuffer
{-------------------------------------------------------------------------------
Pure variants
-------------------------------------------------------------------------------}
@ -94,15 +78,6 @@ withPureBorshVarBuffer :: forall a.
=> (Buffer a -> IO ()) -> a
withPureBorshVarBuffer = unsafePerformIO . withBorshVarBuffer
withPureBorshFailure :: forall a.
( FromBorsh a
, StaticBorshSize a ~ 'HasVariableSize
, Typeable a
, HasCallStack
)
=> (Buffer (Either Text a) -> IO ()) -> Either Failure a
withPureBorshFailure = unsafePerformIO . withBorshFailure
{-------------------------------------------------------------------------------
Generalization
-------------------------------------------------------------------------------}