parser.pas 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727
  1. {
  2. $Id$
  3. Copyright (c) 1998-2000 by Florian Klaempfl
  4. This unit does the parsing process
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; either version 2 of the License, or
  8. (at your option) any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with this program; if not, write to the Free Software
  15. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  16. ****************************************************************************
  17. }
  18. unit parser;
  19. {$i defines.inc}
  20. interface
  21. {$ifdef PREPROCWRITE}
  22. procedure preprocess(const filename:string);
  23. {$endif PREPROCWRITE}
  24. procedure compile(const filename:string);
  25. procedure initparser;
  26. procedure doneparser;
  27. implementation
  28. uses
  29. cutils,cclasses,
  30. globtype,version,tokens,systems,globals,verbose,
  31. symbase,symtable,symdef,symsym,fmodule,fppu,aasm,
  32. cgbase,
  33. script,gendef,
  34. {$ifdef BrowserLog}
  35. browlog,
  36. {$endif BrowserLog}
  37. {$ifdef UseExcept}
  38. tpexcept,
  39. {$endif UseExcept}
  40. {$ifdef GDB}
  41. gdb,
  42. {$endif GDB}
  43. comphook,
  44. scanner,scandir,
  45. pbase,ptype,pmodules,cresstr;
  46. procedure initparser;
  47. begin
  48. { ^M means a string or a char, because we don't parse a }
  49. { type declaration }
  50. ignore_equal:=false;
  51. { we didn't parse a object or class declaration }
  52. { and no function header }
  53. testcurobject:=0;
  54. { Symtable }
  55. aktprocsym:=nil;
  56. aktprocdef:=nil;
  57. current_module:=nil;
  58. compiled_module:=nil;
  59. procinfo:=nil;
  60. loaded_units:=TLinkedList.Create;
  61. usedunits:=TLinkedList.Create;
  62. { global switches }
  63. aktglobalswitches:=initglobalswitches;
  64. { initialize scanner }
  65. InitScanner;
  66. InitScannerDirectives;
  67. { scanner }
  68. c:=#0;
  69. pattern:='';
  70. orgpattern:='';
  71. current_scanner:=nil;
  72. { memory sizes }
  73. if heapsize=0 then
  74. heapsize:=target_info.heapsize;
  75. if maxheapsize=0 then
  76. maxheapsize:=target_info.maxheapsize;
  77. if stacksize=0 then
  78. stacksize:=target_info.stacksize;
  79. { open assembler response }
  80. GenerateAsmRes(outputexedir+'ppas');
  81. { open deffile }
  82. DefFile:=TDefFile.Create(outputexedir+inputfile+target_info.defext);
  83. { list of generated .o files, so the linker can remove them }
  84. SmartLinkOFiles:=TStringList.Create;
  85. end;
  86. procedure doneparser;
  87. begin
  88. { unload units }
  89. loaded_units.free;
  90. usedunits.free;
  91. { if there was an error in the scanner, the scanner is
  92. still assinged }
  93. if assigned(current_scanner) then
  94. begin
  95. current_scanner.free;
  96. current_scanner:=nil;
  97. end;
  98. { close scanner }
  99. DoneScanner;
  100. { close ppas,deffile }
  101. asmres.free;
  102. deffile.free;
  103. { free list of .o files }
  104. SmartLinkOFiles.Free;
  105. end;
  106. procedure default_macros;
  107. var
  108. hp : tstringlistitem;
  109. begin
  110. { commandline }
  111. hp:=tstringlistitem(initdefines.first);
  112. while assigned(hp) do
  113. begin
  114. current_scanner.def_macro(hp.str);
  115. hp:=tstringlistitem(hp.next);
  116. end;
  117. { set macros for version checking }
  118. current_scanner.set_macro('FPC_VERSION',version_nr);
  119. current_scanner.set_macro('FPC_RELEASE',release_nr);
  120. current_scanner.set_macro('FPC_PATCH',patch_nr);
  121. end;
  122. {$ifdef PREPROCWRITE}
  123. procedure preprocess(const filename:string);
  124. var
  125. i : longint;
  126. begin
  127. new(preprocfile,init('pre'));
  128. { default macros }
  129. current_scanner^.macros:=new(pdictionary,init);
  130. default_macros;
  131. { initialize a module }
  132. current_module:=new(pmodule,init(filename,false));
  133. main_module:=current_module;
  134. { startup scanner, and save in current_module }
  135. current_scanner:=new(pscannerfile,Init(filename));
  136. current_module.scanner:=current_scanner;
  137. { loop until EOF is found }
  138. repeat
  139. current_scanner^.readtoken;
  140. preprocfile^.AddSpace;
  141. case token of
  142. _ID :
  143. begin
  144. preprocfile^.Add(orgpattern);
  145. end;
  146. _REALNUMBER,
  147. _INTCONST :
  148. preprocfile^.Add(pattern);
  149. _CSTRING :
  150. begin
  151. i:=0;
  152. while (i<length(pattern)) do
  153. begin
  154. inc(i);
  155. if pattern[i]='''' then
  156. begin
  157. insert('''',pattern,i);
  158. inc(i);
  159. end;
  160. end;
  161. preprocfile^.Add(''''+pattern+'''');
  162. end;
  163. _CCHAR :
  164. begin
  165. case pattern[1] of
  166. #39 :
  167. pattern:='''''''';
  168. #0..#31,
  169. #128..#255 :
  170. begin
  171. str(ord(pattern[1]),pattern);
  172. pattern:='#'+pattern;
  173. end;
  174. else
  175. pattern:=''''+pattern[1]+'''';
  176. end;
  177. preprocfile^.Add(pattern);
  178. end;
  179. _EOF :
  180. break;
  181. else
  182. preprocfile^.Add(tokeninfo^[token].str)
  183. end;
  184. until false;
  185. { free scanner }
  186. dispose(current_scanner,done);
  187. current_scanner:=nil;
  188. { close }
  189. dispose(preprocfile,done);
  190. end;
  191. {$endif PREPROCWRITE}
  192. procedure compile(const filename:string);
  193. var
  194. { scanner }
  195. oldidtoken,
  196. oldtoken : ttoken;
  197. oldtokenpos : tfileposinfo;
  198. oldc : char;
  199. oldpattern,
  200. oldorgpattern : string;
  201. old_block_type : tblock_type;
  202. oldcurrent_scanner,prev_scanner,
  203. scanner : tscannerfile;
  204. { symtable }
  205. oldrefsymtable,
  206. olddefaultsymtablestack,
  207. oldsymtablestack : tsymtable;
  208. oldprocprefix : string;
  209. oldaktprocsym : tprocsym;
  210. oldaktprocdef : tprocdef;
  211. oldoverloaded_operators : toverloaded_operators;
  212. { cg }
  213. oldnextlabelnr : longint;
  214. oldparse_only : boolean;
  215. { asmlists }
  216. oldimports,
  217. oldexports,
  218. oldresource,
  219. oldrttilist,
  220. oldresourcestringlist,
  221. oldbsssegment,
  222. olddatasegment,
  223. oldcodesegment,
  224. oldexprasmlist,
  225. olddebuglist,
  226. oldwithdebuglist,
  227. oldconsts : taasmoutput;
  228. oldasmsymbollist : tdictionary;
  229. { resourcestrings }
  230. OldResourceStrings : tResourceStrings;
  231. { akt.. things }
  232. oldaktlocalswitches : tlocalswitches;
  233. oldaktmoduleswitches : tmoduleswitches;
  234. oldaktfilepos : tfileposinfo;
  235. oldaktpackenum,oldaktmaxfpuregisters : longint;
  236. oldaktalignment : talignmentinfo;
  237. oldaktoutputformat : tasm;
  238. oldaktspecificoptprocessor,
  239. oldaktoptprocessor : tprocessors;
  240. oldaktasmmode : tasmmode;
  241. oldaktinterfacetype: tinterfacetypes;
  242. oldaktmodeswitches : tmodeswitches;
  243. old_compiled_module : tmodule;
  244. oldaktdefproccall : tproccalloption;
  245. { will only be increased once we start parsing blocks in the }
  246. { implementation, so doesn't need to be saved/restored (JM) }
  247. { oldexceptblockcounter : integer; }
  248. oldstatement_level : integer;
  249. prev_name : pstring;
  250. {$ifdef USEEXCEPT}
  251. {$ifndef Delphi}
  252. recoverpos : jmp_buf;
  253. oldrecoverpos : pjmp_buf;
  254. {$endif Delphi}
  255. {$endif useexcept}
  256. {$ifdef newcg}
  257. oldcg : pcg;
  258. {$endif newcg}
  259. {$ifdef GDB}
  260. store_dbx : plongint;
  261. {$endif GDB}
  262. begin
  263. inc(compile_level);
  264. prev_name:=stringdup(parser_current_file);
  265. parser_current_file:=filename;
  266. old_compiled_module:=compiled_module;
  267. { save symtable state }
  268. oldsymtablestack:=symtablestack;
  269. olddefaultsymtablestack:=defaultsymtablestack;
  270. oldrefsymtable:=refsymtable;
  271. oldprocprefix:=procprefix;
  272. oldaktprocsym:=aktprocsym;
  273. oldaktprocdef:=aktprocdef;
  274. oldaktdefproccall:=aktdefproccall;
  275. move(overloaded_operators,oldoverloaded_operators,sizeof(toverloaded_operators));
  276. { save scanner state }
  277. oldc:=c;
  278. oldpattern:=pattern;
  279. oldorgpattern:=orgpattern;
  280. oldtoken:=token;
  281. oldidtoken:=idtoken;
  282. old_block_type:=block_type;
  283. oldtokenpos:=akttokenpos;
  284. oldcurrent_scanner:=current_scanner;
  285. { save cg }
  286. oldnextlabelnr:=nextlabelnr;
  287. oldparse_only:=parse_only;
  288. { save assembler lists }
  289. olddatasegment:=datasegment;
  290. oldbsssegment:=bsssegment;
  291. oldcodesegment:=codesegment;
  292. olddebuglist:=debuglist;
  293. oldwithdebuglist:=withdebuglist;
  294. oldconsts:=consts;
  295. oldrttilist:=rttilist;
  296. oldexprasmlist:=exprasmlist;
  297. oldimports:=importssection;
  298. oldexports:=exportssection;
  299. oldresource:=resourcesection;
  300. oldresourcestringlist:=resourcestringlist;
  301. oldasmsymbollist:=asmsymbollist;
  302. OldResourceStrings:=ResourceStrings;
  303. { save akt... state }
  304. { handle the postponed case first }
  305. if localswitcheschanged then
  306. begin
  307. aktlocalswitches:=nextaktlocalswitches;
  308. localswitcheschanged:=false;
  309. end;
  310. oldaktlocalswitches:=aktlocalswitches;
  311. oldaktmoduleswitches:=aktmoduleswitches;
  312. oldaktalignment:=aktalignment;
  313. oldaktpackenum:=aktpackenum;
  314. oldaktmaxfpuregisters:=aktmaxfpuregisters;
  315. oldaktoutputformat:=aktoutputformat;
  316. oldaktoptprocessor:=aktoptprocessor;
  317. oldaktspecificoptprocessor:=aktspecificoptprocessor;
  318. oldaktasmmode:=aktasmmode;
  319. oldaktinterfacetype:=aktinterfacetype;
  320. oldaktfilepos:=aktfilepos;
  321. oldaktmodeswitches:=aktmodeswitches;
  322. oldstatement_level:=statement_level;
  323. { oldexceptblockcounter:=exceptblockcounter; }
  324. {$ifdef newcg}
  325. oldcg:=cg;
  326. {$endif newcg}
  327. {$ifdef GDB}
  328. store_dbx:=dbx_counter;
  329. dbx_counter:=nil;
  330. {$endif GDB}
  331. { show info }
  332. Message1(parser_i_compiling,filename);
  333. { reset symtable }
  334. symtablestack:=nil;
  335. defaultsymtablestack:=nil;
  336. systemunit:=nil;
  337. refsymtable:=nil;
  338. aktprocsym:=nil;
  339. aktdefproccall:=initdefproccall;
  340. procprefix:='';
  341. registerdef:=true;
  342. statement_level:=0;
  343. aktexceptblock:=0;
  344. exceptblockcounter:=0;
  345. aktmaxfpuregisters:=-1;
  346. fillchar(overloaded_operators,sizeof(toverloaded_operators),0);
  347. { reset the unit or create a new program }
  348. if assigned(current_module) then
  349. begin
  350. {current_module.reset this is wrong !! }
  351. scanner:=tscannerfile(current_module.scanner);
  352. current_module.reset;
  353. tscannerfile(current_module.scanner):=scanner;
  354. end
  355. else
  356. begin
  357. current_module:=tppumodule.create(filename,'',false);
  358. main_module:=current_module;
  359. end;
  360. { a unit compiled at command line must be inside the loaded_unit list }
  361. if (compile_level=1) then
  362. loaded_units.insert(current_module);
  363. { Set the module to use for verbose }
  364. SetCompileModule(current_module);
  365. compiled_module:=current_module;
  366. current_module.in_compile:=true;
  367. { Load current state from the init values }
  368. aktlocalswitches:=initlocalswitches;
  369. aktmoduleswitches:=initmoduleswitches;
  370. aktmodeswitches:=initmodeswitches;
  371. {$IFDEF Testvarsets}
  372. aktsetalloc:=initsetalloc;
  373. {$ENDIF}
  374. aktalignment:=initalignment;
  375. aktpackenum:=initpackenum;
  376. aktoutputformat:=initoutputformat;
  377. set_target_asm(aktoutputformat);
  378. aktoptprocessor:=initoptprocessor;
  379. aktspecificoptprocessor:=initspecificoptprocessor;
  380. aktasmmode:=initasmmode;
  381. aktinterfacetype:=initinterfacetype;
  382. { startup scanner, and save in current_module }
  383. current_scanner:=tscannerfile.Create(filename);
  384. { macros }
  385. default_macros;
  386. { read the first token }
  387. current_scanner.readtoken;
  388. prev_scanner:=tscannerfile(current_module.scanner);
  389. current_module.scanner:=current_scanner;
  390. { init code generator for a new module }
  391. codegen_newmodule;
  392. {$ifdef newcg}
  393. {$ifdef i386}
  394. cg:=new(pcg386,init);
  395. {$endif i386}
  396. {$ifdef alpha}
  397. cg:=new(pcgalpha,init);
  398. {$endif alpha}
  399. {$ifdef powerpc}
  400. cg:=new(pcgppc,init);
  401. {$endif powerpc}
  402. {$endif newcg}
  403. { If the compile level > 1 we get a nice "unit expected" error
  404. message if we are trying to use a program as unit.}
  405. {$ifdef USEEXCEPT}
  406. if setjmp(recoverpos)=0 then
  407. begin
  408. oldrecoverpos:=recoverpospointer;
  409. recoverpospointer:=@recoverpos;
  410. {$endif USEEXCEPT}
  411. if (token=_UNIT) or (compile_level>1) then
  412. begin
  413. current_module.is_unit:=true;
  414. proc_unit;
  415. end
  416. else
  417. proc_program(token=_LIBRARY);
  418. {$ifdef USEEXCEPT}
  419. recoverpospointer:=oldrecoverpos;
  420. end
  421. else
  422. begin
  423. recoverpospointer:=oldrecoverpos;
  424. longjump_used:=true;
  425. end;
  426. {$endif USEEXCEPT}
  427. { clear memory }
  428. {$ifdef Splitheap}
  429. if testsplit then
  430. begin
  431. { temp heap should be empty after that !!!}
  432. codegen_donemodule;
  433. Releasetempheap;
  434. end;
  435. {$endif Splitheap}
  436. { restore old state, close trees, > 0.99.5 has heapblocks, so
  437. it's the default to release the trees }
  438. codegen_donemodule;
  439. {$ifdef newcg}
  440. dispose(cg,done);
  441. {$endif newcg}
  442. { free ppu }
  443. if assigned(tppumodule(current_module).ppufile) then
  444. begin
  445. tppumodule(current_module).ppufile.free;
  446. tppumodule(current_module).ppufile:=nil;
  447. end;
  448. { free scanner }
  449. current_scanner.free;
  450. current_scanner:=nil;
  451. { restore previous scanner !! }
  452. current_module.scanner:=prev_scanner;
  453. if assigned(prev_scanner) then
  454. prev_scanner.invalid:=true;
  455. if (compile_level>1) then
  456. begin
  457. {$ifdef newcg}
  458. cg:=oldcg;
  459. {$endif newcg}
  460. {$ifdef GDB}
  461. dbx_counter:=store_dbx;
  462. {$endif GDB}
  463. { restore scanner }
  464. c:=oldc;
  465. pattern:=oldpattern;
  466. orgpattern:=oldorgpattern;
  467. token:=oldtoken;
  468. idtoken:=oldidtoken;
  469. akttokenpos:=oldtokenpos;
  470. block_type:=old_block_type;
  471. current_scanner:=oldcurrent_scanner;
  472. { restore cg }
  473. nextlabelnr:=oldnextlabelnr;
  474. parse_only:=oldparse_only;
  475. { restore asmlists }
  476. exprasmlist:=oldexprasmlist;
  477. datasegment:=olddatasegment;
  478. bsssegment:=oldbsssegment;
  479. codesegment:=oldcodesegment;
  480. consts:=oldconsts;
  481. debuglist:=olddebuglist;
  482. withdebuglist:=oldwithdebuglist;
  483. importssection:=oldimports;
  484. exportssection:=oldexports;
  485. resourcesection:=oldresource;
  486. rttilist:=oldrttilist;
  487. resourcestringlist:=oldresourcestringlist;
  488. asmsymbollist:=oldasmsymbollist;
  489. ResourceStrings:=OldResourceStrings;
  490. { restore symtable state }
  491. refsymtable:=oldrefsymtable;
  492. symtablestack:=oldsymtablestack;
  493. defaultsymtablestack:=olddefaultsymtablestack;
  494. aktdefproccall:=oldaktdefproccall;
  495. aktprocsym:=oldaktprocsym;
  496. aktprocdef:=oldaktprocdef;
  497. procprefix:=oldprocprefix;
  498. move(oldoverloaded_operators,overloaded_operators,sizeof(toverloaded_operators));
  499. aktlocalswitches:=oldaktlocalswitches;
  500. aktmoduleswitches:=oldaktmoduleswitches;
  501. aktalignment:=oldaktalignment;
  502. aktpackenum:=oldaktpackenum;
  503. aktmaxfpuregisters:=oldaktmaxfpuregisters;
  504. aktoutputformat:=oldaktoutputformat;
  505. set_target_asm(aktoutputformat);
  506. aktoptprocessor:=oldaktoptprocessor;
  507. aktspecificoptprocessor:=oldaktspecificoptprocessor;
  508. aktasmmode:=oldaktasmmode;
  509. aktinterfacetype:=oldaktinterfacetype;
  510. aktfilepos:=oldaktfilepos;
  511. aktmodeswitches:=oldaktmodeswitches;
  512. statement_level:=oldstatement_level;
  513. aktexceptblock:=0;
  514. exceptblockcounter:=0;
  515. end;
  516. { Shut down things when the last file is compiled }
  517. if (compile_level=1) then
  518. begin
  519. { Close script }
  520. if (not AsmRes.Empty) then
  521. begin
  522. Message1(exec_i_closing_script,AsmRes.Fn);
  523. AsmRes.WriteToDisk;
  524. end;
  525. {$ifdef USEEXCEPT}
  526. if not longjump_used then
  527. {$endif USEEXCEPT}
  528. { do not create browsers on errors !! }
  529. if status.errorcount=0 then
  530. begin
  531. {$ifdef BrowserLog}
  532. { Write Browser Log }
  533. if (cs_browser_log in aktglobalswitches) and
  534. (cs_browser in aktmoduleswitches) then
  535. begin
  536. if browserlog.elements_to_list.empty then
  537. begin
  538. Message1(parser_i_writing_browser_log,browserlog.Fname);
  539. WriteBrowserLog;
  540. end
  541. else
  542. browserlog.list_elements;
  543. end;
  544. {$endif BrowserLog}
  545. { Write Browser Collections }
  546. do_extractsymbolinfo{$ifdef FPC}(){$endif};
  547. end;
  548. if current_module.in_second_compile then
  549. begin
  550. current_module.in_second_compile:=false;
  551. current_module.in_compile:=true;
  552. end
  553. else
  554. current_module.in_compile:=false;
  555. (* Obsolete code aktprocsym
  556. is disposed by the localsymtable disposal (PM)
  557. { Free last aktprocsym }
  558. if assigned(aktprocsym) and (aktprocsym.owner=nil) then
  559. begin
  560. { init parts are not needed in units !! }
  561. if current_module.is_unit then
  562. aktprocdef.forwarddef:=false;
  563. dispose(aktprocsym,done);
  564. end; *)
  565. end;
  566. dec(compile_level);
  567. parser_current_file:=prev_name^;
  568. stringdispose(prev_name);
  569. compiled_module:=old_compiled_module;
  570. {$ifdef USEEXCEPT}
  571. if longjump_used then
  572. longjmp(recoverpospointer^,1);
  573. {$endif USEEXCEPT}
  574. end;
  575. end.
  576. {
  577. $Log$
  578. Revision 1.27 2002-01-29 19:43:11 peter
  579. * update target_asm according to outputformat
  580. Revision 1.26 2001/11/02 22:58:02 peter
  581. * procsym definition rewrite
  582. Revision 1.25 2001/10/25 21:22:35 peter
  583. * calling convention rewrite
  584. Revision 1.24 2001/10/23 21:49:42 peter
  585. * $calling directive and -Cc commandline patch added
  586. from Pavel Ozerski
  587. Revision 1.23 2001/10/16 15:10:35 jonas
  588. * fixed goto/label/try bugs
  589. Revision 1.22 2001/08/26 13:36:43 florian
  590. * some cg reorganisation
  591. * some PPC updates
  592. Revision 1.21 2001/07/30 20:59:27 peter
  593. * m68k updates from v10 merged
  594. Revision 1.20 2001/07/01 20:16:16 peter
  595. * alignmentinfo record added
  596. * -Oa argument supports more alignment settings that can be specified
  597. per type: PROC,LOOP,VARMIN,VARMAX,CONSTMIN,CONSTMAX,RECORDMIN
  598. RECORDMAX,LOCALMIN,LOCALMAX. It is possible to set the mimimum
  599. required alignment and the maximum usefull alignment. The final
  600. alignment will be choosen per variable size dependent on these
  601. settings
  602. Revision 1.19 2001/05/19 23:05:19 peter
  603. * support uses <unit> in <file> construction
  604. Revision 1.18 2001/05/06 14:49:17 peter
  605. * ppu object to class rewrite
  606. * move ppu read and write stuff to fppu
  607. Revision 1.17 2001/04/18 22:01:54 peter
  608. * registration of targets and assemblers
  609. Revision 1.16 2001/04/15 09:48:30 peter
  610. * fixed crash in labelnode
  611. * easier detection of goto and label in try blocks
  612. Revision 1.15 2001/04/13 18:08:37 peter
  613. * scanner object to class
  614. Revision 1.14 2001/04/13 01:22:10 peter
  615. * symtable change to classes
  616. * range check generation and errors fixed, make cycle DEBUG=1 works
  617. * memory leaks fixed
  618. Revision 1.13 2000/12/25 00:07:27 peter
  619. + new tlinkedlist class (merge of old tstringqueue,tcontainer and
  620. tlinkedlist objects)
  621. Revision 1.12 2000/12/24 12:24:38 peter
  622. * moved preprocessfile into a conditional
  623. Revision 1.11 2000/11/29 00:30:34 florian
  624. * unused units removed from uses clause
  625. * some changes for widestrings
  626. Revision 1.10 2000/11/12 22:17:46 peter
  627. * some realname updates for messages
  628. Revision 1.9 2000/11/04 14:25:20 florian
  629. + merged Attila's changes for interfaces, not tested yet
  630. Revision 1.8 2000/10/31 22:02:49 peter
  631. * symtable splitted, no real code changes
  632. Revision 1.7 2000/10/14 10:14:51 peter
  633. * moehrendorf oct 2000 rewrite
  634. Revision 1.6 2000/10/01 19:48:25 peter
  635. * lot of compile updates for cg11
  636. Revision 1.5 2000/09/24 15:06:20 peter
  637. * use defines.inc
  638. Revision 1.4 2000/08/27 16:11:51 peter
  639. * moved some util functions from globals,cobjects to cutils
  640. * splitted files into finput,fmodule
  641. Revision 1.3 2000/08/12 15:34:22 peter
  642. + usedasmsymbollist to check and reset only the used symbols (merged)
  643. Revision 1.2 2000/07/13 11:32:44 michael
  644. + removed logs
  645. }