Forum: Compiler & IDEs Makefile-Problem


von Benjamin (Gast)


Lesenswert?

Hallo,

ich habe im makefile eine Liste von Dateien, die von einem Script 
generiert werden:
1
HEADERS =  $(sort \
2
  generatedHeader1.h \
3
  generatedHeader12.h)


Jeder generierte Header hängt von seinem Template ab, dass die Endung 
.h.template trägt.


Ich möchte also für jeden Eintrag in meiner HEADERS-Liste ein Target 
erzeugen, dass von diesem .h.template abhängt.
Dadurch soll sichergestellt werden dass der entsprechende Header 
generiert wird wenn sich mein .h.template file ändert.

Mein Versuch sieht so aus:
1
$(HEADERS): $*.h.template
2
  @echo $* #hier wird normal das Script aufgerufen...

Das klappt nicht.
$* expandiert zwar zum aktuellen File, aber anscheinend nur im "Body" 
eines targets.


Die Fehlermeldung lautet:
1
make: *** No rule to make target '.h.template'

Das bedeutet für mich, $* expandiert nur im Body, nicht aber in der 
Abhängigkeitenliste.

Gibt es da eine Lösung für mein Problem?
Ich verwende GNU make.

von Alexander F. (alexf91)


Lesenswert?


: Bearbeitet durch User
von Benjamin (Gast)


Lesenswert?

Danke!
Klappt soweit.

Ich hab da noch eine Frage:
Angenommen, "generatedHeader1.h" liegt in foo/bar, sprich, meine Liste 
sieht so aus:
1
HEADERS =  $(sort \
2
  foo/bar/generatedHeader1.h \
3
  foo/bar/generatedHeader12.h)
So muss die zugehörige template-Datei auch in foo/bar liegen.

Wenn möglich würd ich diese aber gerne in foo/bar/template ablegen, z.B. 
wäre dann ein Pfad:
1
foo/bar/template/generatedHeader1.h.template

http://www.gnu.org/software/make/manual/make.html#Automatic-Variables
Hier werden einige automatische Variablen gelistet, mit denen man Pfade 
und Dateinamen manipulieren kann.
Allerdings sind diese wohl auch wieder nur im "Body" erlaubt, nicht aber 
in der prerequisites list.

Gibt es da noch eine Möglichkeit?

von Alexander F. (alexf91)


Lesenswert?

Du kannst foo/bar ein eigenes Makefile spendieren, in dem du die Regeln 
für die generierten Dateien definierst und dann den Build aus einem 
anderen Makefile mit "$(MAKE) -C foo/bar" starten.


Makefile in foo/bar:
1
HEADERS = gen1.h gen2.h gen3.h
2
3
all: $(HEADERS)
4
5
$(HEADERS):%:template/%.template
6
    @echo "Generating file..."

Makefile in /
1
all:
2
    $(MAKE) -C foo/bar

von Sebastian (Gast)


Lesenswert?

Benjamin schrieb:
> Wenn möglich würd ich diese aber gerne in foo/bar/template ablegen

Da könnte vpath helfen.

Vorsicht bei generierten Headern - die Abhängigkeiten dazu kannst du 
nicht mit "gcc -M..." generieren lassen, weil sie dazu schon existieren 
müssten. Du musst also alle Abhängigkeiten deiner Objectfiles zu den 
generierten Headern selbst schreiben.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.