On 2009-04-19, at 23:19 +0200, Oliver Kellogg wrote:
> [...]
> 
> How about not doing the name expansion in-place but rather
> storing the expanded name in an extra node field?

I haven't received any reaction on this question yet.
Perhaps I could reuse the Str3 field instead? (I haven't looked
into the depths of its usage yet.)
Please advise.

BTW, I added the invocation of 'as' for assembly files 2 to N
in gcc.c, this means that the multi-source mechanism can now
be used in a normal "gcc -c" invocation using the -multi switch.

Up next would be gnatmake:
I would like to add a switch to gnatmake that enables multi-
source mode. What should I use for the switch name?

Also, I'm thinking that in multi-source mode, the switch "-o"
can perhaps continue to be used - not by giving a filename
but instead by giving a directory. All object files would then
be placed in the given directory. What do you think?

Thanks,

Oliver


> On 2009-04-18 at 21:35 +0200, Oliver Kellogg wrote:
> > I've run up against a problem with reusing the GNAT trees:
> > Apparently during semantic analysis entity names are expanded
> > to their fully qualified names in the tree.
> > 
> > For example, when compiling the following file with the node
> > for System already installed by a previous compilation,
> > 
> > -- file: ext.ads
> > with System;
> > procedure Ext (Addr : System.Address);
> > 
> > I get the following error from sem_ch8.adb Find_Expanded_Name
> > during semantic analysis of the above System.Address,
> > 
> > ext.ads:3:29: "Address" is not a visible entity of "System"
> > 
> > This is because in sem_ch8.adb:4482,
> > 
> >   if No (Id) or else Chars (Id) /= Chars (Selector) then ...
> > 
> > the second part of the condition becomes true as Chars(Id) is
> > "system__address" [and Chars(Selector) is "address"].
> > When compiling the same file afresh without preinstalled nodes,
> > Chars(Id) is just "address" and all is fine.
> > 
> > Oliver
> > 

Reply via email to