亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧美三级资源在线| 欧美色综合影院| 亚洲成av人片在线观看| 亚洲欧洲色图综合| 国产精品国产三级国产aⅴ原创 | 国产999精品久久| 日本不卡1234视频| 久久国产婷婷国产香蕉| 久久精品久久久精品美女| 日韩不卡在线观看日韩不卡视频| 一区二区三区日韩| 天使萌一区二区三区免费观看| 亚洲自拍偷拍欧美| 日韩黄色免费电影| 久久国产精品色| 国产成人鲁色资源国产91色综| 国产精品77777| www.av亚洲| 欧美日韩国产大片| 日韩一级欧美一级| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美精品一区二区三区蜜桃| 国产精品色哟哟| 一区二区三区四区亚洲| 日韩在线一二三区| 国产精品一区二区三区四区| caoporn国产精品| 在线一区二区三区四区五区 | 日本不卡123| 韩国精品在线观看| 91视频你懂的| 日韩免费高清视频| 国产精品第13页| 天天av天天翘天天综合网色鬼国产| 裸体健美xxxx欧美裸体表演| 成人国产电影网| 欧美精品色一区二区三区| 久久婷婷久久一区二区三区| 亚洲四区在线观看| 久久精品99久久久| 欧美主播一区二区三区美女| 精品国内二区三区| 亚洲国产wwwccc36天堂| 国产美女视频一区| 欧美精品一卡两卡| 国产精品沙发午睡系列990531| 日精品一区二区三区| 成人av网站在线观看免费| 69堂精品视频| 亚洲欧美日韩国产中文在线| 久久成人18免费观看| 在线观看亚洲专区| 国产精品久久久久久久久快鸭| 偷窥国产亚洲免费视频| 99久久99久久精品免费观看| 精品国产自在久精品国产| 亚洲电影一级片| 99热在这里有精品免费| 久久一区二区三区四区| 日韩中文字幕区一区有砖一区| 99这里都是精品| 欧美va日韩va| 日本麻豆一区二区三区视频| 日本道精品一区二区三区| 国产日韩欧美麻豆| 精品一区二区免费看| 91麻豆精品国产| 一区二区三区日韩欧美精品| bt欧美亚洲午夜电影天堂| 久久一二三国产| 久久av中文字幕片| 欧美大胆一级视频| 蜜臀av在线播放一区二区三区| 91精品91久久久中77777| 国产精品每日更新| 99麻豆久久久国产精品免费| 日本一区二区三区电影| 国产v综合v亚洲欧| 中文字幕国产一区| av在线不卡免费看| 亚洲欧美在线观看| 色综合 综合色| 亚洲黄色小视频| 欧美自拍丝袜亚洲| 日日嗨av一区二区三区四区| 日韩欧美123| 激情伊人五月天久久综合| 日韩精品一区二区三区在线播放 | 国产精品久久久久9999吃药| 国产成人精品一区二区三区网站观看| 精品少妇一区二区三区免费观看 | 成人欧美一区二区三区在线播放| 波多野结衣中文字幕一区| 亚洲同性同志一二三专区| 91成人网在线| 肉色丝袜一区二区| 国产亚洲一区二区三区四区| 成人精品小蝌蚪| 一区二区三区产品免费精品久久75| 在线精品视频免费观看| 日韩不卡一二三区| 久久精品欧美一区二区三区不卡| 不卡在线视频中文字幕| 亚洲激情图片一区| 欧美成人精品高清在线播放| 国产成人在线色| 亚洲最新在线观看| 日韩欧美国产一区在线观看| 高清不卡在线观看| 亚洲福利视频一区| 久久婷婷成人综合色| 在线精品亚洲一区二区不卡| 美国毛片一区二区| 亚洲日本中文字幕区| 9191成人精品久久| 成人一区二区三区视频在线观看| 亚洲三级电影网站| 欧美一级在线免费| 色悠久久久久综合欧美99| 精品一区二区在线视频| 亚洲欧美另类图片小说| 日韩亚洲欧美一区二区三区| thepron国产精品| 美国一区二区三区在线播放| 一区二区三区在线免费| 国产日产欧产精品推荐色| 欧美日韩激情在线| 成av人片一区二区| 国产在线精品国自产拍免费| 亚洲一区二区三区影院| 国产欧美日韩精品一区| 91精品国产免费| 欧美亚男人的天堂| 成人手机在线视频| 黄页视频在线91| 日韩精品免费视频人成| 中文字幕日韩一区二区| 久久一区二区视频| 欧美成人精品1314www| 欧美日韩精品一区二区| 91欧美一区二区| 波多野洁衣一区| 国产不卡在线一区| 国产精品911| 国产一区二区美女诱惑| 裸体一区二区三区| 奇米影视一区二区三区小说| 亚洲综合精品自拍| 一区二区三国产精华液| 亚洲女人的天堂| 亚洲欧洲日本在线| 亚洲女女做受ⅹxx高潮| 亚洲精品高清在线| 一区二区三区自拍| 一区二区三区四区中文字幕| 亚洲六月丁香色婷婷综合久久| 国产精品不卡在线观看| 国产精品美女久久久久av爽李琼| 亚洲国产高清在线| 国产精品国产三级国产普通话99| 国产日韩三级在线| 欧美国产精品一区二区三区| 欧美经典一区二区| 国产精品乱码妇女bbbb| 成人免费在线视频| 夜色激情一区二区| 日本美女一区二区| 国内精品伊人久久久久av一坑| 国产一区二区伦理片| 成人免费毛片嘿嘿连载视频| 95精品视频在线| 欧美视频在线一区二区三区| 在线成人午夜影院| 精品国偷自产国产一区| 国产无一区二区| 椎名由奈av一区二区三区| 亚洲在线成人精品| 蜜臀精品一区二区三区在线观看| 国内精品视频一区二区三区八戒| 国产suv精品一区二区6| 在线观看日韩av先锋影音电影院| 91麻豆精品91久久久久久清纯| 欧美一区二区三级| 国产欧美日本一区视频| 亚洲成在人线在线播放| 国产一区二区三区四区在线观看 | 一区二区视频在线看| 亚洲大片精品永久免费| 国产精品一线二线三线精华| 91麻豆成人久久精品二区三区| 欧美精品久久久久久久多人混战| 久久亚洲一区二区三区明星换脸| 国产精品电影一区二区三区| 日韩不卡免费视频| 色综合一区二区| 久久老女人爱爱| 亚洲国产日产av| av成人老司机| 精品国产亚洲在线| 亚洲综合图片区|