{-# LANGUAGE UndecidableInstances #-}

module ZkFold.Base.Protocol.Plonkup.Witness where

import           Control.Applicative                     ((<*>))
import           Data.Functor                            ((<$>))
import           Data.Functor.Classes                    (Show1)
import           Data.List                               ((++))
import           Test.QuickCheck                         (Arbitrary (..), Arbitrary1, arbitrary1)
import           Text.Show                               (Show, show)

import           ZkFold.Base.Algebra.EllipticCurve.Class (EllipticCurve (..))

data PlonkupWitnessInput p i c = PlonkupWitnessInput
  { forall (p :: Type -> Type) (i :: Type -> Type) c.
PlonkupWitnessInput p i c -> p (ScalarField c)
payloadInput :: p (ScalarField c)
  , forall (p :: Type -> Type) (i :: Type -> Type) c.
PlonkupWitnessInput p i c -> i (ScalarField c)
witnessInput :: i (ScalarField c)
  }

instance (Show1 p, Show1 i, Show (ScalarField c))
  => Show (PlonkupWitnessInput p i c) where
    show :: PlonkupWitnessInput p i c -> String
show (PlonkupWitnessInput p (ScalarField c)
p i (ScalarField c)
v) = String
"Plonkup Witness Input: " String -> ShowS
forall a. [a] -> [a] -> [a]
++ p (ScalarField c) -> String
forall a. Show a => a -> String
show p (ScalarField c)
p String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
", " String -> ShowS
forall a. [a] -> [a] -> [a]
++ i (ScalarField c) -> String
forall a. Show a => a -> String
show i (ScalarField c)
v

instance (Arbitrary1 p, Arbitrary1 i, Arbitrary (ScalarField c))
  => Arbitrary (PlonkupWitnessInput p i c) where
    arbitrary :: Gen (PlonkupWitnessInput p i c)
arbitrary = p (ScalarField c) -> i (ScalarField c) -> PlonkupWitnessInput p i c
forall (p :: Type -> Type) (i :: Type -> Type) c.
p (ScalarField c) -> i (ScalarField c) -> PlonkupWitnessInput p i c
PlonkupWitnessInput (p (ScalarField c)
 -> i (ScalarField c) -> PlonkupWitnessInput p i c)
-> Gen (p (ScalarField c))
-> Gen (i (ScalarField c) -> PlonkupWitnessInput p i c)
forall (f :: Type -> Type) a b. Functor f => (a -> b) -> f a -> f b
<$> Gen (p (ScalarField c))
forall (f :: Type -> Type) a.
(Arbitrary1 f, Arbitrary a) =>
Gen (f a)
arbitrary1 Gen (i (ScalarField c) -> PlonkupWitnessInput p i c)
-> Gen (i (ScalarField c)) -> Gen (PlonkupWitnessInput p i c)
forall a b. Gen (a -> b) -> Gen a -> Gen b
forall (f :: Type -> Type) a b.
Applicative f =>
f (a -> b) -> f a -> f b
<*> Gen (i (ScalarField c))
forall (f :: Type -> Type) a.
(Arbitrary1 f, Arbitrary a) =>
Gen (f a)
arbitrary1