joe 发表于 2021-8-24 08:53:00

rocketchip高级参数化机制--语法实验(3)

abstract class view中有一个抽象方法 protected def find(pname:Field,site:View):Option
其中,protected的config表示这个方法只能在本object config中使用,并且是protected,也就是说只能是
抽象类View的实现类中实现find方法.
在外部,做一个子类,继承自config中这个View,并实现find方法实验:
class SubView extends View {
override protected def find(pname: Field, site: View): Option = pname.default
}
然后使用的时候:val subView = new SubView
结果编译的时候出现:Error:(13, 26) overriding method find in class View of type (pname: chipsalliance.rocketchip.config.Field, site: chipsalliance.rocketchip.config.View)Option;
method find has weaker access privileges; it should be at least protected
override protected def find(pname: Field, site: View): Option = pname.default

如果:
import chipsalliance.rocketchip._   //主要是想下面def find中的config使用
import chipsalliance.rocketchip.config.{Field,View}
class SubView extends View {
override protected def find(pname: Field, site: View): Option = pname.default
}
...其它代码,用到了Field和View...
编译时出现:
Error:(14, 34) config is not an enclosing class
override protected def find(pname: Field, site: View): Option = pname.default、

从上面二个实验可知,在object config中的View类不可能在外面直接使用。


joe 发表于 2021-8-24 08:55:40

import chipsalliance.rocketchip.config.{Field,View,TerminalView}
val view = new TerminalView() //语法错误,因为TerminaView在object config中是private class内部类,外部不可见
页: [1]
查看完整版本: rocketchip高级参数化机制--语法实验(3)