aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/logger/phases/AddDefaults.scala
diff options
context:
space:
mode:
authorJack Koenig2019-04-26 13:10:44 -0700
committerGitHub2019-04-26 13:10:44 -0700
commita7cf6ff3416a11088d811a435ba71fd36b191fb4 (patch)
tree79e2e8c5753903ca6d14e9b952c26a07442bd980 /src/main/scala/logger/phases/AddDefaults.scala
parent99ae1d6649f1731c5dec2098b10733735232b72c (diff)
parentef8f06f23b9ee6cf86de2450752dfd0fcd32da80 (diff)
Merge pull request #1005 from freechipsproject/f764.7
Stage/Phase
Diffstat (limited to 'src/main/scala/logger/phases/AddDefaults.scala')
-rw-r--r--src/main/scala/logger/phases/AddDefaults.scala27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/main/scala/logger/phases/AddDefaults.scala b/src/main/scala/logger/phases/AddDefaults.scala
new file mode 100644
index 00000000..f6daa811
--- /dev/null
+++ b/src/main/scala/logger/phases/AddDefaults.scala
@@ -0,0 +1,27 @@
+// See LICENSE for license details.
+
+package logger.phases
+
+import firrtl.AnnotationSeq
+import firrtl.options.Phase
+
+import logger.{LoggerOption, LogLevelAnnotation}
+
+/** Add default logger [[Annotation]]s */
+private [logger] object AddDefaults extends Phase {
+
+ /** Add missing default [[Logger]] [[Annotation]]s to an [[AnnotationSeq]]
+ * @param annotations input annotations
+ * @return output annotations with defaults
+ */
+ def transform(annotations: AnnotationSeq): AnnotationSeq = {
+ var ll = true
+ annotations.collect{ case a: LoggerOption => a }.map{
+ case _: LogLevelAnnotation => ll = false
+ case _ =>
+ }
+ annotations ++
+ (if (ll) Seq(LogLevelAnnotation()) else Seq() )
+ }
+
+}