[
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