summaryrefslogtreecommitdiff
path: root/src/main
diff options
context:
space:
mode:
authorSchuyler Eldridge2019-01-14 12:20:44 -0500
committerSchuyler Eldridge2019-05-22 16:17:17 -0400
commit0e6eb5b35a442edf70ad37f963526609f2ba1f3c (patch)
tree2b24df6fd9e71a1f735d9dc1073b6bee6b1c04d2 /src/main
parent20ba486ab1988e57e2b2ca163c9c83e1d8904bba (diff)
Add chisel.stage.phases.AddImplicitOutputFile
Signed-off-by: Schuyler Eldridge <schuyler.eldridge@ibm.com>
Diffstat (limited to 'src/main')
-rw-r--r--src/main/scala/chisel3/stage/phases/AddImplicitOutputFile.scala25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/main/scala/chisel3/stage/phases/AddImplicitOutputFile.scala b/src/main/scala/chisel3/stage/phases/AddImplicitOutputFile.scala
new file mode 100644
index 00000000..4a4dac72
--- /dev/null
+++ b/src/main/scala/chisel3/stage/phases/AddImplicitOutputFile.scala
@@ -0,0 +1,25 @@
+// See LICENSE for license details.
+
+package chisel3.stage.phases
+
+import firrtl.AnnotationSeq
+import firrtl.options.Phase
+
+import chisel3.stage.{ChiselCircuitAnnotation, ChiselOutputFileAnnotation}
+
+/** Add a output file for a Chisel circuit, derived from the top module in the circuit, if no
+ * [[ChiselOutputFileAnnotation]] already exists.
+ */
+class AddImplicitOutputFile extends Phase {
+
+ def transform(annotations: AnnotationSeq): AnnotationSeq =
+ annotations.collectFirst{ case _: ChiselOutputFileAnnotation => annotations }.getOrElse{
+
+ val x: Option[AnnotationSeq] = annotations
+ .collectFirst{ case a: ChiselCircuitAnnotation =>
+ ChiselOutputFileAnnotation(a.circuit.name) +: annotations }
+
+ x.getOrElse(annotations)
+ }
+
+}