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

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

?? zparser.pas

?? 一款由Zlib來的數學公式解析器
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
  while I < FVarCount do
  begin
    if FVars[I].VarName = VarName then
    begin
      Result := FVars[I].VarValue;
      Exit;
    end;
    Inc(I);
  end;
  Result := NULL;
end;

{ Set new value to variable }
procedure TZParser.SetVar(VarName: string; VarValue: Variant);
var
  I: Integer;
begin
  I := 0;
  VarName := AnsiUpperCase(VarName);
  while I < FVarCount do
  begin
    if FVars[I].VarName = VarName then
    begin
      if VarType(VarValue) <> varNull then
        FVars[I].VarValue := ConvType(VarValue);
      Exit;
    end;
    Inc(I);
  end;

  if I >= MAX_PARSE_VARS then Exit;
  FVars[I].VarName  := VarName;
  FVars[I].VarValue := ConvType(VarValue);
  Inc(FVarCount);
end;

{ Get function name by it handle }
function TZParser.GetFuncName(FuncIndex: Integer): string;
begin
  if FuncIndex >= FFuncCount then
    raise EParseException.Create(ResStr(SIncorFuncIdx));
  Result := FFuncs[FuncIndex].FuncName;
end;

{ Get function handle }
function TZParser.GetFunc(FuncName: string): TParseFunc;
var
  I: Integer;
begin
  FuncName := AnsiUpperCase(FuncName);
  for I := 0 to FFuncCount-1 do
    if UpperCase(FFuncs[I].FuncName) = FuncName then
    begin
      Result := FFuncs[I].FuncPtr;
      Exit;
    end;
  Result := nil;
end;

{ Set new function handle }
procedure TZParser.SetFunc(FuncName: string; FuncPtr: TParseFunc);
var
  I: Integer;
begin
  I := 0;
  FuncName := AnsiUpperCase(FuncName);
  while I < FFuncCount do
  begin
    if FFuncs[I].FuncName = FuncName then
    begin
      if Assigned(FuncPtr) then
        FFuncs[i].FuncPtr := FuncPtr;
      Exit;
    end;
    Inc(I);
  end;
  if I >= MAX_PARSE_FUNCS then Exit;
  FFuncs[I].FuncName := FuncName;
  FFuncs[I].FuncPtr  := FuncPtr;
  Inc(FFuncCount);
end;

{ Convert types of two variant values }
function TZParser.ConvType(Value: Variant): Variant;
begin
  case VarType(Value) of
    varByte, varSmallint, varInteger:
      Result := VarAsType(Value, varInteger);
    varSingle, varDouble, varCurrency:
      Result := VarAsType(Value, varDouble);
    varDate, varOleStr, varString, varVariant:
      Result := VarAsType(Value, varString);
    varBoolean:
      Result := Value;
    varNull:
      Result := VarAsType(0, varInteger);
    else
      raise EParseException.Create(ResStr(STypesMismatch));
  end;
end;

{ Convert types of two variant values }
procedure TZParser.CheckTypes(Value1: Variant; var Value2: Variant);
begin
  case VarType(Value1) of
    varInteger:
      if VarType(Value2) = varString then
        Value2 := StrToFloatEx(Value2)
      else
        Value2 := VarAsType(Value2, varInteger);
    varString:
        Value2 := VarAsType(Value2, varString);
    varDouble:
      if VarType(Value2) = varString then
        Value2 := StrToFloatEx(Value2)
      else
        Value2 := VarAsType(Value2, varDouble);
    varBoolean:
      case VarType(Value2) of
        varInteger, varDouble:
          Value2 := (Value2 <> 0);
        varString:
          Value2 := (StrToFloatEx(Value2) <> 0);
        varBoolean:
        else
          raise EParseException.Create(ResStr(STypesMismatch));
      end;
    else
      raise EParseException.Create(ResStr(STypesMismatch));
  end;
end;

{ Calculate an equation }
function TZParser.Evalute: Variant;
var
  I: Integer;
  Value1, Value2, Sgn: Variant;
  Op: string;
  FuncPtr: TParseFunc;
