Skip to content

Commit

Permalink
refactor
Browse files Browse the repository at this point in the history
  • Loading branch information
janmasrovira committed Nov 20, 2024
1 parent 2e14594 commit 99af0ac
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 20 deletions.
6 changes: 3 additions & 3 deletions src/Juvix/Compiler/Builtins/Eq.hs
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,14 @@ checkEqDef :: forall r. (Members '[Reader BuiltinsTable, Error ScoperError] r) =
checkEqDef d = do
let err :: forall a. Text -> Sem r a
err = builtinsErrorText (getLoc d)
unless (isSmallUniverse' (d ^. inductiveType)) (err "Lists should be in the small universe")
let eqTxt = prettyText BuiltinEq
unless (isSmallUniverse' (d ^. inductiveType)) (err (eqTxt <> " should be in the small universe"))
case d ^. inductiveParameters of
[_] -> return ()
_ -> err (eqTxt <> "should have exactly one type parameter")
_ -> err (eqTxt <> " should have exactly one type parameter")
case d ^. inductiveConstructors of
[c1] -> checkMkEq c1
_ -> err (eqTxt <> "should have exactly two constructors")
_ -> err (eqTxt <> " should have exactly two constructors")

checkMkEq :: ConstructorDef -> Sem r ()
checkMkEq _ = return ()
Expand Down
48 changes: 31 additions & 17 deletions src/Juvix/Compiler/Internal/Translation/FromConcrete.hs
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,13 @@ newtype DefaultArgsStack = DefaultArgsStack

makeLenses ''DefaultArgsStack

data DerivingArgs = DerivingArgs
{ _derivingPragmas :: Maybe ParsedPragmas,
_derivingInstanceName :: Internal.FunctionName,
_derivingParameters :: [Internal.FunctionParameter],
_derivingReturnType :: (Internal.InductiveName, [Internal.ApplicationArg])
}

fromConcrete ::
(Members '[Reader EntryPoint, Error JuvixError, Reader Store.ModuleTable, NameIdGen, Termination] r) =>
Scoper.ScoperResult ->
Expand Down Expand Up @@ -414,7 +421,15 @@ goDeriving Deriving {..} = do
(funArgs, ret) <- Internal.unfoldFunType <$> goDefType _derivingFunLhs
let (mtrait, traitArgs) = Internal.unfoldExpressionApp ret
(n, der) <- findDerivingTrait mtrait
deriveTrait der _derivingPragmas ret name funArgs (n, traitArgs)
let deriveArgs =
DerivingArgs
{ _derivingInstanceName = name,
_derivingReturnType = (n, traitArgs),
_derivingParameters = funArgs,
_derivingPragmas
}
-- deriveTrait der _derivingPragmas ret name funArgs (n, traitArgs)
deriveTrait der deriveArgs

deriveTrait ::
( Members
Expand All @@ -429,11 +444,7 @@ deriveTrait ::
r
) =>
Internal.DerivingTrait ->
Maybe ParsedPragmas ->
Internal.Expression ->
Internal.Name ->
[Internal.FunctionParameter] ->
(Internal.InductiveName, [Internal.ApplicationArg]) ->
DerivingArgs ->
Sem r Internal.FunctionDef
deriveTrait = \case
Internal.DerivingEq -> deriveEq
Expand Down Expand Up @@ -539,33 +550,36 @@ deriveEq ::
]
r
) =>
Maybe ParsedPragmas ->
Internal.Expression ->
Internal.FunctionName ->
[Internal.FunctionParameter] ->
(Internal.InductiveName, [Internal.ApplicationArg]) ->
DerivingArgs ->
Sem r Internal.FunctionDef
deriveEq pragmas ret instanceName funParams (eqName, args) = do
deriveEq DerivingArgs {..} = do
arg <- getArg
argsInfo <- goArgsInfo instanceName
argsInfo <- goArgsInfo _derivingInstanceName
lam <- eqLambda arg
mkEq <- getBuiltin (getLoc eqName) BuiltinMkEq
let body = mkEq Internal.@@ lam
ty = Internal.foldFunType funParams (Internal.foldApplication (Internal.toExpression eqName) args)
pragmas' <- goPragmas pragmas
ty = Internal.foldFunType _derivingParameters ret
pragmas' <- goPragmas _derivingPragmas
return
Internal.FunctionDef
{ _funDefTerminating = False,
_funDefIsInstanceCoercion = Just Internal.IsInstanceCoercionInstance,
_funDefPragmas = pragmas',
_funDefArgsInfo = argsInfo,
_funDefDocComment = Nothing,
_funDefName = instanceName,
_funDefName = _derivingInstanceName,
_funDefType = ty,
_funDefBody = body,
_funDefBuiltin = Nothing
}
where
ret :: Internal.Expression
ret = Internal.foldApplication (Internal.toExpression eqName) args

eqName :: Internal.InductiveName
args :: [Internal.ApplicationArg]
(eqName, args) = _derivingReturnType

getArg :: Sem r Internal.InductiveInfo
getArg = runFailDefaultM (throwDerivingWrongForm ret) $ do
[Internal.ApplicationArg Explicit a] <- return args
Expand Down Expand Up @@ -614,7 +628,7 @@ deriveEq pragmas ret instanceName funParams (eqName, args) = do
Sem r Internal.LambdaClause
lambdaClause band btrue bisEqual c = do
numArgs :: [IsImplicit] <- getNumArgs
let loc = getLoc instanceName
let loc = getLoc _derivingInstanceName
mkpat :: Sem r ([Internal.VarName], Internal.PatternArg)
mkpat = runOutputList . runStreamOf allWords $ do
xs :: [(IsImplicit, Internal.VarName)] <- forM numArgs $ \impl -> do
Expand Down

0 comments on commit 99af0ac

Please sign in to comment.