mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-16 05:39:27 +02:00
199 lines
6.6 KiB
ObjectPascal
199 lines
6.6 KiB
ObjectPascal
{
|
|
$Id$
|
|
Copyright (c) 1998-2002 by Florian Klaempfl
|
|
|
|
This unit handles the exports parsing
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
****************************************************************************
|
|
}
|
|
unit pexports;
|
|
|
|
{$i fpcdefs.inc}
|
|
|
|
interface
|
|
|
|
{ reads an exports statement in a library }
|
|
procedure read_exports;
|
|
|
|
|
|
implementation
|
|
|
|
uses
|
|
{ common }
|
|
cutils,
|
|
{ global }
|
|
globals,tokens,verbose,
|
|
systems,
|
|
{ symtable }
|
|
symconst,symbase,symtype,symsym,
|
|
{ pass 1 }
|
|
node,
|
|
ncon,
|
|
{ parser }
|
|
scanner,
|
|
pbase,pexpr,
|
|
{ link }
|
|
gendef,export
|
|
{$ifdef Delphi}
|
|
,dmisc
|
|
,sysutils
|
|
{$endif}
|
|
;
|
|
|
|
|
|
procedure read_exports;
|
|
var
|
|
hp : texported_item;
|
|
orgs,
|
|
DefString : string;
|
|
InternalProcName : string;
|
|
pt : tnode;
|
|
srsym : tsym;
|
|
srsymtable : tsymtable;
|
|
begin
|
|
DefString:='';
|
|
InternalProcName:='';
|
|
consume(_EXPORTS);
|
|
repeat
|
|
hp:=texported_item.create;
|
|
if token=_ID then
|
|
begin
|
|
orgs:=orgpattern;
|
|
consume_sym(srsym,srsymtable);
|
|
hp.sym:=srsym;
|
|
InternalProcName:='';
|
|
case srsym.typ of
|
|
varsym :
|
|
InternalProcName:=tvarsym(srsym).mangledname;
|
|
typedconstsym :
|
|
InternalProcName:=ttypedconstsym(srsym).mangledname;
|
|
procsym :
|
|
begin
|
|
if (Tprocsym(srsym).procdef_count>1) or
|
|
((tf_need_export in target_info.flags) and
|
|
not(po_exports in tprocsym(srsym).first_procdef.procoptions)) then
|
|
Message(parser_e_illegal_symbol_exported)
|
|
else
|
|
InternalProcName:=tprocsym(srsym).first_procdef.mangledname;
|
|
end;
|
|
else
|
|
Message(parser_e_illegal_symbol_exported)
|
|
end;
|
|
if InternalProcName<>'' then
|
|
begin
|
|
{ This is wrong if the first is not
|
|
an underline }
|
|
if InternalProcName[1]='_' then
|
|
delete(InternalProcName,1,1)
|
|
else if (target_info.system in [system_i386_win32,system_i386_wdosx]) and UseDeffileForExport then
|
|
begin
|
|
Message(parser_e_dlltool_unit_var_problem);
|
|
Message(parser_e_dlltool_unit_var_problem2);
|
|
end;
|
|
if length(InternalProcName)<2 then
|
|
Message(parser_e_procname_to_short_for_export);
|
|
DefString:=srsym.realname+'='+InternalProcName;
|
|
end;
|
|
if try_to_consume(_INDEX) then
|
|
begin
|
|
pt:=comp_expr(true);
|
|
if pt.nodetype=ordconstn then
|
|
hp.index:=tordconstnode(pt).value
|
|
else
|
|
begin
|
|
hp.index:=0;
|
|
consume(_INTCONST);
|
|
end;
|
|
hp.options:=hp.options or eo_index;
|
|
pt.free;
|
|
if target_info.system in [system_i386_win32,system_i386_wdosx] then
|
|
DefString:=srsym.realname+'='+InternalProcName+' @ '+tostr(hp.index)
|
|
else
|
|
DefString:=srsym.realname+'='+InternalProcName; {Index ignored!}
|
|
end;
|
|
if try_to_consume(_NAME) then
|
|
begin
|
|
pt:=comp_expr(true);
|
|
if pt.nodetype=stringconstn then
|
|
hp.name:=stringdup(strpas(tstringconstnode(pt).value_str))
|
|
else
|
|
begin
|
|
hp.name:=stringdup('');
|
|
consume(_CSTRING);
|
|
end;
|
|
hp.options:=hp.options or eo_name;
|
|
pt.free;
|
|
DefString:=hp.name^+'='+InternalProcName;
|
|
end;
|
|
if try_to_consume(_RESIDENT) then
|
|
begin
|
|
hp.options:=hp.options or eo_resident;
|
|
DefString:=srsym.realname+'='+InternalProcName;{Resident ignored!}
|
|
end;
|
|
if (DefString<>'') and UseDeffileForExport then
|
|
DefFile.AddExport(DefString);
|
|
{ Default to generate a name entry with the provided name }
|
|
if not assigned(hp.name) then
|
|
begin
|
|
hp.name:=stringdup(orgs);
|
|
hp.options:=hp.options or eo_name;
|
|
end;
|
|
if hp.sym.typ=procsym then
|
|
exportlib.exportprocedure(hp)
|
|
else
|
|
exportlib.exportvar(hp);
|
|
end
|
|
else
|
|
consume(_ID);
|
|
until not try_to_consume(_COMMA);
|
|
consume(_SEMICOLON);
|
|
if not DefFile.empty then
|
|
DefFile.writefile;
|
|
end;
|
|
|
|
end.
|
|
|
|
{
|
|
$Log$
|
|
Revision 1.24 2002-10-05 12:43:26 carl
|
|
* fixes for Delphi 6 compilation
|
|
(warning : Some features do not work under Delphi)
|
|
|
|
Revision 1.23 2002/09/03 16:26:27 daniel
|
|
* Make Tprocdef.defs protected
|
|
|
|
Revision 1.22 2002/07/26 21:15:41 florian
|
|
* rewrote the system handling
|
|
|
|
Revision 1.21 2002/05/18 13:34:12 peter
|
|
* readded missing revisions
|
|
|
|
Revision 1.20 2002/05/16 19:46:43 carl
|
|
+ defines.inc -> fpcdefs.inc to avoid conflicts if compiling by hand
|
|
+ try to fix temp allocation (still in ifdef)
|
|
+ generic constructor calls
|
|
+ start of tassembler / tmodulebase class cleanup
|
|
|
|
Revision 1.18 2002/04/04 19:06:03 peter
|
|
* removed unused units
|
|
* use tlocation.size in cg.a_*loc*() routines
|
|
|
|
Revision 1.17 2002/04/04 18:41:07 carl
|
|
+ added wdosx support (patch from Pavel)
|
|
|
|
}
|