-
Notifications
You must be signed in to change notification settings - Fork 32
Expand file tree
/
Copy pathSupport.scala
More file actions
83 lines (74 loc) · 3.16 KB
/
Copy pathSupport.scala
File metadata and controls
83 lines (74 loc) · 3.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/** This file contains support code for making a majority of Scala shareable between different versions of Scala and
* Daffodil. The main difference comes in package names, converting certain variables, etc. This file has all the
* helper code for that for Scala 3.
*/
package org.apache.daffodil.debugger.dap
import java.io._
import java.nio.file.Path
import org.apache.daffodil.api._
import scala.jdk.CollectionConverters._
import cats.effect.IO
import cats.syntax.all._
import org.apache.daffodil.api.exceptions.ExternalVariableException
object Support {
/* Daffodil DataProcessor wrapper methods */
def dataProcessorWithDebugger(
p: DataProcessor,
debugger: Debugger,
variables: Map[String, String]
): IO[DataProcessor] = {
val base = p.withDebugger(debugger)
variables.toList
.foldLeftM(base) { case (dp, (k, v)) =>
IO(dp.withExternalVariables(Map(k -> v).asJava)).handleErrorWith {
case e: ExternalVariableException =>
IO.println(s"[WARNING] Skipping unknown external variable '$k': ${e.getMessage}") *>
IO.pure(dp)
case e => IO.raiseError(e)
}
}
.map(_.withValidation("daffodil"))
}
/* Daffodil ProcessorFactory wrapper methods */
def getProcessorFactory(
schema: Path,
rootName: Option[String],
rootNamespace: Option[String],
tunables: Map[String, String]
): ProcessorFactory =
Daffodil
.compiler()
.withTunables(tunables.asJava)
.compileFile(schema.toFile(), rootName.orNull, rootNamespace.orNull)
/* Method to convert java list of diagnostics to a sequence of diagnostics */
/* Method to convert java list of diagnostics to a sequence of diagnostics */
def parseDiagnosticList(
dl: java.util.List[org.apache.daffodil.api.Diagnostic]
): Seq[org.apache.daffodil.api.Diagnostic] =
dl.asScala.toSeq
/* Daffodil infoset wrapper methods */
def getInputSourceDataInputStream(data: InputStream): InputSourceDataInputStream =
Daffodil.newInputSourceDataInputStream(data)
def getInfosetOutputter(infosetFormat: String, stream: OutputStream): InfosetOutputter =
infosetFormat match {
case "xml" => Daffodil.newXMLTextInfosetOutputter(stream, true)
case "json" => Daffodil.newJsonInfosetOutputter(stream, true)
case other => throw new IllegalArgumentException(s"unsupported infosetFormat: $other")
}
}