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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? prcdrpsr.c

?? clips源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
   /*******************************************************/   /*      "C" Language Integrated Production System      */   /*                                                     */   /*             CLIPS Version 6.24  06/05/06            */   /*                                                     */   /*          PROCEDURAL FUNCTIONS PARSER MODULE         */   /*******************************************************//*************************************************************//* Purpose:                                                  *//*                                                           *//* Principal Programmer(s):                                  *//*      Gary D. Riley                                        *//*      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: Renamed BOOLEAN macro type to intBool.         *//*                                                           *//*************************************************************/#define _PRCDRPSR_SOURCE_#include <stdio.h>#define _STDIO_INCLUDED_#include "setup.h"#include "argacces.h"#include "constrnt.h"#include "cstrnchk.h"#include "cstrnops.h"#include "cstrnutl.h"#include "envrnmnt.h"#include "exprnpsr.h"#include "memalloc.h"#include "modulutl.h"#include "multifld.h"#include "router.h"#include "scanner.h"#include "utility.h"#include "prcdrpsr.h"#if DEFGLOBAL_CONSTRUCT#include "globldef.h"#include "globlpsr.h"#endif#if ! RUN_TIME#define PRCDRPSR_DATA 12struct procedureParserData  {    struct BindInfo *ListOfParsedBindNames;  };#define ProcedureParserData(theEnv) ((struct procedureParserData *) GetEnvironmentData(theEnv,PRCDRPSR_DATA))#endif/***************************************//* LOCAL INTERNAL FUNCTION DEFINITIONS *//***************************************/#if (! RUN_TIME) && (! BLOAD_ONLY)   static struct expr            *WhileParse(void *,struct expr *,char *);   static struct expr            *LoopForCountParse(void *,struct expr *,char *);   static void                    ReplaceLoopCountVars(void *,SYMBOL_HN *,EXPRESSION *,int);   static struct expr            *IfParse(void *,struct expr *,char *);   static struct expr            *PrognParse(void *,struct expr *,char *);   static struct expr            *BindParse(void *,struct expr *,char *);   static int                     AddBindName(void *,struct symbolHashNode *,CONSTRAINT_RECORD *);   static struct expr            *ReturnParse(void *,struct expr *,char *);   static struct expr            *BreakParse(void *,struct expr *,char *);   static struct expr            *SwitchParse(void *,struct expr *,char *);   static void                    DeallocateProceduralFunctionData(void *);#endif#if ! RUN_TIME/*******************************************//* ProceduralFunctionParsers        *//*******************************************/globle void ProceduralFunctionParsers(  void *theEnv)  {   AllocateEnvironmentData(theEnv,PRCDRPSR_DATA,sizeof(struct procedureParserData),DeallocateProceduralFunctionData);#if (! BLOAD_ONLY)   AddFunctionParser(theEnv,"bind",BindParse);   AddFunctionParser(theEnv,"progn",PrognParse);   AddFunctionParser(theEnv,"if",IfParse);   AddFunctionParser(theEnv,"while",WhileParse);   AddFunctionParser(theEnv,"loop-for-count",LoopForCountParse);   AddFunctionParser(theEnv,"return",ReturnParse);   AddFunctionParser(theEnv,"break",BreakParse);   AddFunctionParser(theEnv,"switch",SwitchParse);#endif  }/*************************************************************//* DeallocateProceduralFunctionData: Deallocates environment *//*    data for procedural functions.                         *//*************************************************************/static void DeallocateProceduralFunctionData(  void *theEnv)  {    struct BindInfo *temp_bind;   while (ProcedureParserData(theEnv)->ListOfParsedBindNames != NULL)     {      temp_bind = ProcedureParserData(theEnv)->ListOfParsedBindNames->next;      rtn_struct(theEnv,BindInfo,ProcedureParserData(theEnv)->ListOfParsedBindNames);      ProcedureParserData(theEnv)->ListOfParsedBindNames = temp_bind;     }  }/********************************************************//* GetParsedBindNames:                                      *//********************************************************/globle struct BindInfo *GetParsedBindNames(  void *theEnv)  {   return(ProcedureParserData(theEnv)->ListOfParsedBindNames);  }/********************************************************//* SetParsedBindNames:                                      *//********************************************************/globle void SetParsedBindNames(  void *theEnv,  struct BindInfo *newValue)  {   ProcedureParserData(theEnv)->ListOfParsedBindNames = newValue;  }/********************************************************//* ClearParsedBindNames:                                     *//********************************************************/globle void ClearParsedBindNames(  void *theEnv)  {   struct BindInfo *temp_bind;   while (ProcedureParserData(theEnv)->ListOfParsedBindNames != NULL)     {      temp_bind = ProcedureParserData(theEnv)->ListOfParsedBindNames->next;      RemoveConstraint(theEnv,ProcedureParserData(theEnv)->ListOfParsedBindNames->constraints);      rtn_struct(theEnv,BindInfo,ProcedureParserData(theEnv)->ListOfParsedBindNames);      ProcedureParserData(theEnv)->ListOfParsedBindNames = temp_bind;     }  }/********************************************************//* ParsedBindNamesEmpty:                                     *//********************************************************/globle intBool ParsedBindNamesEmpty(  void *theEnv)  {   if (ProcedureParserData(theEnv)->ListOfParsedBindNames != NULL) return(FALSE);   return(TRUE);  }#if (! BLOAD_ONLY)/*********************************************************//* WhileParse: purpose is to parse the while statement.  *//*   The parse of the statement is the return value.     *//*   Syntax: (while <expression> do <action>+)           *//*********************************************************/static struct expr *WhileParse(  void *theEnv,  struct expr *parse,  char *infile)  {   struct token theToken;   int read_first_paren;   /*===============================*/   /* Process the while expression. */   /*===============================*/   SavePPBuffer(theEnv," ");   parse->argList = ParseAtomOrExpression(theEnv,infile,NULL);   if (parse->argList == NULL)     {      ReturnExpression(theEnv,parse);      return(NULL);     }   /*====================================*/   /* Process the do keyword if present. */   /*====================================*/   GetToken(theEnv,infile,&theToken);   if ((theToken.type == SYMBOL) && (strcmp(ValueToString(theToken.value),"do") == 0))     {      read_first_paren = TRUE;      PPBackup(theEnv);      SavePPBuffer(theEnv," ");      SavePPBuffer(theEnv,theToken.printForm);      IncrementIndentDepth(theEnv,3);      PPCRAndIndent(theEnv);     }   else if (theToken.type == LPAREN)     {      read_first_paren = FALSE;      PPBackup(theEnv);      IncrementIndentDepth(theEnv,3);      PPCRAndIndent(theEnv);      SavePPBuffer(theEnv,theToken.printForm);     }   else     {      SyntaxErrorMessage(theEnv,"while function");      ReturnExpression(theEnv,parse);      return(NULL);     }   /*============================*/   /* Process the while actions. */   /*============================*/   if (ExpressionData(theEnv)->svContexts->rtn == TRUE)     ExpressionData(theEnv)->ReturnContext = TRUE;   ExpressionData(theEnv)->BreakContext = TRUE;   parse->argList->nextArg = GroupActions(theEnv,infile,&theToken,read_first_paren,NULL,FALSE);   if (parse->argList->nextArg == NULL)     {      ReturnExpression(theEnv,parse);      return(NULL);     }   PPBackup(theEnv);   PPBackup(theEnv);   SavePPBuffer(theEnv,theToken.printForm);   /*=======================================================*/   /* Check for the closing right parenthesis of the while. */   /*=======================================================*/   if (theToken.type != RPAREN)     {      SyntaxErrorMessage(theEnv,"while function");      ReturnExpression(theEnv,parse);      return(NULL);     }   DecrementIndentDepth(theEnv,3);   return(parse);  }/******************************************************************************************//* LoopForCountParse: purpose is to parse the loop-for-count statement.                   *//*   The parse of the statement is the return value.                                      *//*   Syntax: (loop-for-count <range> [do] <action>+)                                      *//*           <range> ::= (<sf-var> [<start-integer-expression>] <end-integer-expression>) *//******************************************************************************************/static struct expr *LoopForCountParse(  void *theEnv,  struct expr *parse,  char *infile)  {   struct token theToken;   SYMBOL_HN *loopVar = NULL;   EXPRESSION *tmpexp;   int read_first_paren;   struct BindInfo *oldBindList,*newBindList,*prev;   /*======================================*/   /* Process the loop counter expression. */   /*======================================*/   SavePPBuffer(theEnv," ");   GetToken(theEnv,infile,&theToken);   /* ==========================================      Simple form: loop-for-count <end> [do] ...      ========================================== */   if (theToken.type != LPAREN)     {      parse->argList = GenConstant(theEnv,INTEGER,EnvAddLong(theEnv,1LL));      parse->argList->nextArg = ParseAtomOrExpression(theEnv,infile,&theToken);      if (parse->argList->nextArg == NULL)        {         ReturnExpression(theEnv,parse);         return(NULL);        }     }   else     {      GetToken(theEnv,infile,&theToken);      if (theToken.type != SF_VARIABLE)        {         if (theToken.type != SYMBOL)           goto LoopForCountParseError;         parse->argList = GenConstant(theEnv,INTEGER,EnvAddLong(theEnv,1LL));         parse->argList->nextArg = Function2Parse(theEnv,infile,ValueToString(theToken.value));         if (parse->argList->nextArg == NULL)           {            ReturnExpression(theEnv,parse);            return(NULL);           }        }      /* =============================================================         Complex form: loop-for-count (<var> [<start>] <end>) [do] ...         ============================================================= */      else        {         loopVar = (SYMBOL_HN *) theToken.value;         SavePPBuffer(theEnv," ");         parse->argList = ParseAtomOrExpression(theEnv,infile,NULL);         if (parse->argList == NULL)           {            ReturnExpression(theEnv,parse);            return(NULL);           }         if (CheckArgumentAgainstRestriction(theEnv,parse->argList,(int) 'i'))           goto LoopForCountParseError;         SavePPBuffer(theEnv," ");         GetToken(theEnv,infile,&theToken);         if (theToken.type == RPAREN)           {            PPBackup(theEnv);            PPBackup(theEnv);            SavePPBuffer(theEnv,theToken.printForm);            tmpexp = GenConstant(theEnv,INTEGER,EnvAddLong(theEnv,1LL));            tmpexp->nextArg = parse->argList;            parse->argList = tmpexp;           }         else          {            parse->argList->nextArg = ParseAtomOrExpression(theEnv,infile,&theToken);            if (parse->argList->nextArg == NULL)              {               ReturnExpression(theEnv,parse);               return(NULL);              }            GetToken(theEnv,infile,&theToken);            if (theToken.type != RPAREN)              goto LoopForCountParseError;           }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品伊人色| 久久色成人在线| 亚洲乱码国产乱码精品精可以看 | 欧美图片一区二区三区| 国产精品毛片大码女人| 国产激情视频一区二区三区欧美| 国产目拍亚洲精品99久久精品| 欧美影院一区二区三区| 欧美美女一区二区| 不卡视频免费播放| 亚洲电影一区二区三区| 色播五月激情综合网| 久久91精品国产91久久小草| 一区二区三区日韩在线观看| 国产精品水嫩水嫩| 五月天欧美精品| 亚洲综合清纯丝袜自拍| 亚洲欧美精品午睡沙发| 久久久国产午夜精品| 欧美一区二区三区视频免费播放| 国产毛片一区二区| 九一久久久久久| 欧美性色aⅴ视频一区日韩精品| 精品国产凹凸成av人导航| 欧美一区二区成人| 亚洲综合在线电影| 成人福利在线看| 2021久久国产精品不只是精品| 亚洲va国产天堂va久久en| av一二三不卡影片| 91首页免费视频| 在线免费观看成人短视频| 91精品国产麻豆国产自产在线 | 色狠狠综合天天综合综合| 亚洲国产精品精华液2区45| 国产视频一区在线播放| 1区2区3区国产精品| 日本欧美一区二区| 精品亚洲aⅴ乱码一区二区三区| 91精品国产色综合久久| 偷拍与自拍一区| 欧美一级一级性生活免费录像| 午夜影院久久久| 日韩免费性生活视频播放| 久久久久久97三级| 高清不卡一二三区| 欧美日韩大陆一区二区| 中文字幕精品一区 | 亚洲三级理论片| 精品一二三四区| 成人欧美一区二区三区视频网页| 99国产一区二区三精品乱码| 欧美一级免费观看| 久久香蕉国产线看观看99| 国产精品小仙女| 国产精品传媒视频| 成人av高清在线| 亚洲一二三区在线观看| 精品卡一卡二卡三卡四在线| 麻豆精品蜜桃视频网站| 国产福利视频一区二区三区| 夜夜揉揉日日人人青青一国产精品| 精品视频在线免费看| 亚洲尤物视频在线| 久久久久久久国产精品影院| 欧美日韩国产综合视频在线观看| 精品一区二区三区视频| 亚洲bt欧美bt精品777| 国产欧美日韩精品一区| 欧美日本一区二区| 色视频欧美一区二区三区| 18涩涩午夜精品.www| 国产亚洲自拍一区| 精品理论电影在线| 69av一区二区三区| 久久精品免费看| 精品少妇一区二区三区在线播放| 欧美午夜精品免费| 91色|porny| 欧美中文一区二区三区| 91视频在线看| 在线看日本不卡| 91福利在线免费观看| 色婷婷av久久久久久久| 99精品视频在线观看| 色综合夜色一区| 午夜欧美在线一二页| 亚洲国产精品麻豆| 亚洲国产精品影院| 免费欧美在线视频| 中文字幕免费一区| 中文字幕一区二| 亚洲一区二区3| 日本不卡高清视频| 国产精品亚洲午夜一区二区三区 | 尤物视频一区二区| 亚洲mv在线观看| 国产精品99久久久久久似苏梦涵 | 欧美激情一区二区三区在线| 亚洲人成人一区二区在线观看| 亚洲一区二区三区在线| 老司机精品视频在线| 9色porny自拍视频一区二区| 欧美在线|欧美| 久久久久久99久久久精品网站| 亚洲欧美自拍偷拍色图| 亚洲第一二三四区| 国产成人精品免费在线| 欧美日韩综合在线| 欧美国产一区视频在线观看| 亚洲图片欧美综合| 久久99精品久久久久久动态图| 91亚洲精品乱码久久久久久蜜桃 | 国产成人啪免费观看软件| 欧美三级日韩在线| 国产精品久久久久久久久免费相片| 亚洲第一福利一区| 97久久超碰精品国产| 欧美激情一区二区三区在线| 亚洲h精品动漫在线观看| 91视视频在线直接观看在线看网页在线看 | 在线播放中文一区| 亚洲欧美日韩国产中文在线| 不卡一区二区三区四区| 欧美精品一区二区三区蜜桃| 日韩福利视频网| 欧美午夜片在线看| 亚洲一级二级三级在线免费观看| 九色porny丨国产精品| 91麻豆精品国产91久久久| 亚洲va欧美va人人爽午夜| 91福利国产成人精品照片| 亚洲美女淫视频| 色婷婷久久久亚洲一区二区三区| 亚洲欧洲精品成人久久奇米网| 黑人巨大精品欧美黑白配亚洲| 国产精品自拍在线| 久久久精品人体av艺术| 国产一区二区精品久久91| 久久久久97国产精华液好用吗| 不卡一卡二卡三乱码免费网站| 日本一区二区动态图| 99re这里只有精品视频首页| 亚洲欧美激情在线| 日韩欧美黄色影院| 福利视频网站一区二区三区| 中文字幕一区二区三区不卡| 欧美色图激情小说| 久久av中文字幕片| 中文字幕一区二区三区av| 欧美高清一级片在线| 国内精品写真在线观看| 日韩美女啊v在线免费观看| 欧美日韩午夜在线视频| 国产综合久久久久久鬼色| 亚洲日本中文字幕区| 91精品国产综合久久香蕉的特点 | 久久综合五月天婷婷伊人| 色婷婷精品久久二区二区蜜臀av| 六月婷婷色综合| 麻豆一区二区三| 中文字幕日韩一区二区| 欧美一区二区三区小说| 在线精品视频免费观看| 成人免费看黄yyy456| 久久精品亚洲一区二区三区浴池| 欧美日韩一区二区在线观看| 国产成人综合精品三级| 强制捆绑调教一区二区| 亚洲成人中文在线| 午夜精品久久久久久久久久| 亚洲欧美日韩国产成人精品影院| 国产香蕉久久精品综合网| 日韩欧美中文字幕一区| 欧美一级久久久久久久大片| 69堂成人精品免费视频| 欧美裸体bbwbbwbbw| 制服.丝袜.亚洲.中文.综合| 欧美一区二区性放荡片| 欧美精品乱码久久久久久| 欧美肥妇free| 欧美刺激脚交jootjob| 久久综合色婷婷| 国产精品女同互慰在线看| 中文字幕亚洲不卡| 亚洲综合一区二区| 亚洲成人免费在线| 日本最新不卡在线| 国产a视频精品免费观看| 99久久99久久综合| 在线视频一区二区三| 欧美剧在线免费观看网站| 日韩欧美成人激情| 国产精品久久久久久久午夜片| 亚洲一区二区三区视频在线播放| 美国一区二区三区在线播放| 国产精品一线二线三线精华| 欧美性色黄大片手机版| 久久九九全国免费| 亚洲不卡av一区二区三区|