Skip to content

Commit

Permalink
fix(aqua-api): Add default constants to Aqua API [LNG-194] (#738)
Browse files Browse the repository at this point in the history
  • Loading branch information
DieMyst authored Jun 9, 2023
1 parent 62b1642 commit 5f5fc49
Show file tree
Hide file tree
Showing 5 changed files with 10 additions and 28 deletions.
2 changes: 1 addition & 1 deletion api/aqua-api/src/main/scala/aqua/api/APICompilation.scala
Original file line number Diff line number Diff line change
Expand Up @@ -139,8 +139,8 @@ object APICompilation {

LogFormatter.initLogger(Some(level))

val config = AquaCompilerConf(constants)
val transformConfig = aquaConfig.getTransformConfig
val config = AquaCompilerConf(constants ++ transformConfig.constantsList)

CompilerAPI
.compile[IO, AquaFileError, FileModuleId, FileSpan.F](
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,4 +7,4 @@ import aqua.raw.ConstantRaw
*
* @param constantsList List of known constants
*/
case class AquaCompilerConf(constantsList: List[ConstantRaw] = ConstantRaw.defaultConstants(None))
case class AquaCompilerConf(constantsList: List[ConstantRaw])
28 changes: 4 additions & 24 deletions compiler/src/test/scala/aqua/compiler/AquaCompilerSpec.scala
Original file line number Diff line number Diff line change
@@ -1,36 +1,16 @@
package aqua.compiler

import aqua.model.{
CallModel,
ForModel,
FunctorModel,
IntoIndexModel,
LiteralModel,
ValueModel,
VarModel
}
import aqua.model.{CallModel, ForModel, FunctorModel, IntoIndexModel, LiteralModel, ValueModel, VarModel}
import aqua.model.transform.TransformConfig
import aqua.model.transform.Transform
import aqua.parser.ParserError
import aqua.parser.Ast
import aqua.parser.Parser
import aqua.parser.lift.Span
import aqua.parser.lift.Span.S
import aqua.raw.ConstantRaw
import aqua.raw.value.{LiteralRaw, ValueRaw, VarRaw}
import aqua.res.{
ApRes,
CallRes,
CallServiceRes,
CanonRes,
FoldRes,
MakeRes,
MatchMismatchRes,
NextRes,
ParRes,
RestrictionRes,
SeqRes,
XorRes
}
import aqua.res.{ApRes, CallRes, CallServiceRes, CanonRes, FoldRes, MakeRes, MatchMismatchRes, NextRes, ParRes, RestrictionRes, SeqRes, XorRes}
import aqua.types.{ArrayType, CanonStreamType, LiteralType, ScalarType, StreamType, Type}
import org.scalatest.flatspec.AnyFlatSpec
import org.scalatest.matchers.should.Matchers
Expand Down Expand Up @@ -64,7 +44,7 @@ class AquaCompilerSpec extends AnyFlatSpec with Matchers {
.compileToContext[Id, String, String, Span.S](
aquaSource(src, imports),
id => txt => Parser.parse(Parser.parserSchema)(txt),
AquaCompilerConf()
AquaCompilerConf(ConstantRaw.defaultConstants(None))
)

"aqua compiler" should "compile a simple snipped to the right context" in {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import aqua.parser.lexer.{LiteralToken, Token}
import aqua.parser.lift.FileSpan.F
import aqua.parser.lift.{FileSpan, Span}
import aqua.parser.{ArrowReturnError, BlockIndentError, LexerError, ParserError}
import aqua.raw.ConstantRaw
import aqua.semantics.{HeaderError, RulesViolated, WrongAST}
import aqua.{AquaIO, SpanParser}
import cats.data.Validated.{Invalid, Valid, invalidNec, validNec}
Expand Down Expand Up @@ -137,7 +138,7 @@ object AquaLSP extends App with Logging {
val path = Path(pathStr)
val pathId = FileModuleId(path)
val sources = new AquaFileSources[IO](path, imports.toList.map(Path.apply))
val config = AquaCompilerConf()
val config = AquaCompilerConf(ConstantRaw.defaultConstants(None))

val proc = for {

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import aqua.files.{AquaFileSources, AquaFilesIO, FileModuleId}
import aqua.io.AquaFileError
import aqua.lsp.LSPCompiler
import aqua.parser.lift.FileSpan
import aqua.raw.ConstantRaw
import aqua.{AquaIO, SpanParser}
import cats.data.Validated
import cats.effect.{IO, IOApp, Sync}
Expand All @@ -18,7 +19,7 @@ object Test extends IOApp.Simple {
override def run: IO[Unit] = {

val sources = new AquaFileSources[IO](Path("./aqua-src/antithesis.aqua"), List(Path("./aqua")))
val config = AquaCompilerConf()
val config = AquaCompilerConf(ConstantRaw.defaultConstants(None))

for {
start <- IO(System.currentTimeMillis())
Expand Down

0 comments on commit 5f5fc49

Please sign in to comment.