make

Program make je utilita pro automatizaci překladu zdrojových kódů do binárních souborů (spustitelné soubory ELF, EXE, knihovny a podobně). Soubor nazvaný Makefile určuje postup utility make při překladu a definuje závislosti mezi zdrojovými soubory. Při sestavování cíle sleduje make topologické seřazení v Makefile. Přestože jsou dnes v oblibě různá integrovaná vývojová prostředí (IDE) a jazykově specifické kompilátory, je make a tedy i Makefile stále široce využíván, zvláště pak na unixových platformách.

make
VývojářStuart Feldman
První vydání1977
Operační systémmultiplatformní
Vyvíjeno vC
Typ softwaruautomatizace sestavování programu, standardní UNIXová utilita či příkaz, skriptovací jazyk, programovací jazyk a programovací jazyk se syntakticky významným odsazováním
LicenceGPL
Webhttp://www.gnu.org/software/make/
Některá data mohou pocházet z datové položky.

Původ

Přestože existuje mnoho utilit sledujících závislosti souborů při kompilaci, make je jednou z nejrozšířenějších. Mezi nejrozšířenější se řadí díky tomu, že existuje v Unixu již od verze PWB/UNIX 1.0. Tato verze se vyznačovala množstvím nástrojů zaměřených na vývoj software. Make byl původně vytvořen Stuartem Feldmanem v roce 1977 v Bellových laboratořích. V roce 2003 byla Dr. Feldmanovi udělena cena ACM Software System Award za vynález tohoto důležitého nástroje.

Před představením make se Unixový překladový (dále jen build) systém skládal z "make" a "install" shellových skriptů doprovázejících zdrojové kódy. Schopnost kombinace příkazů pro různé cíle v jednom souboru, abstrakce řešení závislostí a archivace byly důležitým krokem směrem k moderním build systémům.

Moderní verze

Kód programu make prošel množstvím úprav a také byl několikrát zcela přepsán. Všechny varianty ovšem používaly stejný formát souboru Makefile a stejné základní algoritmy. Postupem času vznikly varianty obsahující množství vlastních nestandardních vylepšení. Některé z nich jsou:

  • BSD make, který je odvozen z verze Adama de Boora na verzi make schopnou vytvářet cíle paralelně. Tato verze si je schopná poradit s modifikacemi pro FreeBSD, NetBSD a OpenBSD. Nejzajímavějšími vlastnostmi jsou podmínky a opakovací smyčky, které jsou aplikovatelné v parsovací části. Jsou využívány při programátorském přístupu ke konstrukci Makefile, který generuje cíle v runtime.
  • GNU Make, který je součástí Linuxových distribucí, je často zmiňován ve spojení s GNU build systémem. Jeho rozdíly od tradičního make jsou nejvíce zřetelné v porovnávání šablon v grafech závislostí a sestavování cílů. Stejně tak tomu je u množství funkcí, které mohou přinutit make například získat seznam souborů v konkrétním adresáři.
  • Microsoft nmake, dostupný ve Windows. Z pohledu schopností nabízí oproti dvěma výše zmíněným variantám pouze základní vlastnosti. Microsoft nmake nemá nic společného s nmake z AT&T a Bell Labs pro Unix.

POSIX obsahuje standardizaci základních dovedností a operací make utility. Make je implementuje v různých stupních. Obecně mohou být jednoduché varianty souboru Makefile využívány bez problémů různými verzemi nástroje make. Některé verze GNU make a BSD make nejdříve hledají soubory nazvané "GNUmakefile", resp. "BSDmakefile", které umožňují rozlišit chování specifické pro konkrétní variantu nástroje make.

Výhody a nevýhody

Make vyžaduje od programátora manuální popis všech závislostí mezi soubory projektu. Zmíněný postup je ovšem náchylný k chybám. Při opomenutí některé závislosti není chyba okamžitě zřejmá. Pomoci může vytvoření Makefile generujícího závislosti, ale častěji se využívá řešení s využitím speciálního generátoru, např. nástroje automake poskytovaného GNU projektem.

Další problém, který není dobře řešen, je tvoření kompilačního procesu na míru platformy. Například kompilátor užívaný na jedné platformě nemusí akceptovat některé volby využívané jiným. Tento problém je řešen generováním platformě specifických instrukcí kompilátoru, které jsou zpracovány make. Využívá se nástroje autoconf a CMake.

Make využívá v souboru Makefile syntaxi, která používá tabulátor a bílé znaky. Neexistuje mnoho textových editorů, které by podporovaly názorné zobrazení rozdílů mezi bílými znaky a usnadnily tím tvorbu Makefile. Znaky tab také nebývají jednotně reprezentovány. Kvůli těmto problémům je syntaxe Makefile často kritizována. Některé projekty jako Apache Ant se snažily předělat lepší syntax make, což je to vcelku nepodstatné pro programátory využívající generátory Makefile.

