Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
Unisay committed Dec 12, 2024
1 parent d3942d7 commit 1599c6d
Show file tree
Hide file tree
Showing 9 changed files with 109 additions and 12 deletions.
8 changes: 4 additions & 4 deletions flake.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 3 additions & 1 deletion plutus-tx-plugin/plutus-tx-plugin.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,7 @@ test-suite plutus-tx-plugin-tests
hs-source-dirs: test
main-is: Spec.hs
other-modules:
Array.Spec
AsData.Budget.Spec
AsData.Budget.Types
AssocMap.Spec
Expand Down Expand Up @@ -166,7 +167,7 @@ test-suite plutus-tx-plugin-tests
Unicode.Spec

build-depends:
, base >=4.9 && <5
, base >=4.9 && <5
, base16-bytestring
, bytestring
, containers
Expand All @@ -190,6 +191,7 @@ test-suite plutus-tx-plugin-tests
, template-haskell
, text
, these
, vector ^>=0.13.2

default-extensions: Strict
ghc-options: -threaded -rtsopts -with-rtsopts=-N
Expand Down
15 changes: 12 additions & 3 deletions plutus-tx-plugin/src/PlutusTx/Compiler/Builtins.hs
Original file line number Diff line number Diff line change
Expand Up @@ -239,6 +239,11 @@ builtinNames = [
, 'Builtins.mkNilPairData
, 'Builtins.mkCons

, ''Builtins.BuiltinArray
, 'Builtins.lengthOfArray
, 'Builtins.listToArray
, 'Builtins.indexArray

, ''Builtins.BuiltinData
, 'Builtins.chooseData
, 'Builtins.caseData'
Expand Down Expand Up @@ -460,6 +465,11 @@ defineBuiltinTerms = do
PLC.MkNilPairData -> defineBuiltinInl 'Builtins.mkNilPairData
PLC.MkCons -> defineBuiltinInl 'Builtins.mkCons

-- Arrays
PLC.LengthArray -> defineBuiltinInl 'Builtins.lengthOfArray
PLC.ListToArray -> defineBuiltinInl 'Builtins.listToArray
PLC.IndexArray -> defineBuiltinInl 'Builtins.indexArray

-- Data
PLC.ChooseData -> defineBuiltinInl 'Builtins.chooseData
PLC.EqualsData -> defineBuiltinInl 'Builtins.equalsData
Expand Down Expand Up @@ -597,9 +607,7 @@ defineBuiltinTerms = do

PLC.ExpModInteger -> defineBuiltinInl 'Builtins.expModInteger

defineBuiltinTypes
:: CompilingDefault uni fun m ann
=> m ()
defineBuiltinTypes :: CompilingDefault uni fun m ann => m ()
defineBuiltinTypes = do
defineBuiltinType ''Builtins.BuiltinByteString . ($> annMayInline) $ PLC.toTypeAst $ Proxy @BS.ByteString
defineBuiltinType ''Integer . ($> annMayInline) $ PLC.toTypeAst $ Proxy @Integer
Expand All @@ -609,6 +617,7 @@ defineBuiltinTypes = do
defineBuiltinType ''Builtins.BuiltinData . ($> annMayInline) $ PLC.toTypeAst $ Proxy @PLC.Data
defineBuiltinType ''Builtins.BuiltinPair . ($> annMayInline) $ PLC.TyBuiltin () (PLC.SomeTypeIn PLC.DefaultUniProtoPair)
defineBuiltinType ''Builtins.BuiltinList . ($> annMayInline) $ PLC.TyBuiltin () (PLC.SomeTypeIn PLC.DefaultUniProtoList)
defineBuiltinType ''Builtins.BuiltinArray . ($> annMayInline) $ PLC.TyBuiltin () (PLC.SomeTypeIn PLC.DefaultUniProtoArray)
defineBuiltinType ''Builtins.BuiltinBLS12_381_G1_Element . ($> annMayInline) $ PLC.toTypeAst $ Proxy @BLS12_381.G1.Element
defineBuiltinType ''Builtins.BuiltinBLS12_381_G2_Element . ($> annMayInline) $ PLC.toTypeAst $ Proxy @BLS12_381.G2.Element
defineBuiltinType ''Builtins.BuiltinBLS12_381_MlResult . ($> annMayInline) $ PLC.toTypeAst $ Proxy @BLS12_381.Pairing.MlResult
Expand Down
39 changes: 39 additions & 0 deletions plutus-tx-plugin/test/Array/Spec.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
{-# LANGUAGE BlockArguments #-}
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TypeApplications #-}
{-# OPTIONS_GHC -fplugin PlutusTx.Plugin #-}

module Array.Spec where

import Data.Vector.Strict qualified as Vector
import PlutusCore (someValue)
import PlutusTx (CompiledCode, getPlcNoAnn)
import PlutusTx.Builtins (toOpaque)
import PlutusTx.Builtins.Internal (BuiltinInteger, BuiltinList, listToArray)
import PlutusTx.TH (compile)
import Test.Tasty (TestTree, testGroup)
import Test.Tasty.HUnit (testCase, (@?=))
import UntypedPlutusCore (DefaultFun, DefaultUni, NamedDeBruijn, Program (_progTerm),
Term (Constant))

smokeTests :: TestTree
smokeTests =
testGroup "Array" [testListToArray]

testListToArray :: TestTree
testListToArray = testCase "Array" do
term compiledArray @?= Constant () (someValue (Vector.fromList [1 :: Integer, 2, 3]))
where
compiledArray =
$$( compile
[||
let xs :: BuiltinList BuiltinInteger
xs = toOpaque [1 :: Integer, 2, 3]
in listToArray xs
||]
)

term :: CompiledCode a -> Term NamedDeBruijn DefaultUni DefaultFun ()
term = _progTerm . getPlcNoAnn
2 changes: 2 additions & 0 deletions plutus-tx-plugin/test/Spec.hs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
module Main (main) where

import Array.Spec qualified as Array
import AsData.Budget.Spec qualified as AsData.Budget
import AssocMap.Spec qualified as AssocMap
import Blueprint.Tests qualified
Expand Down Expand Up @@ -49,4 +50,5 @@ tests =
, embed Unicode.tests
, embed AssocMap.propertyTests
, embed List.propertyTests
, embed Array.smokeTests
]
5 changes: 5 additions & 0 deletions plutus-tx/src/PlutusTx/Builtins.hs
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,11 @@ module PlutusTx.Builtins (
, BI.tail
, uncons
, unsafeUncons
-- * Arrays
, BI.BuiltinArray
, BI.listToArray
, BI.lengthOfArray
, BI.indexArray
-- * Tracing
, trace
-- * BLS12_381
Expand Down
11 changes: 7 additions & 4 deletions plutus-tx/src/PlutusTx/Builtins/HasBuiltin.hs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import PlutusTx.Builtins.Internal
import Data.ByteString (ByteString)
import Data.Kind qualified as GHC
import Data.Text (Text)
import Data.Vector.Strict (Vector)
import Data.Vector.Strict qualified as Strict

{- Note [useToOpaque and useFromOpaque]
It used to be possible to use 'toBuiltin'/'fromBuiltin' within a smart contract, but this is no
Expand Down Expand Up @@ -92,9 +92,12 @@ instance HasFromBuiltin a => HasFromBuiltin (BuiltinList a) where
type FromBuiltin (BuiltinList a) = [FromBuiltin a]
fromBuiltin (BuiltinList xs) = map fromBuiltin xs

instance HasToBuiltin a => HasToBuiltin (Vector a) where
type ToBuiltin (Vector a) = BuiltinArray (ToBuiltin a)
toBuiltin = useToOpaque (BuiltinArray . map toBuiltin)
instance HasToBuiltin a => HasToBuiltin (Strict.Vector a) where
type ToBuiltin (Strict.Vector a) = BuiltinArray (ToBuiltin a)
toBuiltin = useToOpaque (BuiltinArray . fmap toBuiltin)
instance HasFromBuiltin a => HasFromBuiltin (BuiltinArray a) where
type FromBuiltin (BuiltinArray a) = Strict.Vector (FromBuiltin a)
fromBuiltin (BuiltinArray xs) = fmap fromBuiltin xs

instance (HasToBuiltin a, HasToBuiltin b) => HasToBuiltin (a, b) where
type ToBuiltin (a, b) = BuiltinPair (ToBuiltin a) (ToBuiltin b)
Expand Down
26 changes: 26 additions & 0 deletions plutus-tx/src/PlutusTx/Builtins/Internal.hs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@ import Data.Hashable (Hashable (..))
import Data.Kind (Type)
import Data.Text as Text (Text, empty)
import Data.Text.Encoding as Text (decodeUtf8, encodeUtf8)
import Data.Vector.Strict (Vector)
import Data.Vector.Strict qualified as Vector
import GHC.Generics (Generic)
import PlutusCore.Bitwise qualified as Bitwise
import PlutusCore.Builtin (BuiltinResult (..))
Expand Down Expand Up @@ -551,6 +553,30 @@ serialiseData :: BuiltinData -> BuiltinByteString
serialiseData (BuiltinData b) = BuiltinByteString $ BSL.toStrict $ serialise b
{-# OPAQUE serialiseData #-}

{-
ARRAY
-}

data BuiltinArray a = BuiltinArray ~(Vector a) deriving stock (Data)

instance Haskell.Show a => Haskell.Show (BuiltinArray a) where
show (BuiltinArray v) = show v
instance Haskell.Eq a => Haskell.Eq (BuiltinArray a) where
(==) (BuiltinArray v) (BuiltinArray v') = (==) v v'
instance Haskell.Ord a => Haskell.Ord (BuiltinArray a) where
compare (BuiltinArray v) (BuiltinArray v') = compare v v'

lengthOfArray :: BuiltinArray a -> BuiltinInteger
lengthOfArray (BuiltinArray v) = toInteger (Vector.length v)
{-# OPAQUE lengthOfArray #-}

listToArray :: BuiltinList a -> BuiltinArray a
listToArray (BuiltinList l) = BuiltinArray (Vector.fromList l)
{-# OPAQUE listToArray #-}

indexArray :: BuiltinArray a -> BuiltinInteger -> a
indexArray (BuiltinArray v) i = v Vector.! fromInteger i
{-# OPAQUE indexArray #-}

{-
BLS12_381
Expand Down
11 changes: 11 additions & 0 deletions plutus-tx/src/PlutusTx/Lift/Class.hs
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import Data.ByteString qualified as BS
import Data.Kind qualified as GHC
import Data.Proxy
import Data.Text qualified as T
import Data.Vector.Strict qualified as Strict
import GHC.TypeLits (ErrorMessage (..), TypeError)

-- We do not use qualified import because the whole module contains off-chain code
Expand Down Expand Up @@ -180,6 +181,16 @@ instance (HasFromBuiltin arep, uni `PLC.HasTermLevel` [FromBuiltin arep]) =>
Lift uni (BuiltinList arep) where
lift = liftBuiltin . fromBuiltin

-- See Note [Lift and Typeable instances for builtins]
instance uni `PLC.HasTypeLevel` Strict.Vector => Typeable uni BuiltinArray where
typeRep _ = typeRepBuiltin (Proxy @Strict.Vector)

-- See Note [Lift and Typeable instances for builtins]
instance ( HasFromBuiltin arep
, uni `PLC.HasTermLevel` Strict.Vector (FromBuiltin arep)
) => Lift uni (BuiltinArray arep) where
lift = liftBuiltin . fromBuiltin

instance uni `PLC.HasTypeLevel` (,) => Typeable uni BuiltinPair where
typeRep _ = typeRepBuiltin (Proxy @(,))

Expand Down

0 comments on commit 1599c6d

Please sign in to comment.