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

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

?? msgpsr.c

?? clips源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
   /*******************************************************/   /*      "C" Language Integrated Production System      */   /*                                                     */   /*               CLIPS Version 6.24  05/17/06          */   /*                                                     */   /*              MESSAGE-HANDLER PARSER FUNCTIONS       */   /*******************************************************//*************************************************************//* Purpose:                                                  *//*                                                           *//* Principal Programmer(s):                                  *//*      Brian L. Donnell                                     *//*                                                           *//* Contributing Programmer(s):                               *//*                                                           *//* Revision History:                                         *//*      6.23: Changed name of variable exp to theExp         *//*            because of Unix compiler warnings of shadowed  *//*            definitions.                                   *//*                                                           *//*      6.24: Removed IMPERATIVE_MESSAGE_HANDLERS            *//*                    compilation flag.                      *//*                                                           *//*            Renamed BOOLEAN macro type to intBool.         *//*                                                           *//*************************************************************//* =========================================   *****************************************               EXTERNAL DEFINITIONS   =========================================   ***************************************** */#include "setup.h"#if OBJECT_SYSTEM && (! BLOAD_ONLY) && (! RUN_TIME)#include <string.h>#if BLOAD || BLOAD_AND_BSAVE#include "bload.h"#endif#include "classcom.h"#include "classfun.h"#include "memalloc.h"#include "constrct.h"#include "cstrcpsr.h"#include "cstrnchk.h"#include "envrnmnt.h"#include "exprnpsr.h"#include "insfun.h"#include "msgcom.h"#include "msgfun.h"#include "pprint.h"#include "prccode.h"#include "router.h"#include "scanner.h"#include "strngrtr.h"#define _MSGPSR_SOURCE_#include "msgpsr.h"/* =========================================   *****************************************                   CONSTANTS   =========================================   ***************************************** */#define SELF_LEN         4#define SELF_SLOT_REF   ':'/* =========================================   *****************************************      INTERNALLY VISIBLE FUNCTION HEADERS   =========================================   ***************************************** */static intBool IsParameterSlotReference(void *,char *);static int SlotReferenceVar(void *,EXPRESSION *,void *);static int BindSlotReference(void *,EXPRESSION *,void *);static SLOT_DESC *CheckSlotReference(void *,DEFCLASS *,int,void *,intBool,EXPRESSION *);static void GenHandlerSlotReference(void *,EXPRESSION *,unsigned short,SLOT_DESC *);/* =========================================   *****************************************          EXTERNALLY VISIBLE FUNCTIONS   =========================================   ***************************************** *//***********************************************************************  NAME         : ParseDefmessageHandler  DESCRIPTION  : Parses a message-handler for a class of objects  INPUTS       : The logical name of the input source  RETURNS      : FALSE if successful parse, TRUE otherwise  SIDE EFFECTS : Handler allocated and inserted into class  NOTES        : H/L Syntax:                 (defmessage-handler <class> <name> [<type>] [<comment>]                    (<params>)                    <action>*)                 <params> ::= <var>* | <var>* $?<name> ***********************************************************************/globle int ParseDefmessageHandler(  void *theEnv,  char *readSource)  {   DEFCLASS *cls;   SYMBOL_HN *cname,*mname,*wildcard;   unsigned mtype = MPRIMARY;   int min,max,error,lvars;   EXPRESSION *hndParams,*actions;   HANDLER *hnd;   SetPPBufferStatus(theEnv,ON);   FlushPPBuffer(theEnv);   SetIndentDepth(theEnv,3);   SavePPBuffer(theEnv,"(defmessage-handler ");#if BLOAD || BLOAD_AND_BSAVE   if ((Bloaded(theEnv)) && (! ConstructData(theEnv)->CheckSyntaxMode))     {      CannotLoadWithBloadMessage(theEnv,"defmessage-handler");      return(TRUE);     }#endif   cname = GetConstructNameAndComment(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken,"defmessage-handler",                                      NULL,NULL,"~",TRUE,FALSE,TRUE);   if (cname == NULL)     return(TRUE);   cls = LookupDefclassByMdlOrScope(theEnv,ValueToString(cname));   if (cls == NULL)     {      PrintErrorID(theEnv,"MSGPSR",1,FALSE);      EnvPrintRouter(theEnv,WERROR,"A class must be defined before its message-handlers.\n");      return(TRUE);     }   if ((cls == DefclassData(theEnv)->PrimitiveClassMap[INSTANCE_NAME]) ||       (cls == DefclassData(theEnv)->PrimitiveClassMap[INSTANCE_ADDRESS]) ||       (cls == DefclassData(theEnv)->PrimitiveClassMap[INSTANCE_NAME]->directSuperclasses.classArray[0]))     {      PrintErrorID(theEnv,"MSGPSR",8,FALSE);      EnvPrintRouter(theEnv,WERROR,"Message-handlers cannot be attached to the class ");      EnvPrintRouter(theEnv,WERROR,EnvGetDefclassName(theEnv,(void *) cls));      EnvPrintRouter(theEnv,WERROR,".\n");      return(TRUE);     }   if (HandlersExecuting(cls))     {      PrintErrorID(theEnv,"MSGPSR",2,FALSE);      EnvPrintRouter(theEnv,WERROR,"Cannot (re)define message-handlers during execution of \n");      EnvPrintRouter(theEnv,WERROR,"  other message-handlers for the same class.\n");      return(TRUE);     }   if (GetType(DefclassData(theEnv)->ObjectParseToken) != SYMBOL)     {      SyntaxErrorMessage(theEnv,"defmessage-handler");      return(TRUE);     }   PPBackup(theEnv);   PPBackup(theEnv);   SavePPBuffer(theEnv," ");   SavePPBuffer(theEnv,DefclassData(theEnv)->ObjectParseToken.printForm);   SavePPBuffer(theEnv," ");   mname = (SYMBOL_HN *) GetValue(DefclassData(theEnv)->ObjectParseToken);   GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);   if (GetType(DefclassData(theEnv)->ObjectParseToken) != LPAREN)     {      SavePPBuffer(theEnv," ");      if (GetType(DefclassData(theEnv)->ObjectParseToken) != STRING)        {         if (GetType(DefclassData(theEnv)->ObjectParseToken) != SYMBOL)           {            SyntaxErrorMessage(theEnv,"defmessage-handler");            return(TRUE);           }         mtype = HandlerType(theEnv,"defmessage-handler",DOToString(DefclassData(theEnv)->ObjectParseToken));         if (mtype == MERROR)           return(TRUE);         GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);         if (GetType(DefclassData(theEnv)->ObjectParseToken) == STRING)           {            SavePPBuffer(theEnv," ");            GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);           }        }      else        {         SavePPBuffer(theEnv," ");         GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);        }     }   PPBackup(theEnv);   PPBackup(theEnv);   PPCRAndIndent(theEnv);   SavePPBuffer(theEnv,DefclassData(theEnv)->ObjectParseToken.printForm);   hnd = FindHandlerByAddress(cls,mname,mtype);   if (GetPrintWhileLoading(theEnv) && GetCompilationsWatch(theEnv))     {      EnvPrintRouter(theEnv,WDIALOG,"   Handler ");      EnvPrintRouter(theEnv,WDIALOG,ValueToString(mname));      EnvPrintRouter(theEnv,WDIALOG," ");      EnvPrintRouter(theEnv,WDIALOG,MessageHandlerData(theEnv)->hndquals[mtype]);      EnvPrintRouter(theEnv,WDIALOG,(char *) ((hnd == NULL) ? " defined.\n" : " redefined.\n"));     }   if ((hnd != NULL) ? hnd->system : FALSE)     {      PrintErrorID(theEnv,"MSGPSR",3,FALSE);      EnvPrintRouter(theEnv,WERROR,"System message-handlers may not be modified.\n");      return(TRUE);     }   hndParams = GenConstant(theEnv,SYMBOL,(void *) MessageHandlerData(theEnv)->SELF_SYMBOL);   hndParams = ParseProcParameters(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken,hndParams,                                    &wildcard,&min,&max,&error,IsParameterSlotReference);   if (error)     return(TRUE);   PPCRAndIndent(theEnv);   ExpressionData(theEnv)->ReturnContext = TRUE;   actions = ParseProcActions(theEnv,"message-handler",readSource,                              &DefclassData(theEnv)->ObjectParseToken,hndParams,wildcard,                              SlotReferenceVar,BindSlotReference,&lvars,                              (void *) cls);   if (actions == NULL)     {      ReturnExpression(theEnv,hndParams);      return(TRUE);     }   if (GetType(DefclassData(theEnv)->ObjectParseToken) != RPAREN)     {      SyntaxErrorMessage(theEnv,"defmessage-handler");      ReturnExpression(theEnv,hndParams);      ReturnPackedExpression(theEnv,actions);      return(TRUE);     }   PPBackup(theEnv);   PPBackup(theEnv);   SavePPBuffer(theEnv,DefclassData(theEnv)->ObjectParseToken.printForm);   SavePPBuffer(theEnv,"\n");   /* ===================================================      If we're only checking syntax, don't add the      successfully parsed defmessage-handler to the KB.      =================================================== */   if (ConstructData(theEnv)->CheckSyntaxMode)     {      ReturnExpression(theEnv,hndParams);      ReturnPackedExpression(theEnv,actions);      return(FALSE);     }   if (hnd != NULL)     {      ExpressionDeinstall(theEnv,hnd->actions);      ReturnPackedExpression(theEnv,hnd->actions);      if (hnd->ppForm != NULL)        rm(theEnv,(void *) hnd->ppForm,           (sizeof(char) * (strlen(hnd->ppForm)+1)));     }   else     {      hnd = InsertHandlerHeader(theEnv,cls,mname,(int) mtype);      IncrementSymbolCount(hnd->name);     }   ReturnExpression(theEnv,hndParams);   hnd->minParams = min;   hnd->maxParams = max;   hnd->localVarCount = lvars;   hnd->actions = actions;   ExpressionInstall(theEnv,hnd->actions);#if DEBUGGING_FUNCTIONS   /* ===================================================      Old handler trace status is automatically preserved      =================================================== */   if (EnvGetConserveMemory(theEnv) == FALSE)     hnd->ppForm = CopyPPBuffer(theEnv);   else#endif     hnd->ppForm = NULL;   return(FALSE);  }/*******************************************************************************  NAME         : CreateGetAndPutHandlers  DESCRIPTION  : Creates two message-handlers with                  the following syntax for the slot:                 (defmessage-handler <class> get-<slot-name> primary ()                    ?self:<slot-name>)                 For single-field slots:                 (defmessage-handler <class> put-<slot-name> primary (?value)                    (bind ?self:<slot-name> ?value))                 For multifield slots:                 (defmessage-handler <class> put-<slot-name> primary ($?value)                    (bind ?self:<slot-name> ?value))  INPUTS       : The class slot descriptor  RETURNS      : Nothing useful  SIDE EFFECTS : Message-handlers created  NOTES        : A put handler is not created for read-only slots *******************************************************************************/globle void CreateGetAndPutHandlers(  void *theEnv,  SLOT_DESC *sd)  {   char *className,*slotName;   size_t bufsz;   char *buf,*handlerRouter = "*** Default Public Handlers ***";   int oldPWL,oldCM;   char *oldRouter;   char *oldString;   long oldIndex;   if ((sd->createReadAccessor == 0) && (sd->createWriteAccessor == 0))     return;   className = ValueToString(sd->cls->header.name);   slotName = ValueToString(sd->slotName->name);   bufsz = (sizeof(char) * (strlen(className) + (strlen(slotName) * 2) + 80));   buf = (char *) gm2(theEnv,bufsz);   oldPWL = GetPrintWhileLoading(theEnv);   SetPrintWhileLoading(theEnv,FALSE);   oldCM = EnvSetConserveMemory(theEnv,TRUE);   if (sd->createReadAccessor)     {      gensprintf(buf,"%s get-%s () ?self:%s)",className,slotName,slotName);            oldRouter = RouterData(theEnv)->FastCharGetRouter;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲愉拍自拍另类高清精品| 99综合电影在线视频| 三级欧美韩日大片在线看| 亚洲视频每日更新| 亚洲激情成人在线| 亚洲一区二区三区四区在线免费观看| 一区二区三区在线观看动漫| 亚洲欧美欧美一区二区三区| 伊人性伊人情综合网| 亚洲国产综合在线| 午夜精品一区在线观看| 天天操天天干天天综合网| 丝袜亚洲另类欧美| 日本怡春院一区二区| 日本不卡的三区四区五区| 六月丁香婷婷久久| 国产一区二区视频在线| 国产精品123| aaa国产一区| 欧美亚一区二区| 7777精品伊人久久久大香线蕉完整版| 日韩免费一区二区| 国产婷婷色一区二区三区四区| 国产精品久久久久7777按摩| 亚洲色图欧洲色图婷婷| 丝袜亚洲精品中文字幕一区| 免费看日韩精品| 成人中文字幕电影| 色综合久久久久综合体| 欧美系列一区二区| 精品国产乱码久久久久久夜甘婷婷| 久久中文字幕电影| 中文字幕一区二区在线播放| 亚洲一区二区三区四区不卡| 老汉av免费一区二区三区 | 久久99精品久久久| 国产福利一区在线| 色诱视频网站一区| 欧美一级搡bbbb搡bbbb| 欧美高清在线精品一区| 亚洲精品菠萝久久久久久久| 奇米一区二区三区av| 大尺度一区二区| 欧美日韩另类国产亚洲欧美一级| 日韩精品一区二区三区在线| 国产精品久久久久毛片软件| 亚洲444eee在线观看| 国产精品夜夜嗨| 色天天综合久久久久综合片| 日韩欧美国产精品| ㊣最新国产の精品bt伙计久久| 性做久久久久久| 粉嫩高潮美女一区二区三区| 欧美日韩久久久| 国产精品久久久久aaaa樱花| 另类人妖一区二区av| 91网页版在线| 久久久精品蜜桃| 午夜精品久久久久久久蜜桃app| 国产高清亚洲一区| 欧美一区二区三区影视| 亚洲靠逼com| 国产一区啦啦啦在线观看| 欧美四级电影在线观看| 国产精品久久国产精麻豆99网站| 久久福利视频一区二区| 欧美日韩一区二区在线观看视频| 中文字幕国产一区| 麻豆国产欧美日韩综合精品二区 | 欧美三级午夜理伦三级中视频| 2017欧美狠狠色| 日韩精品色哟哟| 日本国产一区二区| 中国av一区二区三区| 日本中文字幕一区二区视频| av成人免费在线观看| 国产午夜精品一区二区三区四区| 日韩精品欧美精品| 欧美午夜一区二区| 亚洲人午夜精品天堂一二香蕉| 国内一区二区视频| 日韩限制级电影在线观看| 一区二区免费看| 色天天综合色天天久久| 亚洲欧美在线另类| 成人av资源在线观看| 国产日产欧美一区| 国产一区美女在线| 久久综合国产精品| 久久国产精品99久久人人澡| 884aa四虎影成人精品一区| 夜夜夜精品看看| 色婷婷av一区二区三区gif| 国产精品久久久久久久久搜平片 | 日本视频一区二区| 51久久夜色精品国产麻豆| 亚洲综合免费观看高清完整版在线 | 《视频一区视频二区| 成人午夜又粗又硬又大| 国产亚洲一区二区三区在线观看 | 欧美久久高跟鞋激| 天堂成人免费av电影一区| 欧美视频日韩视频| 午夜精品久久久久久久久久| 欧美日韩激情一区二区| 天堂蜜桃一区二区三区| 制服.丝袜.亚洲.中文.综合| 日韩电影网1区2区| 日韩欧美三级在线| 国产原创一区二区| 欧美激情资源网| 99re成人在线| 一区二区三区.www| 欧美区视频在线观看| 日韩成人dvd| 2023国产精品自拍| 成人国产一区二区三区精品| 亚洲日本va午夜在线影院| 欧美性生活一区| 日本麻豆一区二区三区视频| 亚洲精品一区二区在线观看| 国产成人精品网址| 亚洲欧美日韩一区二区 | 中文字幕日韩一区| 在线免费观看日本一区| 婷婷国产在线综合| 日韩精品一区二| 国产.欧美.日韩| 亚洲男人天堂av| 6080亚洲精品一区二区| 极品尤物av久久免费看| 国产精品伦一区| 欧美性大战久久久| 国产在线一区二区| 亚洲欧美日韩国产另类专区| 在线成人免费视频| 国产福利一区二区三区在线视频| 亚洲视频你懂的| 欧美一级理论性理论a| 丁香婷婷综合色啪| 亚洲一区二区三区视频在线播放| 日韩欧美色综合网站| 99久久99久久精品国产片果冻| 亚洲妇女屁股眼交7| 久久久久九九视频| 色激情天天射综合网| 久久国产尿小便嘘嘘| 亚洲欧美色一区| 精品美女在线播放| 在线观看视频一区二区欧美日韩| 美腿丝袜一区二区三区| 亚洲人成影院在线观看| 精品日韩一区二区三区| 色综合天天做天天爱| 久久99这里只有精品| 一区二区欧美视频| 久久精品一区四区| 欧美日韩成人综合在线一区二区| 国产另类ts人妖一区二区| 亚洲一区免费观看| 国产精品热久久久久夜色精品三区| 欧美日韩亚洲不卡| 不卡的电视剧免费网站有什么| 丝袜美腿亚洲色图| ...av二区三区久久精品| 欧美videossexotv100| 在线观看亚洲精品视频| 风间由美一区二区av101| 日本成人在线一区| 一区二区不卡在线播放| 久久久99精品久久| 日韩欧美中文字幕精品| 91国内精品野花午夜精品| 粉嫩av亚洲一区二区图片| 日本不卡一二三| 亚洲123区在线观看| 亚洲欧洲另类国产综合| 久久久久久久久久久久久女国产乱| 在线播放一区二区三区| 日本久久电影网| 成人av午夜影院| 国产黄色精品网站| 韩国欧美一区二区| 蜜桃精品视频在线| 天天色天天爱天天射综合| 一级特黄大欧美久久久| 亚洲人成网站色在线观看| 国产精品超碰97尤物18| 国产亚洲欧美中文| 精品久久国产字幕高潮| 欧美大肚乱孕交hd孕妇| 3d动漫精品啪啪1区2区免费| 欧美日产国产精品| 欧美视频一区在线观看| 日本韩国欧美国产| 一本大道久久a久久精二百| 91啦中文在线观看| 91麻豆高清视频| 一本久道中文字幕精品亚洲嫩| 99九九99九九九视频精品|