aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/logger/package.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/package.scala
parent99ae1d6649f1731c5dec2098b10733735232b72c (diff)
parentef8f06f23b9ee6cf86de2450752dfd0fcd32da80 (diff)
Merge pull request #1005 from freechipsproject/f764.7
Stage/Phase
Diffstat (limited to 'src/main/scala/logger/package.scala')
-rw-r--r--src/main/scala/logger/package.scala21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/main/scala/logger/package.scala b/src/main/scala/logger/package.scala
new file mode 100644
index 00000000..52a3331a
--- /dev/null
+++ b/src/main/scala/logger/package.scala
@@ -0,0 +1,21 @@
+// See LICENSE for license details.
+
+import firrtl.AnnotationSeq
+import firrtl.options.OptionsView
+
+package object logger {
+
+ implicit object LoggerOptionsView extends OptionsView[LoggerOptions] {
+ def view(options: AnnotationSeq): LoggerOptions = options
+ .foldLeft(new LoggerOptions()) { (c, x) =>
+ x match {
+ case LogLevelAnnotation(logLevel) => c.copy(globalLogLevel = logLevel)
+ case ClassLogLevelAnnotation(name, level) => c.copy(classLogLevels = c.classLogLevels + (name -> level))
+ case LogFileAnnotation(f) => c.copy(logFileName = f)
+ case LogClassNamesAnnotation => c.copy(logClassNames = true)
+ case _ => c
+ }
+ }
+ }
+
+}