abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 22:22 | Nová verze

    Byla vydána nová verze 9.7 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 18:22 | Komunita

    Vývojáři webového prohlížeče Ladybird dnes oznámili, že mění způsob vývoje. S blížícím se vydáním alfa verze přestávají přijímat veřejné pull requesty. Všechny otevřené veřejné pull requesty budou uzavřeny. Tým nedokáže garantovat bezpečnost AI generovaných pull requestů.

    Ladislav Hagara | Komentářů: 2
    včera 17:33 | Zajímavý software

    OpenLogi (GitHub) je open source náhrada aplikace Logi Options+ pro přizpůsobení myší od společnosti Logitech. Zatím běží pouze na macOS.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Nová verze

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za květen (YouTube).

    Ladislav Hagara | Komentářů: 9
    4.6. 11:22 | Bezpečnostní upozornění

    Úřad pro ochranu osobních údajů řeší desítky stížností na jednotné měsíční hlášení zaměstnavatele, které stát spustil počátkem dubna. Systém, jenž má firmám odlehčit od desítek formulářů, nejenže výrazně zatížil jejich účetní oddělení, ale docházelo v něm i k únikům osobních dat zaměstnanců k firmám, kde nepracovali. Podle ministerstva práce a sociálních věcí stála za problémem technická chyba. „Incident se týkal několika stovek

    … více »
    Ladislav Hagara | Komentářů: 16
    4.6. 10:46 | Nová verze

    Byla vydána (𝕏, Bluesky) nová verze 22.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    4.6. 04:33 | Nová verze

    Vim Classic byl vydán ve verzi 8.3. Drew DeVault oznámil tento fork editoru Vim (verze 8.2.0148, tj. těsně před zavedením Vim9 skriptování) v březnu letošního roku. Důvodem forku bylo, že vývojáři editorů Vim a Neovim začali při vývoji využívat LLM.

    Ladislav Hagara | Komentářů: 7
    4.6. 03:44 | Komunita

    Open source konference DevConf.CZ 2026 proběhne 18. a 19. června v Brně na FIT VUT. Publikován byl program a spuštěna byla registrace.

    Ladislav Hagara | Komentářů: 0
    3.6. 19:44 | Nová verze

    Společnost JetBrains uvolnila verzi 2 svého open-source velkého jazykového modelu (LLM) pro vývojáře Mellum.

    Ladislav Hagara | Komentářů: 0
    3.6. 14:44 | IT novinky

    Probíhá konference Microsoft Build 2026. Microsoft představuje své novinky: kvantový čip Majorana 2, Surface Laptop Ultra a Surface RTX Spark Dev Box s NVIDIA RTX Spark, Intelligent Terminal, Coreutils for Windows (fork Rust Coreutils), AI modely MAI, AI agenta Scout, platformu pro agent-first zařízení Project Solara, …

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1835 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Makefile: problém se závislostmi

    Gilhad avatar 16.4.2023 14:56 Gilhad | skóre: 20 | blog: gilhadoviny
    Makefile: problém se závislostmi
    Přečteno: 779×
    V Makefile mám (kromě dalších) následující pravidla (s příslušnými recepty a v tomto pořadí)
    $(info [$(THIS_MAKEFILE)])
    
    .PHONY: all html plain_files static rsync_upload help more_help clean clean_all
    all: html
    html: $(TARGETS) $(BUILD_DIR)/.nav_dir.nav generated.mk
    $(BUILD_DIR)/.nav_dir.nav: $(DIRNAVS)
    generated.mk: $(THIS_MAKEFILE) $(BUILD_DIR)/.nav_dir.nav
    

    když smažu $(BUILD_DIR)/.nav_dir.nav a dám "make all", tak se mi generated.mk nezbuduje:

    $ rm build/.nav_dir.nav 
    $ make all
    [Makefile]
    build/.nav_dir.nav
    === html ===
    === all ===
    $
    

    teprve až když to dám podruhé

    $ make all
    [Makefile]
    ===  generated.mk ===
    [Makefile]
    compile_rst: input output build   file_5
    compile_rst: input output build  directory_2/subdirectory_5 file_5
    compile_rst: input output build  directory_2/subdirectory_5 file_2
    ....
    === html ===
    === all ===
    $
    

    Já si myslím, že když chybí ten build/.nav_dir.nav a dám přebudovat all, které závisí na html, které závisí na generated.mk, který závisí na tom build/.nav_dir.nav, tak by se měl přebudovat hned na poprvé

    Make si to nemyslí. Kde dělám chybu? Jak ji opravit?

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Gilhad (tazatel))
    16.4.2023 15:51 tttttttttttttt
    Rozbalit Rozbalit vše Re: Makefile: problém se závislostmi
    Pravděpodobně jinde než v tom, co jsi poslal. Zkusil jsem podle toho vytvořit Makefile:
    THIS_MAKEFILE=Makefile
    BUILD_DIR=build
    TARGETS=target
    
    .PHONY: all html plain_files static rsync_upload help more_help clean clean_all
    
    all: html
    
    html: $(TARGETS) $(BUILD_DIR)/.nav_dir.nav generated.mk
    
    $(BUILD_DIR)/.nav_dir.nav: $(DIRNAVS)
    	mkdir -p $(BUILD_DIR)/
    	touch $(BUILD_DIR)/.nav_dir.nav
    
    generated.mk: $(THIS_MAKEFILE) $(BUILD_DIR)/.nav_dir.nav
    		touch generated.mk
    
    target: 
    		touch target
    
    a chová se tak, jak očekáváš:
    ❯ make
    touch target
    mkdir -p build/
    touch build/.nav_dir.nav
    touch generated.mk
    ❯ rm -r build                    
    ❯ make
    mkdir -p build/
    touch build/.nav_dir.nav
    touch generated.mk
    Většinou to jde vyčíst z make --debug resp. make --debug=all
    Řešení 1× (Gilhad (tazatel))
    Gilhad avatar 16.4.2023 19:55 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Makefile: problém se závislostmi
    Díky strašně moc!

    Měl jsi naprostou pravdu a já žil léta v omylu. Celý ten problém způsobilo tohle (úplně jinde v tom Makefilu):

    # .SECONDARY: bez targetu ponecha VSECHNY intermediate fily a nesmaze je (pokud se je podari vyrobit)
    # Define the .SECONDARY target to keep intermediate files
    .SECONDARY:
    

    Ve skutečnosti to sice ty intermediate files sice zachová a nemaže, pokud už je jednou vytvoří (což bylo cílem), ale pokud je něco intermediate file a něco jiného ho potřebuje, ale to něco jiného se stejně bude přebudovávat, tak se ten intermediate file vůbec nemusí tvořit (a to je ten problém).

    https://www.gnu.org/savannah-checkouts/gnu/make/manual/html_node/Special-Targets.html:
    .SECONDARY can be used to avoid redundant rebuilds in some unusual situations. For example:

    Suppose hello.bin is up to date in regards to the source files, but the object file hello.o is missing. Without .SECONDARY make would rebuild hello.o then rebuild hello.bin even though the source files had not changed. By declaring hello.o as .SECONDARY make will not need to rebuild it and won’t need to rebuild hello.bin either. Of course, if one of the source files were updated then all object files would be rebuilt so that the creation of hello.bin could succeed.

    .SECONDARY with no prerequisites causes all targets to be treated as secondary (i.e., no target is removed because it is considered intermediate).
    Ve skutečnosti tam mělo být
    .NOTINTERMEDIATE

    Prerequisites of the special target .NOTINTERMEDIATE are never considered intermediate files. See Chains of Implicit Rules. .NOTINTERMEDIATE with no prerequisites causes all targets to be treated as not intermediate.

    If the prerequisite is a target pattern then targets that are built using that pattern rule are not considered intermediate.
    Tak jsem to opravil a už to dělá co má :)

    Já to používám na vytváření statických stránek na web a mám tam spoustu těch mezilehlých souborů pro urychlení zpracování (seznamy souborů používajících nějaký tag, nějakého autora, v nějakém adresáři ... a často se kvůli takovému mrňavému souboru musí zpracovat naprosto věechny zdrojáky, aby se zjistilo, že se to použije jen v jediném případě), takže když se jednou vytvoří, tak je chci zachovat tak dlouho, dokud je není nutno změnit.

    A jak jsem se koukal, tak se se mnou tenhle špatný překlad/miskoncepce táhne minimálně od roku 2003 ... Takže ještě jednou díky :)

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.