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

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

?? classfun.c

?? clips源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
            for (i = 0 ; i < cls->slotCount ; i++)        {         slot = &cls->slots[i];         DecrementSymbolCount(theEnv,slot->overrideMessage);         if (slot->defaultValue != NULL)           {            if (slot->dynamicDefault)              ExpressionDeinstall(theEnv,(EXPRESSION *) slot->defaultValue);            else              ValueDeinstall(theEnv,(DATA_OBJECT *) slot->defaultValue);           }        }      for (i = 0 ; i < cls->handlerCount ; i++)        {         hnd = &cls->handlers[i];         DecrementSymbolCount(theEnv,hnd->name);         if (hnd->actions != NULL)           ExpressionDeinstall(theEnv,hnd->actions);        }     }   else     {      cls->installed = 1;      IncrementSymbolCount(cls->header.name);     }  }#endif#if (! BLOAD_ONLY) && (! RUN_TIME)/***************************************************  NAME         : IsClassBeingUsed  DESCRIPTION  : Checks the busy flag of a class                   and ALL classes that inherit from                   it to make sure that it is not                   in use before deletion  INPUTS       : The class  RETURNS      : TRUE if in use, FALSE otherwise  SIDE EFFECTS : None  NOTES        : Recursively examines all subclasses ***************************************************/globle int IsClassBeingUsed(  DEFCLASS *cls)  {   long i;   if (cls->busy > 0)     return(TRUE);   for (i = 0 ; i < cls->directSubclasses.classCount ; i++)     if (IsClassBeingUsed(cls->directSubclasses.classArray[i]))       return(TRUE);   return(FALSE);  }/***************************************************  NAME         : RemoveAllUserClasses  DESCRIPTION  : Removes all classes  INPUTS       : None  RETURNS      : TRUE if succesful, FALSE otherwise  SIDE EFFECTS : The class hash table is cleared  NOTES        : None ***************************************************/globle int RemoveAllUserClasses(  void *theEnv)  {   void *userClasses,*ctmp;   int success = TRUE;#if BLOAD || BLOAD_AND_BSAVE   if (Bloaded(theEnv))     return(FALSE);#endif   /* ====================================================      Don't delete built-in system classes at head of list      ==================================================== */   userClasses = EnvGetNextDefclass(theEnv,NULL);   while (userClasses != NULL)     {      if (((DEFCLASS *) userClasses)->system == 0)        break;      userClasses = EnvGetNextDefclass(theEnv,userClasses);     }   while (userClasses != NULL)     {      ctmp = userClasses;      userClasses = EnvGetNextDefclass(theEnv,userClasses);      if (EnvIsDefclassDeletable(theEnv,ctmp))        {         RemoveConstructFromModule(theEnv,(struct constructHeader *) ctmp);         RemoveDefclass(theEnv,ctmp);        }      else        {         success = FALSE;         CantDeleteItemErrorMessage(theEnv,"defclass",EnvGetDefclassName(theEnv,ctmp));        }     }   return(success);  }/****************************************************  NAME         : DeleteClassUAG  DESCRIPTION  : Deallocates a class and all its                 subclasses  INPUTS       : The address of the class  RETURNS      : 1 if successful, 0 otherwise  SIDE EFFECTS : Removes the class from each of                 its superclasses' subclass lists  NOTES        : None ****************************************************/globle int DeleteClassUAG(  void *theEnv,  DEFCLASS *cls)  {   long subCount;   while (cls->directSubclasses.classCount != 0)     {      subCount = cls->directSubclasses.classCount;      DeleteClassUAG(theEnv,cls->directSubclasses.classArray[0]);      if (cls->directSubclasses.classCount == subCount)        return(FALSE);     }   if (EnvIsDefclassDeletable(theEnv,(void *) cls))     {      RemoveConstructFromModule(theEnv,(struct constructHeader *) cls);      RemoveDefclass(theEnv,(void *) cls);      return(TRUE);     }   return(FALSE);  }/*********************************************************  NAME         : MarkBitMapSubclasses  DESCRIPTION  : Recursively marks the ids of a class                 and all its subclasses in a bitmap  INPUTS       : 1) The bitmap                 2) The class                 3) A code indicating whether to set                    or clear the bits of the map                    corresponding to the class ids  RETURNS      : Nothing useful  SIDE EFFECTS : BitMap marked  NOTES        : IMPORTANT!!!!  Assumes the bitmap is                 large enough to hold all ids encountered! *********************************************************/globle void MarkBitMapSubclasses(  char *map,  DEFCLASS *cls,  int set)  {   long i;   if (set)     SetBitMap(map,cls->id);   else     ClearBitMap(map,cls->id);   for (i = 0 ; i < cls->directSubclasses.classCount ; i++)     MarkBitMapSubclasses(map,cls->directSubclasses.classArray[i],set);  }#endif/***************************************************  NAME         : FindSlotNameID  DESCRIPTION  : Finds the id of a slot name  INPUTS       : The slot name  RETURNS      : The slot name id (-1 if not found)  SIDE EFFECTS : None  NOTES        : A slot name always has the same                 id regardless of what class uses                 it.  In this way, a slot can                 be referred to by index independent                 of class.  Each class stores a                 map showing which slot name indices                 go to which slot.  This provides                 for immediate lookup of slots                 given the index (object pattern                 matching uses this). ***************************************************/globle short FindSlotNameID(  void *theEnv,  SYMBOL_HN *slotName)  {   SLOT_NAME *snp;   snp = DefclassData(theEnv)->SlotNameTable[HashSlotName(slotName)];   while ((snp != NULL) ? (snp->name != slotName) : FALSE)     snp = snp->nxt;   return((snp != NULL) ? (short) snp->id : (short) -1);  }/***************************************************  NAME         : FindIDSlotName  DESCRIPTION  : Finds the slot anme for an id  INPUTS       : The id  RETURNS      : The slot name (NULL if not found)  SIDE EFFECTS : None  NOTES        : None ***************************************************/globle SYMBOL_HN *FindIDSlotName(  void *theEnv,  int id)  {   SLOT_NAME *snp;   snp = FindIDSlotNameHash(theEnv,id);   return((snp != NULL) ? snp->name : NULL);  }/***************************************************  NAME         : FindIDSlotNameHash  DESCRIPTION  : Finds the slot anme for an id  INPUTS       : The id  RETURNS      : The slot name (NULL if not found)  SIDE EFFECTS : None  NOTES        : None ***************************************************/globle SLOT_NAME *FindIDSlotNameHash(  void *theEnv,  int id)  {   register int i;   SLOT_NAME *snp;   for (i = 0 ; i < SLOT_NAME_TABLE_HASH_SIZE ; i++)     {      snp = DefclassData(theEnv)->SlotNameTable[i];      while (snp != NULL)        {         if (snp->id == id)           return(snp);         snp = snp->nxt;        }     }   return(NULL);  }/***************************************************  NAME         : GetTraversalID  DESCRIPTION  : Returns a unique integer ID for a                  traversal into the class hierarchy  INPUTS       : None  RETURNS      : The id, or -1 if none available  SIDE EFFECTS : EvaluationError set when no ids                   available  NOTES        : Used for recursive traversals of                  class hierarchy to assure that a                  class is only visited once ***************************************************/globle int GetTraversalID(  void *theEnv)  {   register unsigned i;   register DEFCLASS *cls;   if (DefclassData(theEnv)->CTID >= MAX_TRAVERSALS)     {      PrintErrorID(theEnv,"CLASSFUN",2,FALSE);      EnvPrintRouter(theEnv,WERROR,"Maximum number of simultaneous class hierarchy\n  traversals exceeded ");      PrintLongInteger(theEnv,WERROR,(long) MAX_TRAVERSALS);      EnvPrintRouter(theEnv,WERROR,".\n");      SetEvaluationError(theEnv,TRUE);      return(-1);     }   for (i = 0 ; i < CLASS_TABLE_HASH_SIZE ; i++)     for (cls = DefclassData(theEnv)->ClassTable[i] ; cls != NULL ; cls = cls->nxtHash)       ClearTraversalID(cls->traversalRecord,DefclassData(theEnv)->CTID);   return(DefclassData(theEnv)->CTID++);  }/***************************************************  NAME         : ReleaseTraversalID  DESCRIPTION  : Releases an ID for future use                 Also clears id from all classes  INPUTS       : None  RETURNS      : Nothing useful  SIDE EFFECTS : Old ID released for later reuse  NOTES        : Releases ID returned by most recent                   call to GetTraversalID() ***************************************************/globle void ReleaseTraversalID(  void *theEnv)  {   DefclassData(theEnv)->CTID--;  }/*******************************************************  NAME         : HashClass  DESCRIPTION  : Generates a hash index for a given                 class name  INPUTS       : The address of the class name SYMBOL_HN  RETURNS      : The hash index value  SIDE EFFECTS : None  NOTES        : Counts on the fact that the symbol                 has already been hashed into the                 symbol table - uses that hash value                 multiplied by a prime for a new hash *******************************************************/globle unsigned HashClass(  SYMBOL_HN *cname)  {   unsigned long tally;   tally = ((unsigned long) cname->bucket) * BIG_PRIME;   return((unsigned) (tally % CLASS_TABLE_HASH_SIZE));  }/* =========================================   *****************************************          INTERNALLY VISIBLE FUNCTIONS   =========================================   ***************************************** *//*******************************************************  NAME         : HashSlotName  DESCRIPTION  : Generates a hash index for a given                 slot name  INPUTS       : The address of the slot name SYMBOL_HN  RETURNS      : The hash index value  SIDE EFFECTS : None  NOTES        : Counts on the fact that the symbol                 has already been hashed into the                 symbol table - uses that hash value                 multiplied by a prime for a new hash *******************************************************/static unsigned HashSlotName(  SYMBOL_HN *sname)  {   unsigned long tally;   tally = ((unsigned long) sname->bucket) * BIG_PRIME;   return((unsigned) (tally % SLOT_NAME_TABLE_HASH_SIZE));  }#if (! RUN_TIME)/***********************************************  NAME         : NewSlotNameID  DESCRIPTION  : Returns  an unused slot name id                 as close to 1 as possible  INPUTS       : None  RETURNS      : The new unused id  SIDE EFFECTS : None  NOTES        : None ***********************************************/static int NewSlotNameID(  void *theEnv)  {   int newid = 0;   register unsigned i;   SLOT_NAME *snp;   while (TRUE)     {      for (i = 0 ; i < SLOT_NAME_TABLE_HASH_SIZE ; i++)        {         snp = DefclassData(theEnv)->SlotNameTable[i];         while ((snp != NULL) ? (snp->id != newid) : FALSE)           snp = snp->nxt;         if (snp != NULL)           break;        }      if (i < SLOT_NAME_TABLE_HASH_SIZE)        newid++;      else        break;     }   return(newid);  }/***************************************************  NAME         : DeassignClassID  DESCRIPTION  : Reduces id map and MaxClassID if                 no ids in use above the one being                 released.  INPUTS       : The id  RETURNS      : Nothing useful  SIDE EFFECTS : ID map and MaxClassID possibly                 reduced  NOTES        : None ***************************************************/static void DeassignClassID(  void *theEnv,  unsigned id)  {   register unsigned i;   int reallocReqd;   unsigned short oldChunk = 0,newChunk = 0;   DefclassData(theEnv)->ClassIDMap[id] = NULL;   for (i = id + 1 ; i < DefclassData(theEnv)->MaxClassID ; i++)     if (DefclassData(theEnv)->ClassIDMap[i] != NULL)       return;   reallocReqd = FALSE;   while (DefclassData(theEnv)->ClassIDMap[id] == NULL)     {      DefclassData(theEnv)->MaxClassID = (unsigned short) id;      if ((DefclassData(theEnv)->MaxClassID % CLASS_ID_MAP_CHUNK) == 0)        {         newChunk = DefclassData(theEnv)->MaxClassID;         if (reallocReqd == FALSE)           {            oldChunk = (unsigned short) (DefclassData(theEnv)->MaxClassID + CLASS_ID_MAP_CHUNK);            reallocReqd = TRUE;           }        }      if (id == 0)        break;      id--;     }   if (reallocReqd)     {      DefclassData(theEnv)->ClassIDMap = (DEFCLASS **) genrealloc(theEnv,(void *) DefclassData(theEnv)->ClassIDMap,                       (unsigned) (oldChunk * sizeof(DEFCLASS *)),                       (unsigned) (newChunk * sizeof(DEFCLASS *)));                             DefclassData(theEnv)->AvailClassID = newChunk;     }  }#endif#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一区二区三区不卡牛牛| 91行情网站电视在线观看高清版| 久久先锋影音av| 久久er99热精品一区二区| 777色狠狠一区二区三区| 日韩电影免费一区| 26uuu色噜噜精品一区二区| 国产成人在线视频免费播放| 8x8x8国产精品| 国产精品18久久久久久久久 | 亚洲色图都市小说| 在线精品视频一区二区三四| 蜜桃视频在线一区| 国产三区在线成人av| 色综合色狠狠综合色| 五月婷婷久久丁香| 国产欧美精品一区aⅴ影院 | 亚洲女与黑人做爰| 欧美性一二三区| 国产一区二区剧情av在线| 亚洲欧美综合色| 91精品国产91久久久久久最新毛片 | 日韩丝袜美女视频| 成人免费毛片嘿嘿连载视频| 亚洲国产视频网站| 国产欧美日韩卡一| 欧美丝袜丝交足nylons图片| 国产精品1区2区3区在线观看| 国产亚洲一二三区| 欧美丰满高潮xxxx喷水动漫| 丰满白嫩尤物一区二区| 视频在线观看一区二区三区| 亚洲视频一区二区免费在线观看| 日韩精品中文字幕在线不卡尤物| 色综合久久综合网97色综合 | 日本一区二区动态图| 制服.丝袜.亚洲.另类.中文| 成人av网站在线| 国产一区二区伦理片| 六月婷婷色综合| 视频一区中文字幕| 亚洲美女少妇撒尿| 国产精品久久久久aaaa| 久久人人超碰精品| 欧美成人精品福利| 精品入口麻豆88视频| 精品国产免费人成在线观看| 日韩一区二区三区视频| 欧美一区二区视频观看视频| 7777女厕盗摄久久久| 欧美精品一卡二卡| 91精品国产综合久久福利软件| 欧美午夜不卡视频| 欧美综合欧美视频| 在线免费一区三区| 欧美色综合久久| 欧美区视频在线观看| 欧美二区三区91| 69堂成人精品免费视频| 欧美一级搡bbbb搡bbbb| 欧美电影精品一区二区| 精品少妇一区二区三区在线视频| 精品国产髙清在线看国产毛片| 欧美成人精精品一区二区频| 久久久精品tv| 亚洲欧美视频在线观看| 亚洲午夜私人影院| 极品少妇一区二区| 日韩精品一区二区三区在线播放| 欧美一区二区三区播放老司机| 欧美一区二区福利视频| 国产日韩欧美精品在线| 1024成人网| 青青草97国产精品免费观看无弹窗版| 久久99精品国产麻豆不卡| 成人午夜在线免费| 欧美日韩视频在线观看一区二区三区| 日韩视频一区二区三区在线播放 | 中文在线一区二区 | 久久久久久久久免费| 亚洲精品美腿丝袜| 男女男精品网站| 99国产精品久久久久| 精品久久一二三区| 亚洲精品国产a| 亚洲欧美精品午睡沙发| 2024国产精品| 亚洲欧美视频一区| 国产尤物一区二区在线| 欧美日韩综合色| 中文天堂在线一区| 九九在线精品视频| 欧美唯美清纯偷拍| 国产精品高潮呻吟久久| 国内精品在线播放| 3751色影院一区二区三区| 中文字幕一区二区5566日韩| 26uuu色噜噜精品一区| 91视视频在线直接观看在线看网页在线看| 国产一区二区三区久久悠悠色av | 日韩三级免费观看| 亚洲一线二线三线视频| 国产成人亚洲综合a∨猫咪| 欧美一区二区三区在线观看| 午夜精品久久久久久| 成人中文字幕电影| 久久综合九色综合97婷婷| 舔着乳尖日韩一区| 国产在线国偷精品免费看| 欧美男同性恋视频网站| 亚洲裸体在线观看| a4yy欧美一区二区三区| 久久女同性恋中文字幕| 精品在线播放免费| 久久久久国产精品麻豆ai换脸 | 中文字幕日韩精品一区| 91免费视频网| 婷婷综合五月天| 日韩三级在线观看| 激情图区综合网| 国产天堂亚洲国产碰碰| 9人人澡人人爽人人精品| 亚洲视频中文字幕| 欧美午夜电影在线播放| 老鸭窝一区二区久久精品| 欧美无人高清视频在线观看| 国产精品三级在线观看| 久久99精品久久久久婷婷| 欧美亚洲图片小说| 三级成人在线视频| 日韩一区二区在线看片| 国产馆精品极品| 国产精品丝袜久久久久久app| a4yy欧美一区二区三区| 偷窥少妇高潮呻吟av久久免费| 欧美一区二区三区四区视频| 国产一区二区不卡在线| 亚洲色图视频网站| 欧美videos大乳护士334| 不卡的电影网站| 日韩中文字幕区一区有砖一区| 久久久一区二区三区| 欧美在线观看视频在线| 国产精品99久久久| 人妖欧美一区二区| 亚洲手机成人高清视频| 精品国产乱子伦一区| 欧美性色综合网| 国产成人免费视频网站高清观看视频 | 亚洲成在线观看| 精品国产电影一区二区| 国产精品久久久久久福利一牛影视 | 亚洲视频一区在线| 26uuu国产日韩综合| 欧美日韩成人高清| 91久久精品一区二区| 国产精品一二三在| 免费三级欧美电影| 亚洲精品第一国产综合野| 国产日韩欧美电影| 精品国产乱码久久久久久图片| 色综合天天狠狠| 99国产一区二区三精品乱码| 久久99久国产精品黄毛片色诱| 日韩国产欧美一区二区三区| 一区二区三区蜜桃| 综合网在线视频| 亚洲蜜臀av乱码久久精品蜜桃| 欧美日韩在线电影| 色综合久久九月婷婷色综合| 大尺度一区二区| 成人丝袜高跟foot| 国产风韵犹存在线视精品| 久久成人久久鬼色| 精品一区二区三区在线视频| 九一九一国产精品| 国产又粗又猛又爽又黄91精品| 久久国产精品99久久久久久老狼| 蜜臀av一区二区三区| 精品在线观看视频| 国产成人午夜片在线观看高清观看| 狠狠色丁香久久婷婷综合丁香| 久久成人免费电影| 国产.精品.日韩.另类.中文.在线.播放| 激情图片小说一区| 成人黄色网址在线观看| 一本大道久久a久久综合婷婷| 欧美亚洲日本一区| 欧美大度的电影原声| 欧美国产1区2区| 亚洲高清免费一级二级三级| 亚洲一区二区三区视频在线| 久久国产精品色婷婷| 不卡一区二区在线| 欧美日韩夫妻久久| 久久久青草青青国产亚洲免观| 国产蜜臀av在线一区二区三区| 亚洲裸体在线观看| 精品一区二区三区蜜桃| 97久久超碰国产精品|