亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产拍欧美日韩视频二区| 日韩在线a电影| 蜜桃视频在线一区| www.在线成人| 日韩欧美中文字幕精品| 国产欧美日韩亚州综合 | 色婷婷久久一区二区三区麻豆| 欧美日韩色综合| 日韩理论在线观看| 国产传媒一区在线| 精品免费日韩av| 午夜精品久久久久久久久久久| 97se亚洲国产综合自在线观| 久久九九久久九九| 黄色小说综合网站| 欧美成人性福生活免费看| 亚洲综合激情小说| 91久久国产综合久久| 亚洲欧洲精品成人久久奇米网| 国产乱子伦视频一区二区三区| 555夜色666亚洲国产免| 一级做a爱片久久| 色拍拍在线精品视频8848| 中文字幕制服丝袜成人av| 国产高清久久久久| 精品久久国产字幕高潮| 美女脱光内衣内裤视频久久网站 | eeuss鲁片一区二区三区在线看| 日韩美一区二区三区| 婷婷夜色潮精品综合在线| 欧美三级资源在线| 亚洲va天堂va国产va久| 欧美日高清视频| 日韩和欧美一区二区| 在线91免费看| 另类欧美日韩国产在线| 精品成人免费观看| 国产成人精品www牛牛影视| 欧美国产综合一区二区| 波多野结衣中文一区| 欧美国产综合色视频| 色综合久久久久久久久久久| 国产成人免费在线观看| 国模大尺度一区二区三区| 久久久久久久久久久久久女国产乱| 国产在线精品不卡| 国产精品久久久久四虎| 在线亚洲人成电影网站色www| 亚洲精品国产无天堂网2021| 欧美另类变人与禽xxxxx| 久久国内精品视频| 久久精品一区四区| 91麻豆福利精品推荐| 亚洲aaa精品| 久久久综合网站| 色欧美片视频在线观看| 日韩和欧美的一区| 国产视频一区二区三区在线观看| 99久久婷婷国产综合精品电影| 亚洲国产精品一区二区www在线| 在线观看91av| 成人免费观看av| 亚洲国产你懂的| 亚洲精品一区在线观看| 99麻豆久久久国产精品免费| 香蕉加勒比综合久久| 日韩一二在线观看| 99re热这里只有精品视频| 日韩国产在线观看| 国产精品电影一区二区三区| 欧美色综合久久| 国产成人精品综合在线观看| 一个色在线综合| 亚洲国产精品国自产拍av| 欧美日韩国产一级片| 国产成人综合亚洲91猫咪| 一区二区三区.www| 久久九九99视频| 欧美一区二区三级| 色综合天天综合网国产成人综合天| 免费成人在线播放| 亚洲一卡二卡三卡四卡五卡| 久久久午夜精品理论片中文字幕| 欧美性大战久久| 91小视频在线| 国产精品一区二区91| 日本中文在线一区| 一区二区在线观看不卡| 国产欧美精品在线观看| 国产精品女主播av| wwwwww.欧美系列| 9191成人精品久久| 欧美在线你懂的| eeuss鲁片一区二区三区在线看| 国产自产高清不卡| 美女网站一区二区| 日本欧美一区二区在线观看| 夜夜嗨av一区二区三区网页| 国产精品麻豆网站| 国产精品麻豆视频| 欧美激情一区三区| 国产三级精品三级| 久久亚洲一级片| 久久午夜国产精品| 欧美一区二区三区免费观看视频| 欧美少妇xxx| 欧美日高清视频| 欧美精品少妇一区二区三区| 在线观看亚洲成人| 欧美亚州韩日在线看免费版国语版| 成人18视频日本| 97精品视频在线观看自产线路二| 成人免费高清视频| 成人app软件下载大全免费| 成人性生交大片免费看中文| 粉嫩绯色av一区二区在线观看| 经典三级在线一区| 国产精品亚洲午夜一区二区三区| 国模无码大尺度一区二区三区| 国产精品影视网| 国产99久久久久| 99国产精品久久久久久久久久| www.视频一区| 欧美亚洲一区二区三区四区| 色8久久精品久久久久久蜜| 欧美在线观看一二区| 欧美日韩免费一区二区三区视频| 欧美色倩网站大全免费| 欧美另类一区二区三区| 欧美大尺度电影在线| 久久青草欧美一区二区三区| 国产女同性恋一区二区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 综合在线观看色| 亚洲自拍偷拍九九九| 麻豆一区二区三| 国产高清亚洲一区| 在线免费av一区| 欧美一级久久久| 国产精品丝袜黑色高跟| 亚洲最大成人网4388xx| 免费观看30秒视频久久| 国产成人精品1024| 亚洲品质自拍视频网站| 91免费国产在线观看| 欧美日韩精品欧美日韩精品一| 欧美成人综合网站| 国产精品色婷婷久久58| 天堂久久一区二区三区| 国产美女主播视频一区| 色视频一区二区| 精品国产一区二区三区av性色| 国产精品乱码久久久久久| 视频一区二区国产| 大尺度一区二区| 欧美日韩aaaaa| 综合激情网...| 麻豆精品一二三| 99re热视频这里只精品| 精品久久人人做人人爽| 亚洲另类色综合网站| 国产一区二区免费看| 欧美伊人精品成人久久综合97| 精品国产乱码久久久久久蜜臀| 一级日本不卡的影视| 国产成人精品三级| 欧美一级一区二区| 亚洲精品国产a久久久久久 | 亚洲成av人影院| 99久久久精品| 久久久精品日韩欧美| 五月激情六月综合| 91麻豆免费看片| 欧美国产精品一区二区三区| 亚洲超丰满肉感bbw| 97精品国产露脸对白| 国产亚洲一二三区| 久久国产尿小便嘘嘘| 欧美四级电影在线观看| 中文字幕中文字幕在线一区| 久久成人免费电影| 在线成人小视频| 亚洲午夜一二三区视频| 91视视频在线观看入口直接观看www | 亚洲黄色在线视频| 国产91精品久久久久久久网曝门 | 久久国产免费看| 欧美肥胖老妇做爰| 亚洲高清中文字幕| 色婷婷av一区| 一区二区三区加勒比av| 福利一区福利二区| 久久久.com| 国产精品亚洲午夜一区二区三区| 日韩一级片在线观看| 午夜精品一区二区三区免费视频| 日本乱人伦一区| 亚洲一区中文在线| 欧美日韩在线观看一区二区 | 亚洲视频免费在线观看|