Files
lazarus-ccr/bindings/pascocoa/parser/objcparser.pas

122 lines
2.5 KiB
ObjectPascal
Raw Normal View History

{
Project1.pas
Copyright (C) 2008 Dmitry 'Skalogryz' Boyarintsev
main parser unit
}
program Project1;
{$mode delphi}{$H+}
uses
Classes, SysUtils, ObjCParserUtils, ObjCParserTypes;
type
// this object is used only for precomile directives handling
TPrecompileHandler = class(TObject)
public
hdr : TObjCHeader;
procedure OnPrecompile(Sender: TObject);
constructor Create(AHeader: TObjCHeader);
end;
procedure TPrecompileHandler.OnPrecompile(Sender: TObject);
var
parser : TTextParser;
preEntity : TPrecompiler;
lst : TEntity;
prc : TNotifyEvent;
begin
parser := Sender as TTextParser;
//todo: change for something nicier =)
prc := parser.OnPrecompile;
parser.OnPrecompile := nil;
try
if parser.Stack.Count > 0 then
lst := TEntity(parser.Stack[parser.Stack.Count-1])
else
lst := nil;
preEntity := TPrecompiler.Create(lst);
preEntity.Parse(parser);
//writeln('added to: ', lst.ClassName, ' ', preEntity._Directive + preEntity._Params);
lst.Items.Add(preEntity);
//write('// debug: ');
//writeln('precompile: ', preEntity._Directive, ', params:', preEntity._Params);
finally
parser.OnPrecompile := prc;
end;
end;
constructor TPrecompileHandler.Create(AHeader: TObjCHeader);
begin
hdr := AHeader;
end;
procedure ReadAndParseFile(const FileName: AnsiString; outdata: TStrings);
var
hdr : TObjCHeader;
txt : TTextParser;
prec : TPrecompileHandler;
s : AnsiString;
begin
if not FileExists(FileName) then
Exit;
s := StrFromFile(FileName);
hdr := TObjCHeader.Create;
prec := TPrecompileHandler.Create(hdr);
txt := TTextParser.Create;
txt.TokenTable := CreateObjCTokenTable;
try
txt.Buf := s;
try
txt.TokenTable.Precompile := '#';
txt.OnPrecompile := prec.OnPrecompile;
hdr._FileName := ExtractFileName(FileName);
hdr.Parse(txt);
except
end;
WriteOutIncludeFile(hdr, outdata);
finally
hdr.Free;
txt.TokenTable.Free;
txt.Free;
prec.Free;
end;
end;
procedure GetParams(var InpFile, OutFile: AnsiString);
begin
InpFile := ParamStr(1);
OutFile := ParamStr(2);
end;
var
inpf : AnsiString;
f : Text;
st : TStrings;
fn : AnsiString;
i : integer;
begin
inpf := ParamStr(1);
if not FileExists(inpf) then begin
Exit;
end;
st := TStringList.Create;
try
ReadAndParseFile(inpf, st);
for i := 0 to st.Count - 1 do
writeln(st[i]);
except
end;
st.Free;
end.