aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/logger/LoggerOptions.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/LoggerOptions.scala
parent99ae1d6649f1731c5dec2098b10733735232b72c (diff)
parentef8f06f23b9ee6cf86de2450752dfd0fcd32da80 (diff)
Merge pull request #1005 from freechipsproject/f764.7
Stage/Phase
Diffstat (limited to 'src/main/scala/logger/LoggerOptions.scala')
-rw-r--r--src/main/scala/logger/LoggerOptions.scala38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/main/scala/logger/LoggerOptions.scala b/src/main/scala/logger/LoggerOptions.scala
new file mode 100644
index 00000000..299382f0
--- /dev/null
+++ b/src/main/scala/logger/LoggerOptions.scala
@@ -0,0 +1,38 @@
+// See LICENSE for license details.
+
+package logger
+
+/** Internal options used to control the logging in programs that are part of the Chisel stack
+ *
+ * @param globalLogLevel the verbosity of logging (default: [[logger.LogLevel.None]])
+ * @param classLogLevels the individual verbosity of logging for specific classes
+ * @param logToFile if true, log to a file
+ * @param logClassNames indicates logging verbosity on a class-by-class basis
+ */
+class LoggerOptions private [logger] (
+ val globalLogLevel: LogLevel.Value = LogLevelAnnotation().globalLogLevel,
+ val classLogLevels: Map[String, LogLevel.Value] = Map.empty,
+ val logClassNames: Boolean = false,
+ val logFileName: Option[String] = None) {
+
+ private [logger] def copy(
+ globalLogLevel: LogLevel.Value = globalLogLevel,
+ classLogLevels: Map[String, LogLevel.Value] = classLogLevels,
+ logClassNames: Boolean = logClassNames,
+ logFileName: Option[String] = logFileName): LoggerOptions = {
+
+ new LoggerOptions(
+ globalLogLevel = globalLogLevel,
+ classLogLevels = classLogLevels,
+ logClassNames = logClassNames,
+ logFileName = logFileName)
+
+ }
+
+ /** Return the name of the log file, defaults to `a.log` if unspecified */
+ def getLogFileName(): Option[String] = if (!logToFile) None else logFileName.orElse(Some("a.log"))
+
+ /** True if a [[Logger]] should be writing to a file */
+ @deprecated("logToFile was removed, use logFileName.nonEmpty", "1.2")
+ def logToFile(): Boolean = logFileName.nonEmpty
+}