亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? config.py

?? linux下基于c++的處理器仿真平臺。具有處理器流水線
?? PY
?? 第 1 頁 / 共 5 頁
字號:
def isSimObjSequence(value):    if not isinstance(value, (list, tuple)):        return False    for val in value:        if not isNullPointer(val) and not isSimObject(val):            return False    return Truedef isNullPointer(value):    return isinstance(value, NullSimObject)# The metaclass for ConfigNode (and thus for everything that derives# from ConfigNode, including SimObject).  This class controls how new# classes that derive from ConfigNode are instantiated, and provides# inherited class behavior (just like a class controls how instances# of that class are instantiated, and provides inherited instance# behavior).class MetaSimObject(type):    # Attributes that can be set only at initialization time    init_keywords = { 'abstract' : types.BooleanType,                      'type' : types.StringType }    # Attributes that can be set any time    keywords = { 'check' : types.FunctionType,                 'children' : types.ListType }        # __new__ is called before __init__, and is where the statements    # in the body of the class definition get loaded into the class's    # __dict__.  We intercept this to filter out parameter assignments    # and only allow "private" attributes to be passed to the base    # __new__ (starting with underscore).    def __new__(mcls, name, bases, dict):        # Copy "private" attributes (including special methods such as __new__)        # to the official dict.  Everything else goes in _init_dict to be        # filtered in __init__.        cls_dict = {}        for key,val in dict.items():            if key.startswith('_'):                cls_dict[key] = val                del dict[key]        cls_dict['_init_dict'] = dict        return super(MetaSimObject, mcls).__new__(mcls, name, bases, cls_dict)            # initialization    def __init__(cls, name, bases, dict):        super(MetaSimObject, cls).__init__(name, bases, dict)        # initialize required attributes        cls._params = multidict()        cls._values = multidict()        cls._anon_subclass_counter = 0        # We don't support multiple inheritance.  If you want to, you        # must fix multidict to deal with it properly.        if len(bases) > 1:            raise TypeError, "SimObjects do not support multiple inheritance"        base = bases[0]        if isinstance(base, MetaSimObject):            cls._params.parent = base._params            cls._values.parent = base._values            # If your parent has a value in it that's a config node, clone            # it.  Do this now so if we update any of the values'            # attributes we are updating the clone and not the original.            for key,val in base._values.iteritems():                # don't clone if (1) we're about to overwrite it with                # a local setting or (2) we've already cloned a copy                # from an earlier (more derived) base                if cls._init_dict.has_key(key) or cls._values.has_key(key):                    continue                if isSimObject(val):                    cls._values[key] = val()                elif isSimObjSequence(val) and len(val):                    cls._values[key] = [ v() for v in val ]        # now process remaining _init_dict items        for key,val in cls._init_dict.items():            if isinstance(val, (types.FunctionType, types.TypeType)):                type.__setattr__(cls, key, val)            # param descriptions            elif isinstance(val, ParamDesc):                cls._new_param(key, val)            # init-time-only keywords            elif cls.init_keywords.has_key(key):                cls._set_keyword(key, val, cls.init_keywords[key])            # default: use normal path (ends up in __setattr__)            else:                setattr(cls, key, val)    def _set_keyword(cls, keyword, val, kwtype):        if not isinstance(val, kwtype):            raise TypeError, 'keyword %s has bad type %s (expecting %s)' % \\                  (keyword, type(val), kwtype)        if isinstance(val, types.FunctionType):            val = classmethod(val)        type.__setattr__(cls, keyword, val)    def _new_param(cls, name, value):        cls._params[name] = value        if hasattr(value, 'default'):            setattr(cls, name, value.default)    # Set attribute (called on foo.attr = value when foo is an    # instance of class cls).    def __setattr__(cls, attr, value):        # normal processing for private attributes        if attr.startswith('_'):            type.__setattr__(cls, attr, value)            return        if cls.keywords.has_key(attr):            cls._set_keyword(attr, value, cls.keywords[attr])            return        # must be SimObject param        param = cls._params.get(attr, None)        if param:            # It's ok: set attribute by delegating to 'object' class.            try:                cls._values[attr] = param.convert(value)            except Exception, e:                msg = "%s\\nError setting param %s.%s to %s\\n" % \\                      (e, cls.__name__, attr, value)                e.args = (msg, )                raise        # I would love to get rid of this        elif isSimObject(value) or isSimObjSequence(value):           cls._values[attr] = value        else:            raise AttributeError, \\                  "Class %s has no parameter %s" % (cls.__name__, attr)    def __getattr__(cls, attr):        if cls._values.has_key(attr):            return cls._values[attr]        raise AttributeError, \\              "object '%s' has no attribute '%s'" % (cls.__name__, attr)# The ConfigNode class is the root of the special hierarchy.  Most of# the code in this class deals with the configuration hierarchy itself# (parent/child node relationships).class SimObject(object):    # Specify metaclass.  Any class inheriting from SimObject will    # get this metaclass.    __metaclass__ = MetaSimObject    def __init__(self, _value_parent = None, **kwargs):        self._children = {}        if _value_parent and type(_value_parent) != type(self):            # this was called as a type conversion rather than a clone            raise TypeError, "Cannot convert %s to %s" % \\                  (_value_parent.__class__.__name__, self.__class__.__name__)        if not _value_parent:            _value_parent = self.__class__        # clone values        self._values = multidict(_value_parent._values)        for key,val in _value_parent._values.iteritems():            if isSimObject(val):                setattr(self, key, val())            elif isSimObjSequence(val) and len(val):                setattr(self, key, [ v() for v in val ])        # apply attribute assignments from keyword args, if any        for key,val in kwargs.iteritems():            setattr(self, key, val)    def __call__(self, **kwargs):        return self.__class__(_value_parent = self, **kwargs)    def __getattr__(self, attr):        if self._values.has_key(attr):            return self._values[attr]        raise AttributeError, "object '%s' has no attribute '%s'" \\              % (self.__class__.__name__, attr)    # Set attribute (called on foo.attr = value when foo is an    # instance of class cls).    def __setattr__(self, attr, value):        # normal processing for private attributes        if attr.startswith('_'):            object.__setattr__(self, attr, value)            return        # must be SimObject param        param = self._params.get(attr, None)        if param:            # It's ok: set attribute by delegating to 'object' class.            try:                value = param.convert(value)            except Exception, e:                msg = "%s\\nError setting param %s.%s to %s\\n" % \\                      (e, self.__class__.__name__, attr, value)                e.args = (msg, )                raise        # I would love to get rid of this        elif isSimObject(value) or isSimObjSequence(value):            pass        else:            raise AttributeError, "Class %s has no parameter %s" \\                  % (self.__class__.__name__, attr)        # clear out old child with this name, if any        self.clear_child(attr)        if isSimObject(value):            value.set_path(self, attr)        elif isSimObjSequence(value):            value = SimObjVector(value)            [v.set_path(self, "%s%d" % (attr, i)) for i,v in enumerate(value)]        self._values[attr] = value    # this hack allows tacking a '[0]' onto parameters that may or may    # not be vectors, and always getting the first element (e.g. cpus)    def __getitem__(self, key):        if key == 0:            return self        raise TypeError, "Non-zero index '%s' to SimObject" % key    # clear out children with given name, even if it's a vector    def clear_child(self, name):        if not self._children.has_key(name):            return        child = self._children[name]        if isinstance(child, SimObjVector):            for i in xrange(len(child)):                del self._children["s%d" % (name, i)]        del self._children[name]    def add_child(self, name, value):        self._children[name] = value    def set_path(self, parent, name):        if not hasattr(self, '_parent'):            self._parent = parent            self._name = name            parent.add_child(name, self)    def path(self):        if not hasattr(self, '_parent'):            return 'root'        ppath = self._parent.path()        if ppath == 'root':            return self._name        return ppath + "." + self._name    def __str__(self):        return self.path()    def ini_str(self):        return self.path()    def find_any(self, ptype):        if isinstance(self, ptype):            return self, True        found_obj = None        for child in self._children.itervalues():            if isinstance(child, ptype):                if found_obj != None and child != found_obj:                    raise AttributeError, \\                          'parent.any matched more than one: %s %s' % \\                          (found_obj.path, child.path)                found_obj = child        # search param space        for pname,pdesc in self._params.iteritems():            if issubclass(pdesc.ptype, ptype):                match_obj = self._values[pname]                if found_obj != None and found_obj != match_obj:                    raise AttributeError, \\                          'parent.any matched more than one: %s' % obj.path                found_obj = match_obj        return found_obj, found_obj != None    def unproxy(self, base):        return self    def print_ini(self):        print '[' + self.path() + ']'	# .ini section header        if hasattr(self, 'type') and not isinstance(self, ParamContext):            print 'type=%s' % self.type        child_names = self._children.keys()        child_names.sort()        np_child_names = [c for c in child_names \\                          if not isinstance(self._children[c], ParamContext)]        if len(np_child_names):            print 'children=%s' % ' '.join(np_child_names)        param_names = self._params.keys()        param_names.sort()        for param in param_names:            value = self._values.get(param, None)            if value != None:                if isproxy(value):                    try:                        value = value.unproxy(self)                    except:                        print >> sys.stderr, \\                              "Error in unproxying param '%s' of %s" % \\                              (param, self.path())                        raise                    setattr(self, param, value)                print '%s=%s' % (param, self._values[param].ini_str())        print	# blank line between objects        for child in child_names:            self._children[child].print_ini()    # generate output file for 'dot' to display as a pretty graph.    # this code is currently broken.    def outputDot(self, dot):        label = "{%s|" % self.path        if isSimObject(self.realtype):            label +=  '%s|' % self.type        if self.children:            # instantiate children in same order they were added for            # backward compatibility (else we can end up with cpu1            # before cpu0).            for c in self.children:                dot.add_edge(pydot.Edge(self.path,c.path, style="bold"))                  simobjs = []         for param in self.params:            try:                if param.value is None:                    raise AttributeError, 'Parameter with no value'                value = param.value                string = param.string(value)            except Exception, e:                msg = 'exception in %s:%s\\n%s' % (self.name, param.name, e)                e.args = (msg, )                raise            if isSimObject(param.ptype) and string != "Null":                simobjs.append(string)            else:                label += '%s = %s\\\\n' % (param.name, string)                        for so in simobjs:            label += "|<%s> %s" % (so, so)            dot.add_edge(pydot.Edge("%s:%s" % (self.path, so), so,                                    tailport="w"))        label += '}'        dot.add_node(pydot.Node(self.path,shape="Mrecord",label=label))                # recursively dump out children        for c in self.children:            c.outputDot(dot)class ParamContext(SimObject):    pass####################################################################### Proxy object support.######################################################################class BaseProxy(object):    def __init__(self, search_self, search_up):        self._search_self = search_self        self._search_up = search_up        self._multiplier = None    def __setattr__(self, attr, value):        if not attr.startswith('_'):            raise AttributeError, 'cannot set attribute on proxy object'        super(BaseProxy, self).__setattr__(attr, value)    # support multiplying proxies by constants    def __mul__(self, other):

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
26uuu另类欧美| 久久99久久久欧美国产| 亚洲欧美日韩国产一区二区三区| 久久久精品免费免费| 国产视频一区在线播放| 国产三级一区二区三区| 国产日韩成人精品| 国产精品不卡一区| 亚洲欧美日韩国产中文在线| 亚洲美女免费在线| 亚洲国产欧美日韩另类综合| 亚洲一区成人在线| 日韩精品国产精品| 精品制服美女久久| 国产成人免费视频网站高清观看视频| 国产一区二区三区电影在线观看| 国产精品一区三区| 成人av在线播放网站| 91麻豆免费视频| 欧美性大战久久久久久久蜜臀| 欧美专区亚洲专区| 日韩精品一区二区三区视频| 26uuu欧美| 亚洲欧洲av在线| 亚洲成人av电影在线| 九色porny丨国产精品| 国产69精品久久久久毛片| 91网站黄www| 欧美日韩精品专区| 精品人在线二区三区| 国产欧美精品区一区二区三区 | 国产精品少妇自拍| 亚洲欧美成aⅴ人在线观看| 午夜久久久久久久久久一区二区| 美女mm1313爽爽久久久蜜臀| 国产一二三精品| 91片黄在线观看| 欧美久久婷婷综合色| 久久免费午夜影院| 亚洲欧美激情在线| 蜜臀久久99精品久久久画质超高清| 韩国v欧美v亚洲v日本v| 欧美色图在线观看| 欧美成人激情免费网| 国产精品麻豆视频| 偷拍自拍另类欧美| 成人午夜电影小说| 欧美精品乱人伦久久久久久| 国产午夜精品美女毛片视频| 一区二区三区免费看视频| 精品影院一区二区久久久| 91在线丨porny丨国产| 日韩一区二区在线免费观看| 国产精品女人毛片| 奇米影视一区二区三区小说| 99久久久久久99| 日韩欧美高清dvd碟片| 亚洲人成精品久久久久久| 精一区二区三区| 欧美日韩精品一区二区天天拍小说| 久久久久久久久久久电影| 亚洲影视资源网| 丁香六月综合激情| 日韩欧美成人一区| 亚洲电影你懂得| 97se亚洲国产综合在线| 精品国产伦一区二区三区免费| 一区二区三区丝袜| 成人综合婷婷国产精品久久蜜臀| 欧美浪妇xxxx高跟鞋交| 亚洲视频每日更新| 国产一区二区三区精品视频| 在线不卡中文字幕播放| 亚洲免费在线视频| 高清beeg欧美| 久久综合999| 蜜桃久久av一区| 欧美日产在线观看| 一区二区三区av电影 | 欧美精品第一页| 亚洲欧美国产77777| 大胆亚洲人体视频| 久久综合av免费| 看电视剧不卡顿的网站| 欧美午夜一区二区三区免费大片| 国产精品人妖ts系列视频 | 91精品国产91久久久久久一区二区 | 中文字幕精品一区二区三区精品| 综合电影一区二区三区| 精品影院一区二区久久久| 欧美一区二区二区| 午夜精品爽啪视频| 欧美性色黄大片| 亚洲自拍偷拍av| 色94色欧美sute亚洲线路二| 国产精品免费久久| 成人va在线观看| 国产精品青草久久| 成人黄色综合网站| 国产精品情趣视频| a级精品国产片在线观看| 国产亚洲欧洲997久久综合 | 国产麻豆精品theporn| www激情久久| 国产精品一区二区三区99 | 极品少妇xxxx精品少妇偷拍| 日韩一区二区视频在线观看| 日日夜夜免费精品视频| 这里是久久伊人| 日本午夜一区二区| 5月丁香婷婷综合| 捆绑紧缚一区二区三区视频 | 蜜臀av性久久久久av蜜臀妖精| 欧美日韩国产影片| 美美哒免费高清在线观看视频一区二区| 7777精品伊人久久久大香线蕉的| 石原莉奈在线亚洲二区| 日韩午夜在线影院| 国产伦理精品不卡| 国产精品理伦片| 在线精品观看国产| 日日摸夜夜添夜夜添精品视频 | 亚洲日本在线视频观看| 日本韩国一区二区三区视频| 亚洲国产成人va在线观看天堂| 欧美色爱综合网| 男男成人高潮片免费网站| 精品理论电影在线| 国产91精品免费| 一区二区三区在线视频播放| 欧美丰满美乳xxx高潮www| 玖玖九九国产精品| 国产精品国模大尺度视频| 欧洲一区二区av| 久久er99热精品一区二区| 国产精品女主播在线观看| 欧美伊人久久久久久久久影院 | 亚洲一二三四区| 日韩欧美国产小视频| 国产91露脸合集magnet| 一区二区三区欧美| 久久先锋影音av鲁色资源| av动漫一区二区| 视频一区二区中文字幕| 欧美激情中文字幕| 欧美日韩国产精品自在自线| 国产一区二区电影| 一区二区三区国产豹纹内裤在线 | 夜夜爽夜夜爽精品视频| 91精品国产综合久久婷婷香蕉| 国产一区999| 亚洲va欧美va天堂v国产综合| 精品美女在线观看| 91毛片在线观看| 寂寞少妇一区二区三区| 亚洲综合一区在线| 久久蜜桃av一区二区天堂| 欧洲精品一区二区| 国产成人免费在线| 日韩高清电影一区| 亚洲婷婷国产精品电影人久久| 91精品婷婷国产综合久久竹菊| 成人精品电影在线观看| 奇米一区二区三区av| 亚洲免费观看高清完整版在线| 日韩精品中文字幕在线一区| 色猫猫国产区一区二在线视频| 激情五月播播久久久精品| 亚洲一区二区欧美| 国产精品欧美一级免费| 精品99久久久久久| 欧美日本一区二区在线观看| 菠萝蜜视频在线观看一区| 六月丁香综合在线视频| 亚洲欧美日韩成人高清在线一区| 精品国产免费人成电影在线观看四季 | 国产日本欧美一区二区| 色94色欧美sute亚洲线路一久| 国产精品一区二区久久不卡 | 国产成人亚洲综合a∨婷婷| 五月婷婷综合在线| 亚洲视频一二三| 中文字幕欧美日本乱码一线二线| 欧美电影免费观看高清完整版在| 欧美日韩一区二区欧美激情| 91色porny蝌蚪| 99久久免费视频.com| 国产精品一品视频| 国产综合色视频| 蜜桃在线一区二区三区| 日韩成人免费在线| 丝袜美腿亚洲一区| 亚洲一区二区在线观看视频| 亚洲欧洲无码一区二区三区| 久久久久国产精品人| 久久久久久久久久电影| 久久奇米777| 久久久综合网站| 久久精品日韩一区二区三区| 久久久久久麻豆|