summaryrefslogtreecommitdiff
path: root/src/main/scala/chisel3/internal/firrtl/Emitter.scala
blob: ca8562e8e4947b77e9919ac5227b4ef19e0b8a10 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// SPDX-License-Identifier: Apache-2.0

package chisel3.internal.firrtl

import scala.collection.immutable.LazyList // Needed for 2.12 alias
import firrtl.ir.Serializer

private[chisel3] object Emitter {
  def emit(circuit: Circuit): String = {
    val fcircuit = Converter.convertLazily(circuit)
    Serializer.serialize(fcircuit)
  }

  def emitLazily(circuit: Circuit): Iterable[String] = new Iterable[String] {
    def iterator = {
      val prelude = Iterator(s"circuit ${circuit.name} :\n")
      val modules = circuit.components.iterator.map(Converter.convert)
      val moduleStrings = modules.flatMap { m =>
        Serializer.lazily(m, 1) ++ Seq("\n\n")
      }
      prelude ++ moduleStrings
    }
  }
}