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í
×
    dnes 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 19:00 | Nová verze

    Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Upozornění

    eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.

    Ladislav Hagara | Komentářů: 5
    včera 17:00 | Komunita

    Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.

    Ladislav Hagara | Komentářů: 1
    včera 14:33 | Komunita

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

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | Upozornění

    Vyšla kniha Počítačové programy a autorské právo. Podle internetových stránek nakladatelství je v knize "Významný prostor věnován otevřenému a svobodnému softwaru, jeho licencím, důsledkům jejich porušení a rizikům „nakažení“ proprietárního kódu režimem open source."

    javokajifeng | Komentářů: 0
    včera 01:11 | Bezpečnostní upozornění

    Red Hat řeší bezpečnostní incident, při kterém došlo k neoprávněnému přístupu do GitLab instance používané svým konzultačním týmem.

    Ladislav Hagara | Komentářů: 0
    2.10. 23:33 | Nová verze

    Immich byl vydán v první stabilní verzi 2.0.0 (YouTube). Jedná se o alternativu k výchozím aplikacím od Googlu a Applu pro správu fotografií a videí umožňující vlastní hosting serveru Immich. K vyzkoušení je demo. Immich je součástí balíčků open source aplikací FUTO. Zdrojové kódy jsou k dispozici na GitHubu pod licencí AGPL-3.0.

    Ladislav Hagara | Komentářů: 2
    2.10. 22:33 | IT novinky

    Český telekomunikační úřad vydal zprávy o vývoji cen a trhu elektronických komunikací se zaměřením na rok 2024. Jaká jsou hlavní zjištění? V roce 2024 bylo v ČR v rámci služeb přístupu k internetu v pevném místě přeneseno v průměru téměř 366 GB dat na jednu aktivní přípojku měsíčně – celkově jich tak uživateli bylo přeneseno přes 18 EB (Exabyte). Nejvyužívanějším způsobem přístupu k internetu v pevném místě zůstal v roce 2024 bezdrátový

    … více »
    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (46%)
     (14%)
     (16%)
     (18%)
     (14%)
     (18%)
     (15%)
     (14%)
    Celkem 169 hlasů
     Komentářů: 11, poslední včera 07:30
    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: 706×
    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.