begin
  FStackCount := 0;
  for I := 0 to FParseCount-1 do
  begin
    case FParseItems[I].ItemType of
      ptFunction:
        begin
          FuncPtr := GetFunc(FParseItems[I].ItemValue);
          if Assigned(FuncPtr) then
            Push(FuncPtr(Self))
          else
            raise EParseException.CreateFmt(ResStr(SFuncNotFound),
              [FParseItems[I].ItemValue]);
        end;
      ptVariable:
        begin
          Value1 := GetVar(FParseItems[I].ItemValue);
          if VarType(Value1) = varNull then
            raise EParseException.CreateFmt(ResStr(SVarNotFound),
              [FParseItems[I].ItemValue]);
          Push(Value1);
        end;
      ptFloat, ptInteger, ptString, ptBoolean:
        Push(FParseItems[I].ItemValue);
      ptDelim:
        begin
          Op := VarAsType(FParseItems[I].ItemValue, varString);

          if Op[1] in ['+','-','*','/','%'] then
          begin
            Value2 := Pop;
            Value1 := Pop;
            CheckTypes(Value1, Value2);
            case Op[1] of
              '+': Push(Value1 + Value2);
              '-': Push(Value1 - Value2);
              '*': Push(Value1 * Value2);
              '/': Push(Value1 / Value2);
              '%': Push(Value1 mod Value2);
            end;
            Continue;
          end;

          if (Op = '=') or (Op = '<') or (Op = '>') then
          begin
            Value2 := Pop;
            Value1 := Pop;
            CheckTypes(Value1, Value2);
            case Op[1] of
              '=': Push(Value1 = Value2);
              '<': Push(Value1 < Value2);
              '>': Push(Value1 > Value2);
            end;
            Continue;
          end;

          if (Op = '>=') or (Op = '<=') or (Op = '<>') then
          begin
            Value2 := Pop;
            Value1 := Pop;
            CheckTypes(Value1, Value2);
            if Op='>=' then Push(Value1 >= Value2);
            if Op='<=' then Push(Value1 <= Value2);
            if Op='<>' then Push(Value1 <> Value2);
            Continue;
          end;

          if (Op = tokAND) or (Op = tokOR) or (Op = tokXOR) then
          begin
            Value1 := Pop;
            Value2 := Pop;
            if Op = tokAND then Push(Value1 and Value2);
            if Op = tokOR then  Push(Value1 or Value2);
            if Op = tokXOR then Push((not Value1 and Value2) or (Value1 and not Value2));
            Continue;
          end;

          if Op = '~' then
          begin
            Value1 := Pop;
            Push(-Value1);
            Continue;
          end;

          if Op = tokNOT then
          begin
            Value1 := Pop;
            CheckTypes(True, Value1);
            Push(not Value1);
            Continue;
          end;

          if Op = '^' then            
          begin
            Value2 := VarAsType(Pop,varDouble);
            Value1 := VarAsType(Pop,varDouble);
            if (Value1 < 0) and ((Value2 mod 2) = 1) then Sgn := -1
            else Sgn := 1;
            Push(Sgn*Power(Abs(Value1),Value2));
            Continue;
          end;

          if Op = tokLIKE then
          begin
            Value2 := VarAsType(Pop, varString);
            Value1 := VarAsType(Pop, varString);
            Push(IsMatch(Value2,Value1));
            Continue;
          end;

          raise EParseException.Create(ResStr(SIncorOperate));
        end;
    end;
  end;

  Result := Pop;
  if FStackCount > 0 then
    raise EParseException.Create(ResStr(SEvalError));
end;

{ Push value to stack }
procedure TZParser.Push(Value: Variant);
begin
  if FStackCount >= MAX_PARSE_STACK then
    raise EParseException.Create(ResStr(SStackFull));
  FParseStack[FStackCount] := Value;
  Inc(FStackCount);
end;

{ Pop value from stack }
function TZParser.Pop: Variant;
begin
  if FStackCount = 0 then
    raise EParseException.Create(ResStr(SStackEmpty));
  Dec(FStackCount);
  Result := FParseStack[FStackCount];
end;

{ Clear all variables and equation }
procedure TZParser.Clear;
begin
  FStackCount := 0;
  FParseCount := 0;
  FVarCount   := 0;
  FEquation   := '';
end;

{ Define function }
function TZParser.CheckFunc(var Buffer: string): Boolean;
var
  I: Integer;
  Token: string;
begin
  I := 1;
  Result := False;
  while (I <= Length(Buffer)) and (Buffer[I] in [' ',#9,#10,#13]) do
    Inc(I);
  if Buffer = '' then
    Exit;
  if Buffer[I] = '(' then
  begin
    Result := True;
    ExtractToken(Buffer, Token);
  end;
end;

{****************************************************}

{ Register component in component palette }
procedure Register;
begin
  RegisterComponents(ZEOS_PALETTE, [TZParser]);
end;

{************** User functions implementation **************}

{ Get current date and time }
function FuncNow(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 0 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokNOW]);
  Result := FormatDateTime('yyyy-mm-dd hh:nn:ss', Now());
end;

{ Get maximum value }
function FuncMax(Sender: TZParser): Variant;
var
  Count: Integer;
  Temp:  Variant;
begin
  Count := Sender.Pop;
  if Count = 0 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokMAX]);
  Result := Sender.Pop;
  Dec(Count);
  while Count > 0 do
  begin
    Temp := Sender.Pop;
    if Temp > Result then Result := Temp;
    Dec(Count);
  end;