S příchodem moderních IDE (hlavně na ne-unixových platformách) se velmi málo programátorů zaobírá manuální správou závislostí mezi soubory projektu. Úkol správy závislostí je přenesen na IDE, kde je automatizován. Stejně tak mnoho moderních programovacích jazyků používá jazykově-specifické způsoby výčtu závislostí, které jsou efektivněji rozpoznány s použitím jazykově-specifických kompilačních utilit.

Make je považován za deklarativní programovací jazyk[1][2][3] a tyto jazyky jsou někdy považovány za složitější pro programátory zvyklé na příkazové programovací jazyky.[4]

Struktura Makefile

Makefile se skládá z řádků textu definujících závislost cíle na souborech. Cílem může být množina souborů, nebo název pravidla. Např. výstupní soubor kompilace je značen jako cíl závislý na svých zdrojových souborech a souborech odkazovaných interně. Po řádku naznačujícího závislosti může následovat série příkazových řádků. Příkazové řádky se označují odsazením pomocí tabulátoru. Příkazové řádky definují transformaci vstupu do výstupu. Transformace se aplikují pouze tehdy, pokud je cíl starší než některý ze souborů/odkazů, na kterých je závislý. Základní struktura je:[5]

# Komentář
cíl: závislost
	příkaz 1
	příkaz 2
.
.
.
	příkaz n

Makefile může obsahovat definice proměnných a odkazovat se na jiné Makefile. Proměnné v Makefile mohou být přepsány příslušnými argumenty z příkazového řádku při spouštění make. Tímto způsobem lze specifikovat rozdílné chování při sestavování cíle. Například proměnná "CC" je často používána v Makefile jako odkaz na kompilátor jazyka C, ovšem uživatel si může přát použít alternativní kompilátor.

Sufixová pravidla

Sufixová pravidla umožňují definovat závislosti a způsob vytváření souborů podle přípon jmen souborů. Například pravidlo, že z každého zdrojového souboru v jazyce C s příponou .c lze překladačem cc získat cílový soubor s příponou .o lze zapsat pravidlem:

.c.o:
        cc __SUB_LEVEL_SECTION_4__lt; -o $@

Řetězce $@ a __SUB_LEVEL_SECTION_4__lt; jsou tak zvané automatické proměnné a zastupují cílové jméno, respektive tzv. „implicitní“ zdroj. Existuje mnoho dalších automatických proměnných.[5][6]

Automatické proměnné

ProměnnáVýznam
$@jméno cíle
__SUB_LEVEL_SECTION_5__lt;jméno první závislosti
$+jména všech závislostí (včetně jejich opakování)
$^jména všech závislostí bez opakování, u členů knihoven pouze jejich jména
$?jména všech závislostí, které jsou novější než cíl
$%jméno závislosti bez jména knihovny
$*kořen jména (část odpovídající znaku % ze sufixového pravidla, resp. jméno předpokladu z explicitního pravidla bez přípony)

Příklad Makefile

Níže je uveden velmi jednoduchý Makefile, který definuje kompilaci zdrojového souboru nazvaného helloworld.c s použitím cc jako kompilátoru jazyka C. PHONY tag je specialita, která příkazu make oznamuje, které názvy cílů nejsou soubory.

helloworld: helloworld.o
	cc -o $@ $<
 
helloworld.o: helloworld.c
	cc -c -o $@ $<
 
.PHONY: clean
 
clean:
	rm -f helloworld helloworld.o
 

Související články

  • Apache Ant
  • CMake
  • configure script
  • Flowtracer
  • GNU Automake
  • imake
  • Jam
  • mk
  • qmake
  • Rake
  • SCons
  • Debian Package Maker

Reference

V tomto článku byl použit překlad textu z článku Make_(software) na anglické Wikipedii.

  1. What is a DSL? [online]. phoenix.labri.fr [cit. 2009-05-02]. Dostupné v archivu pořízeném dne 2007-10-23. (anglicky)
  2. Choreography and REST [online]. w3.org [cit. 2009-05-02]. Dostupné online. (anglicky)
  3. Target Junior Makefiles [online]. robots.ox.ac.uk [cit. 2009-05-02]. Dostupné online. (anglicky)
  4. Thesis Defense on XForms [online]. [cit. 2009-05-02]. Dostupné online. (anglicky)
  5. Je potřeba mít na paměti citlivost make na bílé znaky. Odsazené řádky příkladu jsou ve funkčním kódu odsazeny pomocí tabulátoru.
  6. 10.5.3 Automatic Variables [online]. gnu.org [cit. 2009-05-02]. Dostupné online. (anglicky)

Externí odkazy

(česky)

(anglicky)

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.