summaryrefslogtreecommitdiff
path: root/core/src/main/scala/chisel3/Printable.scala
diff options
context:
space:
mode:
authormergify[bot]2022-09-29 18:53:44 +0000
committerGitHub2022-09-29 18:53:44 +0000
commit5a79814631bdc8c71c5a7b4722cd43712f7ff445 (patch)
tree6a42aceb9b6002bcbeb3070c7bb98d1b17db91b4 /core/src/main/scala/chisel3/Printable.scala
parent9f1eae19445e110bb743176767f59970ce1d36b5 (diff)
Add lexical scope checks to Assert, Assume and Printf (#2706) (#2753)
(cherry picked from commit f462c9f9307bebf3012da52432c3729cd752321c) Co-authored-by: Aditya Naik <91489422+adkian-sifive@users.noreply.github.com>
Diffstat (limited to 'core/src/main/scala/chisel3/Printable.scala')
-rw-r--r--core/src/main/scala/chisel3/Printable.scala13
1 files changed, 13 insertions, 0 deletions
diff --git a/core/src/main/scala/chisel3/Printable.scala b/core/src/main/scala/chisel3/Printable.scala
index 78655517..82054ee1 100644
--- a/core/src/main/scala/chisel3/Printable.scala
+++ b/core/src/main/scala/chisel3/Printable.scala
@@ -134,6 +134,19 @@ object Printable {
val bufEscapeBackSlash = buf.map(_.replace("\\", "\\\\"))
StringContext(bufEscapeBackSlash.toSeq: _*).cf(data: _*)
}
+
+ private[chisel3] def checkScope(message: Printable): Unit = {
+ def getData(x: Printable): Seq[Data] = {
+ x match {
+ case y: FirrtlFormat => Seq(y.bits)
+ case Name(d) => Seq(d)
+ case FullName(d) => Seq(d)
+ case Printables(p) => p.flatMap(getData(_)).toSeq
+ case _ => Seq() // Handles subtypes PString and Percent
+ }
+ }
+ getData(message).foreach(_.requireVisible())
+ }
}
case class Printables(pables: Iterable[Printable]) extends Printable {