end;

{ Get minimum value }
function FuncMin(Sender: TZParser): Variant;
var
  Count: Integer;
  Temp:  Variant;
begin
  Count := Sender.Pop;
  if Count = 0 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokMIN]);
  Result := Sender.Pop;
  Dec(Count);
  while Count > 0 do
  begin
    Temp := Sender.Pop;
    if Temp < Result then Result := Temp;
    Dec(Count);
  end;
end;

{ Calculate sum of values }
function FuncSum(Sender: TZParser): Variant;
var
  Count: Integer;
begin
  Count := Sender.Pop;
  if Count = 0 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokSUM]);
  Result := Sender.Pop;
  Dec(Count);
  while Count > 0 do
  begin
    Result := Result + Sender.Pop;
    Dec(Count);
  end;
end;

{ Get result by value }
function FuncIIf(Sender: TZParser): Variant;
var
  Count: Integer;
  Temp, Temp1, Temp2: Variant;
begin
  Count := Sender.Pop;
  if Count <> 3 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokIIF]);
  Temp2 := Sender.Pop;
  Temp1 := Sender.Pop;
  Temp := VarAsType(Sender.Pop, varBoolean);
  if Temp then Result := Temp1
  else Result := Temp2;
end;

{ Evalue sinus value }
function FuncSin(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokSIN]);
  Result := Sin(Sender.Pop);
end;

{ Evalue cosinus value }
function FuncCos(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokCOS]);
  Result := Cos(Sender.Pop);
end;

{ Evalue tangens value }
function FuncTan(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokTAN]);
  Result := Tan(Sender.Pop);
end;

{ Evalue exponent value }
function FuncExp(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokEXP]);
  Result := Exp(Sender.Pop);
end;

{ Evalue natural logoriphm value }
function FuncLn(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokLN]);
  Result := Ln(Sender.Pop);
end;

{ Evalue square root value }
function FuncSqrt(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokSQRT]);
  Result := Sqrt(Sender.Pop);
end;

