pexports.pas 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. {
  2. $Id$
  3. Copyright (c) 1998-2000 by Florian Klaempfl
  4. This unit handles the exports parsing
  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 pexports;
  19. {$i defines.inc}
  20. interface
  21. { reads an exports statement in a library }
  22. procedure read_exports;
  23. implementation
  24. uses
  25. { common }
  26. cutils,
  27. { global }
  28. globals,tokens,verbose,
  29. systems,
  30. { symtable }
  31. symconst,symbase,symtype,symdef,symsym,
  32. { pass 1 }
  33. node,
  34. ncon,
  35. { parser }
  36. scanner,
  37. pbase,pexpr,
  38. { link }
  39. gendef,export
  40. ;
  41. procedure read_exports;
  42. var
  43. hp : texported_item;
  44. orgs,
  45. DefString : string;
  46. InternalProcName : string;
  47. pt : tnode;
  48. srsym : tsym;
  49. srsymtable : tsymtable;
  50. begin
  51. DefString:='';
  52. InternalProcName:='';
  53. consume(_EXPORTS);
  54. while true do
  55. begin
  56. hp:=texported_item.create;
  57. if token=_ID then
  58. begin
  59. orgs:=orgpattern;
  60. consume_sym(srsym,srsymtable);
  61. hp.sym:=srsym;
  62. InternalProcName:='';
  63. case srsym.typ of
  64. varsym :
  65. InternalProcName:=tvarsym(srsym).mangledname;
  66. typedconstsym :
  67. InternalProcName:=ttypedconstsym(srsym).mangledname;
  68. procsym :
  69. begin
  70. if assigned(tprocsym(srsym).defs^.next) or
  71. ((tf_need_export in target_info.flags) and
  72. not(po_exports in tprocsym(srsym).defs^.def.procoptions)) then
  73. Message(parser_e_illegal_symbol_exported)
  74. else
  75. InternalProcName:=tprocsym(srsym).defs^.def.mangledname;
  76. end;
  77. else
  78. Message(parser_e_illegal_symbol_exported)
  79. end;
  80. if InternalProcName<>'' then
  81. begin
  82. { This is wrong if the first is not
  83. an underline }
  84. if InternalProcName[1]='_' then
  85. delete(InternalProcName,1,1)
  86. else if (target_info.target=target_i386_win32) and UseDeffileForExport then
  87. begin
  88. Message(parser_e_dlltool_unit_var_problem);
  89. Message(parser_e_dlltool_unit_var_problem2);
  90. end;
  91. if length(InternalProcName)<2 then
  92. Message(parser_e_procname_to_short_for_export);
  93. DefString:=srsym.realname+'='+InternalProcName;
  94. end;
  95. if (idtoken=_INDEX) then
  96. begin
  97. consume(_INDEX);
  98. pt:=comp_expr(true);
  99. if pt.nodetype=ordconstn then
  100. hp.index:=tordconstnode(pt).value
  101. else
  102. begin
  103. hp.index:=0;
  104. consume(_INTCONST);
  105. end;
  106. hp.options:=hp.options or eo_index;
  107. pt.free;
  108. if target_info.target=target_i386_win32 then
  109. DefString:=srsym.realname+'='+InternalProcName+' @ '+tostr(hp.index)
  110. else
  111. DefString:=srsym.realname+'='+InternalProcName; {Index ignored!}
  112. end;
  113. if (idtoken=_NAME) then
  114. begin
  115. consume(_NAME);
  116. pt:=comp_expr(true);
  117. if pt.nodetype=stringconstn then
  118. hp.name:=stringdup(strpas(tstringconstnode(pt).value_str))
  119. else
  120. begin
  121. hp.name:=stringdup('');
  122. consume(_CSTRING);
  123. end;
  124. hp.options:=hp.options or eo_name;
  125. pt.free;
  126. DefString:=hp.name^+'='+InternalProcName;
  127. end;
  128. if (idtoken=_RESIDENT) then
  129. begin
  130. consume(_RESIDENT);
  131. hp.options:=hp.options or eo_resident;
  132. DefString:=srsym.realname+'='+InternalProcName;{Resident ignored!}
  133. end;
  134. if (DefString<>'') and UseDeffileForExport then
  135. DefFile.AddExport(DefString);
  136. { Default to generate a name entry with the provided name }
  137. if not assigned(hp.name) then
  138. begin
  139. hp.name:=stringdup(orgs);
  140. hp.options:=hp.options or eo_name;
  141. end;
  142. if hp.sym.typ=procsym then
  143. exportlib.exportprocedure(hp)
  144. else
  145. exportlib.exportvar(hp);
  146. end
  147. else
  148. consume(_ID);
  149. if token=_COMMA then
  150. consume(_COMMA)
  151. else
  152. break;
  153. end;
  154. consume(_SEMICOLON);
  155. if not DefFile.empty then
  156. DefFile.writefile;
  157. end;
  158. end.
  159. {
  160. $Log$
  161. Revision 1.16 2001-11-02 22:58:04 peter
  162. * procsym definition rewrite
  163. Revision 1.15 2001/04/18 22:01:57 peter
  164. * registration of targets and assemblers
  165. Revision 1.14 2001/04/13 01:22:12 peter
  166. * symtable change to classes
  167. * range check generation and errors fixed, make cycle DEBUG=1 works
  168. * memory leaks fixed
  169. Revision 1.13 2001/04/04 22:43:52 peter
  170. * remove unnecessary calls to firstpass
  171. Revision 1.12 2001/03/11 22:58:50 peter
  172. * getsym redesign, removed the globals srsym,srsymtable
  173. Revision 1.11 2001/01/03 13:12:50 jonas
  174. * fixed copy/past bugs
  175. Revision 1.10 2000/12/30 22:53:25 peter
  176. * export with the case provided in the exports section
  177. Revision 1.9 2000/12/25 00:07:27 peter
  178. + new tlinkedlist class (merge of old tstringqueue,tcontainer and
  179. tlinkedlist objects)
  180. Revision 1.8 2000/11/29 00:30:36 florian
  181. * unused units removed from uses clause
  182. * some changes for widestrings
  183. Revision 1.7 2000/10/31 22:02:49 peter
  184. * symtable splitted, no real code changes
  185. Revision 1.6 2000/10/14 10:14:51 peter
  186. * moehrendorf oct 2000 rewrite
  187. Revision 1.5 2000/09/24 21:19:50 peter
  188. * delphi compile fixes
  189. Revision 1.4 2000/09/24 15:06:21 peter
  190. * use defines.inc
  191. Revision 1.3 2000/08/27 16:11:51 peter
  192. * moved some util functions from globals,cobjects to cutils
  193. * splitted files into finput,fmodule
  194. Revision 1.2 2000/07/13 11:32:44 michael
  195. + removed logs
  196. }