Frage zu Makefile für MINGW/GCC linker



  • Hier noch mal wie das auf Kommandozeile laut MinGW aufgerufen wird:
    http://www.mingw.org/wiki/sampleDLL
    Passende Umgebung (Path) setze ich mal voraus.

    CYGWIN - nicht jeder hantiert in der Form mit dem MinGW.
    Also läuft dein Script nicht überall. Hab die Möglichkeit bezüglich der Scripte unter den neuen Windows, Stichwort "Powershell", noch nicht in der Hinsicht getestet.

    MfG f.-th.



  • Super Herzlichen Dank für die Antworten !

    Mit den letzten beiden Antworten (abc.w f.-th.) konnte ich richtig viel anfangen, das ist schon mal ne perfekte erklährung warum makefiles sinniger sind...

    http://www.mingw.org/wiki/sampleDLL

    Wird mir hoffentlich weiter helfen, sieht auf jeden fall so aus als könnte ich damit weiter kommen...

    Den ansatz shell script werde ich dann mal vernachlässigen und mich weiter mit Makefiles beschäftigen... irgendwie muss ich das ja mal zum laufen bekommen ^^

    Ihr habt mir auf jeden fall deutlich weiter geholfen !

    Mfg McMorf



  • So, hab das jetzt mal total minimalistisch gemacht...
    und ja, es funktioniert !

    CC = gcc                                                                                    
    CPP = g++                                                                                  
    LD = $(CPP)                                                                                
    CFLAGS = -Wall -g                                                                         
    
    LDDIR = -L./ -ldllBsp1
    LDFLAGS = $(LDDIR)                                                                      
    RM = rm -f                                                                                  
    
    OBJS = main.o
    SRCS = main.cpp
    PROG = main.exe
    
    all: $(OBJS)
    	$(LD) $(SRCS) -o $(PROG) $(LDFLAGS)
    

    jetzt hab ich ne frage die mich beschäftigt....
    was hat das mit den *.o dateien genau auf sich ?
    also bei meinem shell script z.b habe ich diese ja nicht gebildet....

    und wofür brächte man das ?:

    depend:
        $(CPP) $(CFLAGS) -MM $(SRCS) > depend
    

    das sind ja alles sachen die z.B von DEV-CPP auch mit gebildet würden, ich verstehe nur nicht wozu....

    Aber trotzdem erst mal Danke für die tolle hilfe hier, so komme ich doch immer n stückchen weiter !!! Will halt so langsam mal verstehen ^^



  • also *.o hab ich schon mal verstanden...

    hier speichert der compiler zwischen und deswegen muss nicht bei jeder Änderung das gesamte projekt neu kompiliert werden (denke nicht das meine progs so groß werden das ich das zwingend benötige)

    bleibt nur noch die frage wozu depend ?

    Mfg McMorf



  • Zum Thema mehrere Kerne...

    Also klar... nen shellScript bekomme ich ohne CYGWIN(o.ä.) nicht unter Windows zum Laufen... das verstehe ich....

    Prüfst Du im Skript den Rückgabewert des Compilers?

    bei einem Shellscript bricht MinGW bei error ab...
    bei nem Makefile auch...
    wozu den Rückgabewert überprüfen ? ich sehe es doch dann in der Shell ?!?

    Was mir jetzt nicht ganz klar ist....:

    Nutzt Dein Skript mehrere Kerne aus? Nein, ein Skript wird von oben nach unten abgearbeitet. Mit make könnte man die Aufgabe auf mehrere CPU-Kerne verteilen, d.h. man könnte ein Projekt deutlich schneller bauen, mit dem Skript nicht.

    also mal auf mein beispiel bezogen:

    COMPILER=	G++                                                                              
    SOURCE= 	main.cpp
    OUTPUT= 	main.exe
    CFLAGS= 	-Wall -g -mwindows                                                                        
    LDIR= 		-L./
    LIBS=		-lm libdllBsp1.a		
    
    RM = 		rm -f                                                                                  
    OBJS= 		main.o
    
    LIBS1 = $(LDIR) $(LIBS)
    
    all:
    	$(COMPILER) -c $(SOURCE) -o $(OBJS)
    	$(COMPILER) $(SOURCE) -o $(OUTPUT) $(LIBS1) $(CFLAGS)
    
    clean:
    	$(RM) $(PROG)
    	$(RM) *.o
    	$(RM) depend
    

    wie würde ich das jetzt auf mehrere kerne aufteilen ?
    und warum sollte das mit einem shellscript nicht gehen ? wird nicht letzten endes die aufgabe eh an MinGw übergeben ?

    Fragen über fragen... sehe schon das thema wird mich noch länger beschäftigen 😉

    Mfg McMorf



  • Eine 'test.cpp' wird compiliert zur 'test.o'.
    Wenn die 'test.o' gelinkt wird es eine 'test.exe'

    Das ist ein Einfachst-Beispiel beim MinGW.

    Wenn es ein wenig umfangreicher wird kannst du auch mehrere '.o' Dateien zu einem Projekt zusammen linken. Das Ergebnis muss auch nicht 'test.exe' heissen. Da kannst du auch andere Namen mit der gleichen Endung '.exe' wählen.

    Wenn eine der '.cpp' in einem grösseren Projekt nicht geändert wurde, brauchen nur die geänderten vor einem gemeinsamen Linken neu kompiliert werden.

    Soweit eine Kurzfassung. Da kann man noch ausführlicher was dazu schreiben.

    MfG f.-th.



  • McMorf! schrieb:

    Zbei einem Shellscript bricht MinGW bei error ab...
    bei nem Makefile auch...
    wozu den Rückgabewert überprüfen ? ich sehe es doch dann in der Shell ?!?

    Wenn im Skript Hunderte Dateien gebaut werden, übersiehst Du die Fehlermeldung von MinGW. MinGW bricht bei einem Fehler ab, aber Dein Skript nicht. Dein Skript wird weiter abgearbeitet, egal was passiert. Wenn, dann müsste man bei jedem Aufruf des Compilers, Linkers usw. so was machen:

    gcc -c blabla.c -o blabla.o || error
    

    und error ist eine Funktion die exit aufruft o.ä. Aber das ist ungut, weil man beim Schreiben des Skripts daran denken muss, überall || error dranzuhängen. (Mit meinem Lieblings-Editor gVim wäre es vielleicht kein Problem).

    McMorf! schrieb:

    wie würde ich das jetzt auf mehrere kerne aufteilen ?

    Bei Deinem Makefile wird es wahrscheinlich nicht funktionieren, weil Du im Prinzip nur einen Compiler-Aufruf hast. Es geht mit dem Parameter -j{X}, wobei es eine (ungeschriebene?) Regel gibt, X solle Anzahl der Kerne mal zwei sein. Ich habe einen DualCore, also würde ich so aufrufen:

    make -j4
    

    Bei einem QuadCore so

    make -j8
    

    McMorf! schrieb:

    und warum sollte das mit einem shellscript nicht gehen ? wird nicht letzten endes die aufgabe eh an MinGw übergeben ?

    Das geht bestimmt, nur musst Du als Autor des Skripts die Sisyphos-Arbeit erledigen, manuell Threads erzeugen, die bestimmte Teile deines Projektes bauen usw.



  • Herzlichen Dank für die ganzen Antworten !

    Ihr habt mir wirklich sehr weiter geholfen !

    Mfg McMorf



  • Hi !
    Ich habe noch eine Frage bezüglich makefiles...

    Ich würde gerne wissen wie man die ausgabe eines Programms in eine Variable schreiben kann...

    Sprich ich habe eine z.B hallo.exe die in der console nur hallo ausgibt...
    diese würde ich gerne im makefile als variable angeben also so habe ich es versucht, funktioniert leider nicht:

    VarHallo =´hallo.exe´
    oder
    VarHallo = @echo´hallo.exe´
    

    also mir geht es darum die ausgabe von wx-config in eine variable umzuleiten sprich sowas wie:

    WXCONFIG = ´wx-config --cxxflags --libs´
    

    irgendwie habe ich keinen ansatz dafür gefunden...
    würde mich sehr über eure Hilfe freuen !

    Mfg McMorf



  • VAR =$(shell wx-config --cxxflags --libs)

    Mfg McMorf


Anmelden zum Antworten