{ Evalute absolute value }
function FuncAbs(Sender: TZParser): Variant;
begin
  Result := Sender.Pop;
  if Result <> 1 then
    EParseException.CreateFmt(ResStr(SIncorFuncParam),[tokABS]);
  Result := Abs(Sender.Pop);
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆国产精品官网| 91理论电影在线观看| 精品一区二区在线播放| 欧美久久久影院| 国产欧美精品国产国产专区 | 视频一区在线播放| 91精品国产综合久久久久久久| 天堂在线亚洲视频| 99re这里都是精品| 精品国产电影一区二区 | 国产一区二区91| 国产精品视频看| 在线观看一区日韩| 免费成人你懂的| 国产亚洲精品免费| 在线观看免费亚洲| 欧美极品aⅴ影院| 色婷婷亚洲婷婷| 欧美激情综合网| 国产成人在线免费| 精品国产伦一区二区三区观看方式 | 欧美中文字幕亚洲一区二区va在线| 精品国产1区2区3区| 粉嫩高潮美女一区二区三区| 欧美成人女星排名| 成人app在线| 天堂av在线一区| 国产日韩精品一区二区三区| 欧美中文字幕一区二区三区亚洲| 国产精品国产a| 在线播放91灌醉迷j高跟美女| 国产尤物一区二区在线| 亚洲精品久久久蜜桃| av福利精品导航| 美女一区二区三区在线观看| 最新热久久免费视频| 日韩欧美国产一区二区在线播放| 高清不卡一区二区| 国产精品美女久久久久aⅴ| 国产电影一区在线| 国产色综合一区| 成人精品一区二区三区四区| 爽好多水快深点欧美视频| 制服.丝袜.亚洲.中文.综合| 日韩高清一区在线| 亚洲欧美一区二区三区极速播放| 欧美一区二区三区在线观看视频 | 中文字幕亚洲电影| 欧美一级在线视频| 欧洲一区二区三区免费视频| 亚洲午夜久久久久久久久电影网| 久久久久久毛片| 欧美电影在线免费观看| 99精品视频在线播放观看| 亚洲精品日产精品乱码不卡| 亚洲精品一区二区在线观看| 91麻豆精品国产自产在线 | 在线区一区二视频| 丁香亚洲综合激情啪啪综合| 久久国产精品72免费观看| 久久久久久夜精品精品免费| 不卡的av在线播放| 国产精品一二三| 国产精品国产三级国产aⅴ原创| 成年人国产精品| 97精品久久久久中文字幕| 在线一区二区视频| 国产 日韩 欧美大片| 久久精品久久久精品美女| 午夜欧美视频在线观看| 亚洲一级电影视频| 亚洲精品自拍动漫在线| 日韩理论片中文av| 亚洲欧洲另类国产综合| 亚洲国产成人在线| 欧美三区在线观看| 欧美日韩精品一二三区| 欧美视频一二三区| 国产精品69毛片高清亚洲| 精品一区二区影视| 国产一区三区三区| 亚洲一区精品在线| 亚洲国产精品人人做人人爽| 亚洲资源在线观看| 欧美激情在线一区二区三区| 国产亚洲欧美激情| 中文字幕一区二区三区色视频| 5858s免费视频成人| 欧美一级久久久久久久大片| 97精品国产97久久久久久久久久久久| 蜜桃传媒麻豆第一区在线观看| 免费人成在线不卡| 麻豆视频观看网址久久| 伊人开心综合网| 午夜视频在线观看一区二区三区| 五月天欧美精品| 精品一区二区三区在线视频| 国产成人丝袜美腿| 色综合久久久久| 欧美日韩你懂得| 色综合色狠狠天天综合色| 欧美日韩亚州综合| 欧美哺乳videos| 国产精品国产三级国产普通话蜜臀| 日韩精品综合一本久道在线视频| 欧美精品一区二区三区蜜臀| 在线不卡中文字幕播放| 久久久久久久久久久久久女国产乱| 欧美日韩的一区二区| 精品黑人一区二区三区久久| 中文久久乱码一区二区| www成人在线观看| 欧美精品1区2区| 欧美日韩高清在线| 国产亚洲欧洲一区高清在线观看| 亚洲美女在线一区| 国产精品不卡在线| 日韩黄色小视频| 天天操天天干天天综合网| 国产一区二区三区香蕉 | 香蕉成人伊视频在线观看| 久久99国产精品久久99果冻传媒| 成人ar影院免费观看视频| 91精品国模一区二区三区| 国产精品丝袜91| 日韩国产欧美在线观看| 成人avav影音| 99视频在线精品| 日韩欧美国产不卡| 1024成人网| 国产乱码精品1区2区3区| 91国产免费观看| 国产日韩av一区| 蜜臀av一区二区在线免费观看 | 一区二区三区在线视频观看58| 日本不卡视频在线| 日本成人中文字幕| 波多野结衣一区二区三区 | 成年人网站91| 日本午夜精品一区二区三区电影| av在线免费不卡| 精品国产免费视频| 亚洲国产一区二区三区青草影视| 国产精品综合一区二区| 欧美喷潮久久久xxxxx| 亚洲欧美色一区| 亚洲精品免费看| 蜜臀av在线播放一区二区三区| 在线免费观看日本欧美| 国产精品乱人伦| 国产精品系列在线播放| 日韩欧美激情一区| 免费av成人在线| 成人精品鲁一区一区二区| 在线视频你懂得一区二区三区| 在线成人免费观看| 性欧美大战久久久久久久久| 91猫先生在线| 国产精品黄色在线观看| 国产精品一区专区| 精品久久人人做人人爰| 日本不卡中文字幕| 欧美老女人在线| 五月天亚洲婷婷| 欧美另类久久久品| 青椒成人免费视频| 99riav久久精品riav| 亚洲精品大片www| 中文字幕亚洲在| 亚洲国产一区二区三区| 欧美性大战久久久久久久| 一区二区三区成人| 欧美午夜片在线看| 精品三级在线看| 一区二区三区美女| 欧洲一区在线观看| 午夜精品视频在线观看| 欧美精品在欧美一区二区少妇| 国产欧美一区二区精品性色超碰| 国内精品免费**视频| 精品国产欧美一区二区| 国产**成人网毛片九色| 制服丝袜激情欧洲亚洲| 捆绑紧缚一区二区三区视频| 日韩欧美一二三| 亚洲婷婷综合久久一本伊一区| 亚洲二区在线观看| 福利一区二区在线观看| 欧美一区二区视频在线观看2022| 亚洲三级免费观看| 日本高清视频一区二区| 欧美—级在线免费片| 久久99最新地址| 欧美激情一区二区三区四区 | 中文子幕无线码一区tr| 成人午夜免费视频| 亚洲伦理在线精品| 欧美日本韩国一区二区三区视频| 国产欧美一区二区精品性| 亚洲成人动漫精品|