aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/firrtl/options/Phase.scala
diff options
context:
space:
mode:
authorSchuyler Eldridge2018-11-22 23:40:38 -0500
committerGitHub2018-11-22 23:40:38 -0500
commit27afc3d8defd9e2a85d5e3d2f9d2b35310b9b775 (patch)
tree8435ab570e88b60ca6af127e607794c64565bb9c /src/main/scala/firrtl/options/Phase.scala
parent4a2211c1602b37a65b4e44c3b7ebe82e8bfeedc0 (diff)
parent696bc256a90cc80bcb094aaeada8eea51a643ae0 (diff)
Merge pull request #945 from seldridge/add-phase
- Change firrtl.options API, add Phase
Diffstat (limited to 'src/main/scala/firrtl/options/Phase.scala')
-rw-r--r--src/main/scala/firrtl/options/Phase.scala20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/main/scala/firrtl/options/Phase.scala b/src/main/scala/firrtl/options/Phase.scala
new file mode 100644
index 00000000..22715bc2
--- /dev/null
+++ b/src/main/scala/firrtl/options/Phase.scala
@@ -0,0 +1,20 @@
+// See LICENSE for license details.
+
+package firrtl.options
+
+import firrtl.AnnotationSeq
+
+/** A transformation of an [[AnnotationSeq]]
+ *
+ * A [[Phase]] forms one block in the Chisel/FIRRTL Hardware Compiler Framework (HCF). Note that a [[Phase]] may
+ * consist of multiple phases internally.
+ */
+abstract class Phase {
+
+ /** A transformation of an [[AnnotationSeq]]
+ * @param annotations some annotations
+ * @return transformed annotations
+ */
+ def transform(annotations: AnnotationSeq): AnnotationSeq
+
+}