Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 583

•  TDictionary Custom Sort  6 599

•  Fast Watermark Sources  6 369

•  3D Designer  9 319

•  Sik Screen Capture  6 703

•  Patch Maker  7 084

•  Айболит (remote control)  7 088

•  ListBox Drag & Drop  5 955

•  Доска для игры Реверси  97 496

•  Графические эффекты  7 290

•  Рисование по маске  6 584

•  Перетаскивание изображений  5 457

•  Canvas Drawing  5 826

•  Рисование Луны  5 537

•  Поворот изображения  5 058

•  Рисование стержней  3 623

•  Paint on Shape  2 864

•  Генератор кроссвордов  3 750

•  Головоломка Paletto  3 019

•  Теорема Монжа об окружностях  3 828

•  Пазл Numbrix  2 519

•  Заборы и коммивояжеры  3 219

•  Игра HIP  2 186

•  Игра Go (Го)  2 117

•  Симулятор лифта  2 499

•  Программа укладки плитки  2 149

•  Генератор лабиринта  2 633

•  Проверка числового ввода  2 303

•  HEX View  2 635

•  Физический маятник  2 255

 
скрыть

Использование TParser



Автор: Mike Scott

Вы просили пример кода использования TParser. Хорошо, вот несколько процедур для модуля Parser для создания документации Delphi-компонент напрямую из исходного кода.

TDelphiUnitParser - подкласс со специфическими методами, позволяющими парсировать секцию Interface модуля Delphi. Вы можете не использовать этого наследника TParser в вашем коде - это просто иллюстрация того, как можно использовать некоторые свойства и методы TParser. Присылайте мне другие ваши решения по этому вопросу.


{ TDelphiUnitParser }

function TDelphiUnitParser.CheckSectionBreak: Boolean;
begin
  with Parser do
  begin
    Result := (Token = toSymbol) and
      (Compare('Var') or
      Compare('Const') or
      Compare('Type') or
      Compare('Implementation') or
      Compare('Procedure') or
      Compare('Function'));
  end;
end;

procedure TDelphiUnitParser.ParseParameterList;
begin
  with Parser do
  begin
    { пропускаем '(' }
    NextToken;
    while Token <> ')' do
      NextToken;
    NextToken;
  end;
end;

procedure TDelphiUnitParser.ParseRecord;
begin
  with Parser do
  begin
    { пропускаем 'record' }
    NextToken;
    while (Token <> toSymbol) or not Compare('End') do
    begin
      if Token = 'Record' then
        ParseRecord
      else
        NextToken;
    end;
  end;
end;

procedure TDelphiUnitParser.ParseDeclaration;
begin
  with Parser do
  begin
    while Token <> ';' do
    begin
      if Token = '(' then
        ParseParameterList
      else if (Token = toSymbol) and Compare('Record') then
        ParseRecord
      else
        NextToken;
    end;
  end;
end;

procedure TDelphiUnitParser.ParseConst;
var
  AString: string;
  AStart: PChar;
  EndOfConsts: Boolean;
begin
  with Parser do
  begin
    NextToken;
    repeat
      if Token <> toSymbol then
        ErrorStr('Неопознанный идентификатор');
      AString := TokenString;
      AStart := FSourcePtr;
      NextToken;
      if not (Token in ['=', ':']) then
        ErrorStr('''='' or '':''
          ожидалось' ) ;

          ParseDeclaration;
          FindToken(';');
    until CheckSectionBreak;
  end;
end;