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

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

?? classpsr.c

?? clips源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
   /*******************************************************/   /*      "C" Language Integrated Production System      */   /*                                                     */   /*               CLIPS Version 6.24  07/01/05          */   /*                                                     */   /*                  CLASS PARSER MODULE                */   /*******************************************************//**************************************************************//* Purpose: Parsing Routines for Defclass Construct           *//*                                                            *//* Principal Programmer(s):                                   *//*      Brian L. Donnell                                      *//*                                                            *//* Contributing Programmer(s):                                *//*                                                            *//* Revision History:                                          *//*      6.24: Added allowed-classes slot facet.               *//*                                                            *//*            Converted INSTANCE_PATTERN_MATCHING to          *//*            DEFRULE_CONSTRUCT.                              *//*                                                            *//*            Renamed BOOLEAN macro type to intBool.          *//*                                                            *//**************************************************************//* =========================================   *****************************************               EXTERNAL DEFINITIONS   =========================================   ***************************************** */#include "setup.h"#if OBJECT_SYSTEM && (! BLOAD_ONLY) && (! RUN_TIME)#if BLOAD || BLOAD_AND_BSAVE#include "bload.h"#endif#include "classcom.h"#include "classfun.h"#include "clsltpsr.h"#include "cstrcpsr.h"#include "envrnmnt.h"#include "inherpsr.h"#include "memalloc.h"#include "modulpsr.h"#include "modulutl.h"#include "msgpsr.h"#include "router.h"#include "scanner.h"#define _CLASSPSR_SOURCE_#include "classpsr.h"/* =========================================   *****************************************                   CONSTANTS   =========================================   ***************************************** */#define ROLE_RLN             "role"#define ABSTRACT_RLN         "abstract"#define CONCRETE_RLN         "concrete"#define HANDLER_DECL         "message-handler"#define SLOT_RLN             "slot"#define SGL_SLOT_RLN         "single-slot"#define MLT_SLOT_RLN         "multislot"#define DIRECT               0#define INHERIT              1/* =========================================   *****************************************      INTERNALLY VISIBLE FUNCTION HEADERS   =========================================   ***************************************** */static intBool ValidClassName(void *,char *,DEFCLASS **);static intBool ParseSimpleQualifier(void *,char *,char *,char *,char *,intBool *,intBool *);static intBool ReadUntilClosingParen(void *,char *,struct token *);static void AddClass(void *,DEFCLASS *);static void BuildSubclassLinks(void *,DEFCLASS *);static void FormInstanceTemplate(void *,DEFCLASS *);static void FormSlotNameMap(void *,DEFCLASS *);static TEMP_SLOT_LINK *MergeSlots(void *,TEMP_SLOT_LINK *,DEFCLASS *,short *,int);static void PackSlots(void *,DEFCLASS *,TEMP_SLOT_LINK *);#if DEFMODULE_CONSTRUCTstatic void CreateClassScopeMap(void *,DEFCLASS *);#endifstatic void CreatePublicSlotMessageHandlers(void *,DEFCLASS *);/* =========================================   *****************************************          EXTERNALLY VISIBLE FUNCTIONS   =========================================   ***************************************** *//***************************************************************************************  NAME         : ParseDefclass  DESCRIPTION  : (defclass ...) is a construct (as                 opposed to a function), thus no variables                 may be used.  This means classes may only                 be STATICALLY defined (like rules).  INPUTS       : The logical name of the router                    for the parser input  RETURNS      : FALSE if successful parse, TRUE otherwise  SIDE EFFECTS : Inserts valid class definition into                 Class Table.  NOTES        : H/L Syntax :                 (defclass <name> [<comment>]                    (is-a <superclass-name>+)                    <class-descriptor>*)                 <class-descriptor> :== (slot <name> <slot-descriptor>*) |                                        (role abstract|concrete) |                                        (pattern-match reactive|non-reactive)                                        These are for documentation only:                                        (message-handler <name> [<type>])                 <slot-descriptor>  :== (default <default-expression>) |                                        (default-dynamic <default-expression>) |                                        (storage shared|local) |                                        (access read-only|read-write|initialize-only) |                                        (propagation no-inherit|inherit) |                                        (source composite|exclusive)                                        (pattern-match reactive|non-reactive)                                        (visibility public|private)                                        (override-message <message-name>)                                        (type ...) |                                        (cardinality ...) |                                        (allowed-symbols ...) |                                        (allowed-strings ...) |                                        (allowed-numbers ...) |                                        (allowed-integers ...) |                                        (allowed-floats ...) |                                        (allowed-values ...) |                                        (allowed-instance-names ...) |                                        (allowed-classes ...) |                                        (range ...)               <default-expression> ::= ?NONE | ?VARIABLE | <expression>*  ***************************************************************************************/globle int ParseDefclass(  void *theEnv,  char *readSource)  {   SYMBOL_HN *cname;   DEFCLASS *cls;   PACKED_CLASS_LINKS *sclasses,*preclist;   TEMP_SLOT_LINK *slots = NULL;   int roleSpecified = FALSE,       abstract = FALSE,       parseError;#if DEFRULE_CONSTRUCT   int patternMatchSpecified = FALSE,       reactive = TRUE;#endif   SetPPBufferStatus(theEnv,ON);   FlushPPBuffer(theEnv);   SetIndentDepth(theEnv,3);   SavePPBuffer(theEnv,"(defclass ");#if BLOAD || BLOAD_ONLY || BLOAD_AND_BSAVE   if ((Bloaded(theEnv)) && (! ConstructData(theEnv)->CheckSyntaxMode))     {      CannotLoadWithBloadMessage(theEnv,"defclass");      return(TRUE);     }#endif   cname = GetConstructNameAndComment(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken,"defclass",                                      EnvFindDefclass,NULL,"#",TRUE,                                      TRUE,TRUE);   if (cname == NULL)     return(TRUE);   if (ValidClassName(theEnv,ValueToString(cname),&cls) == FALSE)     return(TRUE);   sclasses = ParseSuperclasses(theEnv,readSource,cname);   if (sclasses == NULL)     return(TRUE);   preclist = FindPrecedenceList(theEnv,cls,sclasses);   if (preclist == NULL)     {      DeletePackedClassLinks(theEnv,sclasses,TRUE);      return(TRUE);     }   parseError = FALSE;   GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);   while (GetType(DefclassData(theEnv)->ObjectParseToken) != RPAREN)     {      if (GetType(DefclassData(theEnv)->ObjectParseToken) != LPAREN)        {         SyntaxErrorMessage(theEnv,"defclass");         parseError = TRUE;         break;        }      PPBackup(theEnv);      PPCRAndIndent(theEnv);      SavePPBuffer(theEnv,"(");      GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);      if (GetType(DefclassData(theEnv)->ObjectParseToken) != SYMBOL)        {         SyntaxErrorMessage(theEnv,"defclass");         parseError = TRUE;         break;        }      if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),ROLE_RLN) == 0)        {         if (ParseSimpleQualifier(theEnv,readSource,ROLE_RLN,CONCRETE_RLN,ABSTRACT_RLN,                                  &roleSpecified,&abstract) == FALSE)           {            parseError = TRUE;            break;           }        }#if DEFRULE_CONSTRUCT      else if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),MATCH_RLN) == 0)        {         if (ParseSimpleQualifier(theEnv,readSource,MATCH_RLN,NONREACTIVE_RLN,REACTIVE_RLN,                                  &patternMatchSpecified,&reactive) == FALSE)           {            parseError = TRUE;            break;           }        }#endif      else if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),SLOT_RLN) == 0)        {         slots = ParseSlot(theEnv,readSource,slots,preclist,FALSE,FALSE);         if (slots == NULL)           {            parseError = TRUE;            break;           }        }      else if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),SGL_SLOT_RLN) == 0)        {         slots = ParseSlot(theEnv,readSource,slots,preclist,FALSE,TRUE);         if (slots == NULL)           {            parseError = TRUE;            break;           }        }      else if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),MLT_SLOT_RLN) == 0)        {         slots = ParseSlot(theEnv,readSource,slots,preclist,TRUE,TRUE);         if (slots == NULL)           {            parseError = TRUE;            break;           }        }      else if (strcmp(DOToString(DefclassData(theEnv)->ObjectParseToken),HANDLER_DECL) == 0)        {         if (ReadUntilClosingParen(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken) == FALSE)           {            parseError = TRUE;            break;           }        }      else        {         SyntaxErrorMessage(theEnv,"defclass");         parseError = TRUE;         break;        }      GetToken(theEnv,readSource,&DefclassData(theEnv)->ObjectParseToken);     }   if ((GetType(DefclassData(theEnv)->ObjectParseToken) != RPAREN) || (parseError == TRUE))     {      DeletePackedClassLinks(theEnv,sclasses,TRUE);      DeletePackedClassLinks(theEnv,preclist,TRUE);      DeleteSlots(theEnv,slots);      return(TRUE);     }   SavePPBuffer(theEnv,"\n");   /* =========================================================================      The abstract/reactive qualities of a class are inherited if not specified      ========================================================================= */   if (roleSpecified == FALSE)     {      if (preclist->classArray[1]->system &&                             /* Change to cause         */           (DefclassData(theEnv)->ClassDefaultsMode == CONVENIENCE_MODE)) /* default role of         */        { abstract = FALSE; }                                            /* classes to be concrete. */      else        { abstract = preclist->classArray[1]->abstract; }     }#if DEFRULE_CONSTRUCT   if (patternMatchSpecified == FALSE)     {      if ((preclist->classArray[1]->system) &&                           /* Change to cause       */          (! abstract) &&                                                /* default pattern-match */           (DefclassData(theEnv)->ClassDefaultsMode == CONVENIENCE_MODE)) /* of classes to be      */        { reactive = TRUE; }                                             /* reactive.             */      else        { reactive = preclist->classArray[1]->reactive; }     }   /* ================================================================      An abstract class cannot have direct instances, thus it makes no      sense for it to be reactive since it will have no objects to

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品一区二区三区av| 欧美一区二区在线看| 中文字幕av一区二区三区免费看| 精品一区二区三区香蕉蜜桃| 精品三级av在线| 久久99蜜桃精品| 久久久久9999亚洲精品| 国产99久久久久久免费看农村| 国产亚洲综合性久久久影院| 成人激情小说乱人伦| 亚洲欧美另类小说| 欧美猛男gaygay网站| 色综合久久六月婷婷中文字幕| 中文字幕一区二区在线观看| 欧美撒尿777hd撒尿| 麻豆成人91精品二区三区| 久久日一线二线三线suv| 成人妖精视频yjsp地址| 亚洲午夜精品久久久久久久久| 91麻豆精品91久久久久同性| 久久成人久久爱| 成人欧美一区二区三区黑人麻豆 | 精品在线免费观看| 国产欧美一区二区三区鸳鸯浴 | 精品一区二区在线观看| 中文字幕国产一区| 欧美精品在线一区二区| 国产精品系列在线观看| 一区二区三区在线视频免费| 日韩一区二区视频| 成人高清伦理免费影院在线观看| 亚洲一区二区中文在线| 久久只精品国产| 色婷婷综合五月| 精品伊人久久久久7777人| 亚洲人午夜精品天堂一二香蕉| 日韩一区二区三区电影在线观看| 国产91精品露脸国语对白| 亚洲成人自拍一区| 国产女人水真多18毛片18精品视频| 欧美色手机在线观看| 国产精品一区不卡| 亚洲成人福利片| 国产精品三级视频| 91精品福利在线一区二区三区| eeuss国产一区二区三区| 久久草av在线| 性做久久久久久| 综合在线观看色| 国产日韩欧美精品综合| 日韩一区二区三区电影在线观看| 色婷婷久久99综合精品jk白丝| 国产精品乡下勾搭老头1| 麻豆精品视频在线观看免费| 久久成人麻豆午夜电影| 亚洲国产精品久久久久秋霞影院| 国产日产精品1区| 日韩久久久久久| 欧美人成免费网站| 在线观看亚洲精品| 91片在线免费观看| 成人黄色777网| 国产精品资源在线观看| 蜜臀精品久久久久久蜜臀| 亚洲综合久久久久| 亚洲日本在线a| 成人免费一区二区三区视频| 久久久久国产精品人| 精品日韩在线一区| 欧美成人精品高清在线播放| 69久久夜色精品国产69蝌蚪网 | 69久久99精品久久久久婷婷| 在线视频国产一区| 99视频一区二区| 99精品热视频| 成人精品视频.| 成人午夜电影网站| 成人午夜电影久久影院| 成人免费观看av| 99久久精品免费看国产| 91丨porny丨首页| 欧美四级电影网| 欧美欧美欧美欧美首页| 日韩一级大片在线观看| 精品人伦一区二区色婷婷| 日韩精品一区二区三区在线 | 欧美一区二区三区免费视频| 欧美另类久久久品| 在线不卡a资源高清| 欧美一区二区三区四区久久| 日韩一区二区三区四区| 精品国产青草久久久久福利| 久久午夜老司机| 日韩av电影一区| 美女被吸乳得到大胸91| 美国一区二区三区在线播放| 加勒比av一区二区| 顶级嫩模精品视频在线看| 波波电影院一区二区三区| 色狠狠色狠狠综合| 欧美日韩国产另类不卡| 欧美精品黑人性xxxx| 精品成人免费观看| 国产精品久久久久久福利一牛影视 | 亚洲一线二线三线视频| 午夜精品一区二区三区三上悠亚| 日本va欧美va精品发布| 精品一二线国产| www..com久久爱| 欧美性感一区二区三区| 日韩欧美在线影院| 亚洲国产精品高清| 亚洲国产欧美在线| 黑人巨大精品欧美一区| 99久久久精品免费观看国产蜜| 欧美卡1卡2卡| 国产拍揄自揄精品视频麻豆| 一区二区三区中文在线观看| 美日韩一区二区| 99久久婷婷国产精品综合| 欧美欧美欧美欧美| 国产精品视频看| 五月婷婷欧美视频| av激情亚洲男人天堂| 欧美夫妻性生活| 国产精品国产三级国产有无不卡 | 精品国产乱码久久久久久夜甘婷婷| 亚洲国产精品二十页| 日韩国产在线观看| 盗摄精品av一区二区三区| 欧美三日本三级三级在线播放| 国产精品萝li| 久久99国产精品麻豆| 色婷婷激情久久| 久久精品人人做人人爽人人| 亚洲国产精品视频| 99久久综合国产精品| 精品sm在线观看| 亚洲国产aⅴ天堂久久| 99综合电影在线视频| 久久亚区不卡日本| 天堂影院一区二区| 色88888久久久久久影院野外 | 亚洲国产岛国毛片在线| 日韩福利视频导航| 欧美性受xxxx黑人xyx| 国产精品的网站| 国产综合色视频| 欧美一区二区三区播放老司机| 亚洲伦理在线精品| 国产 欧美在线| 精品国产乱码久久久久久久久| 香蕉影视欧美成人| 色婷婷激情一区二区三区| 国产精品伦理一区二区| 激情综合一区二区三区| 日韩一区二区影院| 日本免费新一区视频| 欧美日韩激情一区二区三区| 亚洲精品视频一区| 99在线精品观看| 亚洲色图视频网| av综合在线播放| 亚洲视频一二三区| 99re在线视频这里只有精品| 国产精品久久国产精麻豆99网站| 高清不卡在线观看av| 国产精品少妇自拍| zzijzzij亚洲日本少妇熟睡| 国产精品久久久久久一区二区三区| 国内精品国产成人| 国产亚洲短视频| 丁香桃色午夜亚洲一区二区三区| 国产欧美一区二区精品性| 丁香五精品蜜臀久久久久99网站| 国产精品久久久一区麻豆最新章节| 国产成人精品亚洲777人妖| 欧美国产日韩在线观看| 99精品视频在线观看| 亚洲一区二区中文在线| 欧美精品v国产精品v日韩精品 | www激情久久| 久久国产精品99久久人人澡| 26uuu精品一区二区三区四区在线| 久久精品国产网站| 日本一区二区三区四区| 91麻豆国产自产在线观看| 一个色在线综合| 欧美福利一区二区| 国产一区二区三区在线观看免费视频 | 欧美国产日产图区| 色伊人久久综合中文字幕| 五月婷婷另类国产| 亚洲一区影音先锋| 91精品久久久久久久久99蜜臂| 久久精品国产亚洲高清剧情介绍 | www.亚洲色图.com| 一区二区三区在线视频观看| 欧美一区二区精美| 成人综合婷婷国产精品久久|