Skip to main content

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [List Home]
RE: [cdt-dev] Managing additional toolchain state

My comments are embedded below in Chris' response.


-----Original Message-----
From: cdt-dev-admin@xxxxxxxxxxx [mailto:cdt-dev-admin@xxxxxxxxxxx] On
Behalf Of Recoskie, Chris
Sent: Friday, January 21, 2005 6:34 AM
To: cdt-dev@xxxxxxxxxxx
Subject: RE: [cdt-dev] Managing additional toolchain state

I would suspect as well that you are going to have to create a new
makefile generator so that when you change this "module def file", the
build system detects the dependency and relinks the executable file.

[Leo]  Good point!

I disclaim however that it's been a few months since I took a look at
the featureset of the work that Leo did in 2.1 so it might be that this
is already taken care of.  I do recall that we had discussed having
"command formatters" that would allow you to specify printf-style how
you wanted the command for a particular tool to be generated, but I
don't recall if a) this included the ability to modify the dependency
portion of the makefile rule, and b) if this feature in general was
slated for 2.1 or beyond.

[Leo]  The command generation flexibility was added (see
commandLinePattern and commandLineGenerator) in 2.1, but this doesn't
help with the dependency problem.

There are 2 other approaches to solving the dependency problem.

You could add a dependency calculator to your linker tool.  I haven't
tried this with the linker - hopefully it will work....

The main makefile that gets generated includes 3 optional, user-defined,
makefile fragments - below is an example makefile.  The files are
makefile.init, makefile.defs, and makefile.targets.  You could create a
makefile.defs that contains:

USER_OBJS += filename.def

Regards,
Leo

########################################################################
########
# Automatically-generated file. Do not edit!
########################################################################
########

ROOT := ..

-include $(ROOT)/makefile.init

RM := rm -rf

# All of the sources participating in the build are defined here
-include sources.mk
-include $(SUBDIRS:%=%/subdir.mk)
-include objects.mk
-include $(DEPS)
-include $(ROOT)/makefile.defs

all: GNU_EXE.exe

GNU_EXE.exe: $(OBJS)
	@echo 'Building target: $@'
	gcc  -o $@ $(OBJS) $(USER_OBJS) $(LIBS)
	@echo 'Finished building: $@'

clean:
	-$(RM) $(OBJS) $(DEPS) GNU_EXE.exe

.PHONY: all clean dependents

-include $(ROOT)/makefile.targets
___________________________________________
 
Chris Recoskie
Software Designer
IDE Frameworks Group
Texas Instruments, Toronto
 
 

> -----Original Message-----
> From: cdt-dev-admin@xxxxxxxxxxx [mailto:cdt-dev-admin@xxxxxxxxxxx] On
> Behalf Of Treggiari, Leo
> Sent: Thursday, January 20, 2005 11:14 PM
> To: cdt-dev@xxxxxxxxxxx
> Subject: RE: [cdt-dev] Managing additional toolchain state
> 
> Hi,
> 
> It's not clear to me what you are trying to do, but I'll give you some
> thoughts and maybe they'll help.
> 
> The managed build system allows you to define tools (e.g. compiler,
> linker) and their command line options.  I don't know what you mean by
> "I created a properties page for this module def file".  Do you have a
> tool that creates module definition files, or does your user use a
text
> editor to create the file?  If there is a tool, then you can define
the
> tool in your tool-chain definition.  If the file is simply a text file
> that is input to the linker, you can define your own linker tool that
> has an additional option for specifying the name of the module
> definition file.  That option can generate whatever command line
option
> is needed by the linker (e.g. /def:filename).
> 
> Regards,
> Leo
> 
> -----Original Message-----
> From: cdt-dev-admin@xxxxxxxxxxx [mailto:cdt-dev-admin@xxxxxxxxxxx] On
> Behalf Of Scott Michel
> Sent: Thursday, January 20, 2005 9:48 PM
> To: cdt-dev@xxxxxxxxxxx
> Subject: [cdt-dev] Managing additional toolchain state
> 
> Question: How does one go about managing additional toolchain state
> within the current CDT structure? As an example, I'm creating a
plug-in
> for the Digital Mars C/C++ compiler, and its linker depends on a
"module
> 
> definition" file to properly create binaries for Win32.
> 
> I created a properties page for this module def file, but now, I'm
> wondering how to hook this additional state into ManagedBuildManager
or
> how to get an object invoked to track this additional plug-in build
> state. It'd be even better if I could subscribe to events involving
the
> file, but I'll settle for whatever I can get.
> 
> Any suggestions? Pointing me at some code for ideas will help.
> 
> I did look at "cextension", but didn't quite see how I could get CDT
to
> create the the cextension object on my behalf automagically.
> 
> 
> -scooter
>   (preparing to be flattened by the deafening silence... :-)
> _______________________________________________
> cdt-dev mailing list
> cdt-dev@xxxxxxxxxxx
> http://dev.eclipse.org/mailman/listinfo/cdt-dev
> _______________________________________________
> cdt-dev mailing list
> cdt-dev@xxxxxxxxxxx
> http://dev.eclipse.org/mailman/listinfo/cdt-dev
_______________________________________________
cdt-dev mailing list
cdt-dev@xxxxxxxxxxx
http://dev.eclipse.org/mailman/listinfo/cdt-dev


Back to the top