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

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

?? genrcfun.c

?? clips源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
   /*******************************************************/   /*      "C" Language Integrated Production System      */   /*                                                     */   /*               CLIPS Version 6.24  05/17/06          */   /*                                                     */   /*                                                     */   /*******************************************************//*************************************************************//* Purpose: Generic Functions Internal Routines              *//*                                                           *//* Principal Programmer(s):                                  *//*      Brian L. Donnell                                     *//*                                                           *//* Contributing Programmer(s):                               *//*                                                           *//* Revision History:                                         *//*      6.23: Changed name of variable log to logName        *//*            because of Unix compiler warnings of shadowed  *//*            definitions.                                   *//*                                                           *//*      6.24: Removed IMPERATIVE_METHODS compilation flag.   *//*                                                           *//*            Renamed BOOLEAN macro type to intBool.         *//*                                                           *//*************************************************************//* =========================================   *****************************************               EXTERNAL DEFINITIONS   =========================================   ***************************************** */#include "setup.h"#if DEFGENERIC_CONSTRUCT#if BLOAD || BLOAD_AND_BSAVE#include "bload.h"#endif#if OBJECT_SYSTEM#include "classcom.h"#include "classfun.h"#endif#include "argacces.h"#include "constrct.h"#include "cstrcpsr.h"#include "envrnmnt.h"#include "genrccom.h"#include "genrcexe.h"#include "memalloc.h"#include "prccode.h"#include "router.h"#include "sysdep.h"#define _GENRCFUN_SOURCE_#include "genrcfun.h"/* =========================================   *****************************************      INTERNALLY VISIBLE FUNCTION HEADERS   =========================================   ***************************************** */#if DEBUGGING_FUNCTIONSstatic void DisplayGenericCore(void *,DEFGENERIC *);#endif/* =========================================   *****************************************          EXTERNALLY VISIBLE FUNCTIONS   =========================================   ***************************************** */#if ! RUN_TIME/***************************************************  NAME         : ClearDefgenericsReady  DESCRIPTION  : Determines if it is safe to                 remove all defgenerics                 Assumes *all* constructs will be                 deleted - only checks to see if                 any methods are currently                 executing  INPUTS       : None  RETURNS      : TRUE if no methods are                 executing, FALSE otherwise  SIDE EFFECTS : None  NOTES        : Used by (clear) and (bload) ***************************************************/globle intBool ClearDefgenericsReady(  void *theEnv)  {   return((DefgenericData(theEnv)->CurrentGeneric != NULL) ? FALSE : TRUE);  }/*****************************************************  NAME         : AllocateDefgenericModule  DESCRIPTION  : Creates and initializes a                 list of defgenerics for a new module  INPUTS       : None  RETURNS      : The new deffunction module  SIDE EFFECTS : Deffunction module created  NOTES        : None *****************************************************/globle void *AllocateDefgenericModule(  void *theEnv)  {   return((void *) get_struct(theEnv,defgenericModule));  }/***************************************************  NAME         : FreeDefgenericModule  DESCRIPTION  : Removes a deffunction module and                 all associated deffunctions  INPUTS       : The deffunction module  RETURNS      : Nothing useful  SIDE EFFECTS : Module and deffunctions deleted  NOTES        : None ***************************************************/globle void FreeDefgenericModule(  void *theEnv,  void *theItem)  {#if (! BLOAD_ONLY)   FreeConstructHeaderModule(theEnv,(struct defmoduleItemHeader *) theItem,DefgenericData(theEnv)->DefgenericConstruct);#endif   rtn_struct(theEnv,defgenericModule,theItem);  }#endif#if (! BLOAD_ONLY) && (! RUN_TIME)/************************************************************  NAME         : ClearDefmethods  DESCRIPTION  : Deletes all defmethods - generic headers                   are left intact  INPUTS       : None  RETURNS      : TRUE if all methods deleted, FALSE otherwise  SIDE EFFECTS : Defmethods deleted  NOTES        : Clearing generic functions is done in                   two stages                 1) Delete all methods (to clear any                    references to other constructs)                 2) Delete all generic headers                 This allows other constructs which                   mutually refer to generic functions                   to be cleared ************************************************************/globle int ClearDefmethods(  void *theEnv)  {   register DEFGENERIC *gfunc;   int success = TRUE;#if BLOAD || BLOAD_AND_BSAVE   if (Bloaded(theEnv) == TRUE) return(FALSE);#endif   gfunc = (DEFGENERIC *) EnvGetNextDefgeneric(theEnv,NULL);   while (gfunc != NULL)     {      if (RemoveAllExplicitMethods(theEnv,gfunc) == FALSE)        success = FALSE;      gfunc = (DEFGENERIC *) EnvGetNextDefgeneric(theEnv,(void *) gfunc);     }   return(success);  }/*****************************************************************  NAME         : RemoveAllExplicitMethods  DESCRIPTION  : Deletes all explicit defmethods - generic headers                   are left intact (as well as a method for an                   overloaded system function)  INPUTS       : None  RETURNS      : TRUE if all methods deleted, FALSE otherwise  SIDE EFFECTS : Explicit defmethods deleted  NOTES        : None *****************************************************************/globle int RemoveAllExplicitMethods(  void *theEnv,  DEFGENERIC *gfunc)  {   long i,j;   unsigned systemMethodCount = 0;   DEFMETHOD *narr;   if (MethodsExecuting(gfunc) == FALSE)     {      for (i = 0 ; i < gfunc->mcnt ; i++)        {         if (gfunc->methods[i].system)           systemMethodCount++;         else           DeleteMethodInfo(theEnv,gfunc,&gfunc->methods[i]);        }      if (systemMethodCount != 0)        {         narr = (DEFMETHOD *) gm2(theEnv,(systemMethodCount * sizeof(DEFMETHOD)));         i = 0;         j = 0;         while (i < gfunc->mcnt)           {            if (gfunc->methods[i].system)              GenCopyMemory(DEFMETHOD,1,&narr[j++],&gfunc->methods[i]);            i++;           }         rm(theEnv,(void *) gfunc->methods,(sizeof(DEFMETHOD) * gfunc->mcnt));         gfunc->mcnt = systemMethodCount;         gfunc->methods = narr;        }      else        {         if (gfunc->mcnt != 0)           rm(theEnv,(void *) gfunc->methods,(sizeof(DEFMETHOD) * gfunc->mcnt));         gfunc->mcnt = 0;         gfunc->methods = NULL;        }      return(TRUE);     }   return(FALSE);  }/**************************************************  NAME         : RemoveDefgeneric  DESCRIPTION  : Removes a generic function node                   from the generic list along with                   all its methods  INPUTS       : The generic function  RETURNS      : Nothing useful  SIDE EFFECTS : List adjusted                 Nodes deallocated  NOTES        : Assumes generic is not in use!!! **************************************************/globle void RemoveDefgeneric(  void *theEnv,  void *vgfunc)  {   DEFGENERIC *gfunc = (DEFGENERIC *) vgfunc;   long i;   for (i = 0 ; i < gfunc->mcnt ; i++)     DeleteMethodInfo(theEnv,gfunc,&gfunc->methods[i]);   if (gfunc->mcnt != 0)     rm(theEnv,(void *) gfunc->methods,(sizeof(DEFMETHOD) * gfunc->mcnt));   DecrementSymbolCount(theEnv,GetDefgenericNamePointer((void *) gfunc));   SetDefgenericPPForm((void *) gfunc,NULL);   ClearUserDataList(theEnv,gfunc->header.usrData);   rtn_struct(theEnv,defgeneric,gfunc);  }/****************************************************************  NAME         : ClearDefgenerics  DESCRIPTION  : Deletes all generic headers  INPUTS       : None  RETURNS      : TRUE if all methods deleted, FALSE otherwise  SIDE EFFECTS : Generic headers deleted (and any implicit system                  function methods)  NOTES        : None ****************************************************************/globle int ClearDefgenerics(  void *theEnv)  {   register DEFGENERIC *gfunc,*gtmp;   int success = TRUE;#if BLOAD || BLOAD_AND_BSAVE   if (Bloaded(theEnv) == TRUE) return(FALSE);#endif   gfunc = (DEFGENERIC *) EnvGetNextDefgeneric(theEnv,NULL);   while (gfunc != NULL)     {      gtmp = gfunc;      gfunc = (DEFGENERIC *) EnvGetNextDefgeneric(theEnv,(void *) gfunc);      if (RemoveAllExplicitMethods(theEnv,gtmp) == FALSE)        {         CantDeleteItemErrorMessage(theEnv,"generic function",EnvGetDefgenericName(theEnv,gtmp));         success = FALSE;        }      else        {         RemoveConstructFromModule(theEnv,(struct constructHeader *) gtmp);         RemoveDefgeneric(theEnv,(void *) gtmp);        }     }   return(success);  }/********************************************************  NAME         : MethodAlterError  DESCRIPTION  : Prints out an error message reflecting                   that a generic function's methods                   cannot be altered while any of them                   are executing  INPUTS       : The generic function  RETURNS      : Nothing useful  SIDE EFFECTS : None  NOTES        : None ********************************************************/globle void MethodAlterError(  void *theEnv,  DEFGENERIC *gfunc)  {   PrintErrorID(theEnv,"GENRCFUN",1,FALSE);   EnvPrintRouter(theEnv,WERROR,"Defgeneric ");   EnvPrintRouter(theEnv,WERROR,EnvGetDefgenericName(theEnv,(void *) gfunc));   EnvPrintRouter(theEnv,WERROR," cannot be modified while one of its methods is executing.\n");  }/***************************************************  NAME         : DeleteMethodInfo  DESCRIPTION  : Deallocates all the data associated                  w/ a method but does not release                  the method structure itself  INPUTS       : 1) The generic function address                 2) The method address  RETURNS      : Nothing useful  SIDE EFFECTS : Nodes deallocated  NOTES        : None ***************************************************/globle void DeleteMethodInfo(  void *theEnv,  DEFGENERIC *gfunc,  DEFMETHOD *meth)  {   short j,k;   RESTRICTION *rptr;   SaveBusyCount(gfunc);   ExpressionDeinstall(theEnv,meth->actions);   ReturnPackedExpression(theEnv,meth->actions);   ClearUserDataList(theEnv,meth->usrData);   if (meth->ppForm != NULL)     rm(theEnv,(void *) meth->ppForm,(sizeof(char) * (strlen(meth->ppForm)+1)));   for (j = 0 ; j < meth->restrictionCount ; j++)     {      rptr = &meth->restrictions[j];      for (k = 0 ; k < rptr->tcnt ; k++)#if OBJECT_SYSTEM        DecrementDefclassBusyCount(theEnv,rptr->types[k]);#else        DecrementIntegerCount(theEnv,(INTEGER_HN *) rptr->types[k]);#endif      if (rptr->types != NULL)        rm(theEnv,(void *) rptr->types,(sizeof(void *) * rptr->tcnt));      ExpressionDeinstall(theEnv,rptr->query);      ReturnPackedExpression(theEnv,rptr->query);     }   if (meth->restrictions != NULL)     rm(theEnv,(void *) meth->restrictions,        (sizeof(RESTRICTION) * meth->restrictionCount));   RestoreBusyCount(gfunc);  }  /***************************************************  NAME         : DestroyMethodInfo  DESCRIPTION  : Deallocates all the data associated                  w/ a method but does not release                  the method structure itself  INPUTS       : 1) The generic function address                 2) The method address  RETURNS      : Nothing useful  SIDE EFFECTS : Nodes deallocated  NOTES        : None ***************************************************/#if IBM_TBC#pragma argsused#endifgloble void DestroyMethodInfo(  void *theEnv,  DEFGENERIC *gfunc,  DEFMETHOD *meth)  {   register int j;   register RESTRICTION *rptr;#if MAC_MCW || IBM_MCW || MAC_XCD#pragma unused(gfunc)#endif   ReturnPackedExpression(theEnv,meth->actions);      ClearUserDataList(theEnv,meth->usrData);   if (meth->ppForm != NULL)     rm(theEnv,(void *) meth->ppForm,(sizeof(char) * (strlen(meth->ppForm)+1)));   for (j = 0 ; j < meth->restrictionCount ; j++)     {      rptr = &meth->restrictions[j];      if (rptr->types != NULL)        rm(theEnv,(void *) rptr->types,(sizeof(void *) * rptr->tcnt));      ReturnPackedExpression(theEnv,rptr->query);     }   if (meth->restrictions != NULL)     rm(theEnv,(void *) meth->restrictions,        (sizeof(RESTRICTION) * meth->restrictionCount));  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品污www在线观看| 欧美视频一区在线观看| 日韩成人av影视| 亚洲国产美女搞黄色| 国产精品高潮呻吟久久| 国产欧美日韩卡一| 国产女人水真多18毛片18精品视频 | 精品久久人人做人人爽| 日韩片之四级片| 精品国产一区二区三区忘忧草| 日韩欧美电影一二三| 欧美变态tickle挠乳网站| 精品福利av导航| 国产精品欧美一级免费| 亚洲欧美区自拍先锋| 有码一区二区三区| 日本大胆欧美人术艺术动态| 久久国产剧场电影| 成人国产亚洲欧美成人综合网| 91在线观看视频| 欧美精品第1页| 久久久久久黄色| 亚洲最新在线观看| 喷水一区二区三区| 成人久久18免费网站麻豆| 日本二三区不卡| 精品美女在线观看| 一片黄亚洲嫩模| 美国毛片一区二区| 高清成人在线观看| 欧美美女视频在线观看| 欧美国产日本韩| 亚洲国产精品自拍| 国产经典欧美精品| 在线一区二区三区四区五区| 欧美一区二区三区性视频| 久久精品网站免费观看| 性做久久久久久免费观看欧美| 国产精选一区二区三区| 欧美性高清videossexo| 国产精品午夜春色av| 日韩avvvv在线播放| 91看片淫黄大片一级在线观看| 欧美日本一道本| 综合久久久久久久| 国产一区二区看久久| 欧美日韩成人一区二区| 亚洲三级在线看| 国产一区二区导航在线播放| 欧美在线色视频| 国产精品不卡在线| 国产麻豆午夜三级精品| 91精品国产欧美日韩| 亚洲黄色录像片| 99国产精品视频免费观看| www国产成人免费观看视频 深夜成人网| 亚洲激情五月婷婷| 91在线看国产| 欧美韩国日本综合| 国产制服丝袜一区| 精品成人免费观看| 精品亚洲porn| 精品国产区一区| 美女视频黄免费的久久| 91精品久久久久久久91蜜桃| 午夜影视日本亚洲欧洲精品| 色哟哟日韩精品| 亚洲美女视频一区| 91福利国产成人精品照片| 国产色一区二区| 国产一区欧美二区| 精品成人a区在线观看| 久久99国内精品| 2023国产精品| 国产成人午夜99999| 国产亚洲欧美一级| 国产成人综合亚洲网站| 国产精品免费av| 91在线国产观看| 亚洲国产aⅴ成人精品无吗| 欧美另类变人与禽xxxxx| 日韩精品福利网| 日韩久久精品一区| 国产美女视频一区| 国产精品黄色在线观看| 色综合天天性综合| 亚洲综合色成人| 91精品国产综合久久香蕉的特点| 免费看欧美女人艹b| 久久―日本道色综合久久| 国产精品一区三区| 亚洲国产cao| 日韩欧美亚洲一区二区| 经典一区二区三区| 专区另类欧美日韩| 欧美日韩高清不卡| 国产精选一区二区三区| 亚洲乱码精品一二三四区日韩在线| 色老综合老女人久久久| 日本中文字幕不卡| 国产午夜精品久久久久久久| 在线观看av不卡| 久草中文综合在线| 亚洲精品日日夜夜| 日韩一区二区三区视频| 成人av电影在线观看| 亚洲欧美日韩国产综合| 日韩免费在线观看| 91玉足脚交白嫩脚丫在线播放| 午夜精品在线看| 国产精品色哟哟| 日韩一区二区三区观看| 99re在线精品| 麻豆一区二区在线| 亚洲专区一二三| 国产三级欧美三级日产三级99| 91久久一区二区| 国产一区二区在线视频| 亚洲国产成人av网| 国产精品毛片久久久久久久| 777久久久精品| 99久久精品费精品国产一区二区| 美女看a上一区| 夜夜操天天操亚洲| 国产精品污污网站在线观看| 欧美成va人片在线观看| 欧美色图在线观看| 北条麻妃国产九九精品视频| 蜜臀av一区二区| 亚洲福利一区二区| 综合欧美一区二区三区| 国产欧美日韩视频在线观看| 日韩一区二区在线播放| 欧美午夜精品电影| 97se亚洲国产综合自在线| 国产成人免费视频网站高清观看视频| 天天综合色天天综合色h| 夜夜夜精品看看| 亚洲人成人一区二区在线观看 | 欧美乱熟臀69xxxxxx| www.亚洲色图.com| 成人理论电影网| 国产成人精品免费一区二区| 国产综合色在线视频区| 精品一区二区在线看| 蜜臀av性久久久久蜜臀aⅴ| 亚洲第一成人在线| 亚洲6080在线| 亚洲成在人线在线播放| 一二三四区精品视频| 亚洲一区二区高清| 亚洲成人精品影院| 亚洲成人av资源| 日韩国产一二三区| 日本成人在线视频网站| 日韩精品成人一区二区在线| 午夜精品福利视频网站| 日韩国产在线一| 免费三级欧美电影| 国产精品一区二区久激情瑜伽| 激情综合色综合久久综合| 精品一区二区三区在线观看 | 国产成人精品www牛牛影视| 成人午夜又粗又硬又大| www.亚洲在线| 欧美性色黄大片| 欧美一区二区三区免费大片 | 亚洲成人综合网站| 麻豆国产精品一区二区三区 | 丁香桃色午夜亚洲一区二区三区| 国产一区不卡在线| 99精品视频中文字幕| 91亚洲精品乱码久久久久久蜜桃| 色爱区综合激月婷婷| 欧美一区二区网站| 久久精品在这里| 亚洲一本大道在线| 精品在线播放午夜| 色欧美日韩亚洲| 精品少妇一区二区三区视频免付费| 久久男人中文字幕资源站| 亚洲欧美区自拍先锋| 免费看日韩精品| 色综合久久综合中文综合网| 91精品欧美久久久久久动漫| 一区二区三区四区视频精品免费| 亚洲国产一区在线观看| 国产一区二区三区综合| 91蝌蚪porny成人天涯| 欧美成人精精品一区二区频| 国产精品久久久久久久久果冻传媒| 亚洲h在线观看| aaa亚洲精品| 久久女同精品一区二区| 亚洲国产成人av好男人在线观看| 国产精品一区二区在线观看不卡| 欧美日韩精品免费| 亚洲欧洲制服丝袜| 国产一区二区在线影院| 欧美日韩国产在线播放网站|