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 12:44 | IT novinky

    Počítačová hra Kingdom Come: Deliverance 2 českého studia Warhorse získala cenu BAFTA v kategorii nejlepší příběh. V konkurenci pěti dalších nominovaných děl porazila i úspěšnou francouzskou hru Clair Obscur: Expedition 33, která v letošním ročníku získala cenu za nejlepší hru roku.

    Ladislav Hagara | Komentářů: 1
    dnes 12:22 | Komunita

    Projekt KDE oslaví v říjnu 30 let. Matthias Ettrich poslal 14. října 1996 do diskusní skupiny comp.os.linux.misc zprávu, která započala historii projektu. Důležité milníky jsou zobrazeny na časové ose KDE.

    Ladislav Hagara | Komentářů: 1
    dnes 02:55 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucí/ho projektu Debian (DPL, Wikipedie). Poprvé povede Debian žena. Novou vedoucí je Sruthi Chandran. Letos byla jedinou kandidátkou. Kandidovala již v letech 2020, 2021, 2024 a 2025. Na konferenci DebConf19 měla přednášku Is Debian (and Free Software) gender diverse enough?

    Ladislav Hagara | Komentářů: 13
    dnes 00:55 | Nová verze

    Byla vydána nová verze 10.3 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Přidána byla podpora Orange Pi 4 LTS. Přibyl balíček Prometheus.

    Ladislav Hagara | Komentářů: 0
    včera 18:55 | Nová verze

    Implementace VPN softwaru WireGuard (Wikipedie) pro Windows, tj. WireGuard pro Windows a WireGuardNT, dospěly do verze 1.0.

    Ladislav Hagara | Komentářů: 2
    včera 16:11 | IT novinky

    V Pekingu dnes proběhl 2. ročník půlmaratonu humanoidních robotů. První 3 místa obsadili roboti Honor Lightning v různých týmech. Nový rekord autonomního robota je 50 minut a 26 sekund. Operátorem řízený robot to zvládl i s pádem za 48 minut a 19 sekund. Řízení roboti měli časovou penalizaci 20 %. Před rokem nejrychlejší robot zvládl půlmaraton za 2 hodiny 40 minut a 42 sekund. Aktuální lidský rekord drží Jacob Kiplimo z Ugandy s časem 57 minut a 20 sekund [𝕏].

    Ladislav Hagara | Komentářů: 4
    17.4. 17:11 | Zajímavý článek

    Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.

    MakeIranBombedAgain❗ | Komentářů: 6
    17.4. 12:44 | IT novinky

    Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.

    MakeIranBombedAgain❗ | Komentářů: 13
    17.4. 12:33 | Nová verze

    Qwen (čínská firma Alibaba Cloud) představila novou verzi svého modelu, Qwen3.6‑35B‑A3B. Jedná se o multimodální MoE model s 35 miliardami parametrů (3B aktivních), nativní kontextovou délkou až 262 144 tokenů, 'silným multimodálním vnímáním a schopností uvažování' a 'výjimečnou schopností agentického kódování, která se může měřit s mnohem rozsáhlejšími modely'. Model a dokumentace jsou volně dostupné na Hugging Face, případně na čínském Modelscope. Návod na spuštění je už i na Unsloth.

    MakeIranBombedAgain❗ | Komentářů: 1
    17.4. 11:00 | Nová verze

    Sniffnet, tj. multiplatformní (Windows, macOS a Linux) open source grafická aplikace pro sledování internetového provozu, byl vydán ve verzi 1.5. V přehledu novinek je vypíchnuta identifikace aplikací komunikujících po síti.

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

    Unixové nástroje – 8 (diff a patch)

    3. 2. 2010 | David Watzke | Návody | 15364×

    Tentokrát se podíváme na vytváření a aplikaci patchů, neboli záplat. Představíme si totiž programy diffpatch.

    Obsah

    diff

    link

    diff je program sloužící k porovnání dvou textových souborů a vypsání rozdílů mezi nimi. Název vychází z anglického slova difference, což znamená rozdíl. Výstup programu se obvykle ukládá do souboru a těmto souborům se říká patche nebo česky záplaty. Tyto soubory mají obvykle příponu .patch nebo .diff.

    Tento program často používají programátoři, a to nejen pro zdrojový kód, ale pro libovolný text v projektu. Když se totiž větší patch zkomprimuje, jde o dobrý způsob jak šířit změny v programu oproti předchozímu vydání. Představte si projekt, jehož balík se zdrojáky má 200 MiB. Vývojáři změní 2000 řádků v různých souborech. Místo toho, aby vydali (pouze) novou setinkovou verzi a nutili lidi, kteří si stáhli předchozí verzi, stahovat zbytečně znova celý balík, poskytnou navíc ještě záplatu, která může po zkomprimování zabírat klidně i méně než 1 KiB.

    Základní použití je velice prosté. Mějme dva soubory obsahující třeba 2 stejné řádky, dále jeden řádek, který bude v každém souboru jiný a dva řádky, které jsou obsaženy pouze ve druhém souboru.

    diff stary.txt novy.txt
    3c3
    < Python
    ---
    > Perl
    4a5,6
    > Haskell
    > Pascal
    

    Možná se divíte co znamená „4a5,6“ (a „3c3“). Jsou to v podstatě souřadnice textu. První číslo (4) značí řádek, na kterém začíná změna. Znak za ním (a) značí, o jakou změnu jde. Pokud se změnil řádek, šlo o change (změnu). Pokud byl řádek přidán, šlo o add (přidání). Další číslo (5) značí řádek, na kterém změna začíná. Pokud změna není jednořádková (jako v případě „3c3“), za čárkou následuje ještě další číslo (6), které značí číslo řádku, na kterém změna končí.

    Programátoři tento výchozí formát programu diff nevyužívají nejspíš zejména proto, že by při aplikaci patche mohlo dojít k omylu. Často se totiž patch aplikuje s jistou tolerancí vůči tomu, když nesouhlasí čísla řádků. K tomu dojde, třeba když na program verze 1.0.1 aplikujeme patch, který byl vytvořen pro verzi 1.0.0. Aby se omylu předešlo a bylo bezpečné této tolerance využívat, existuje další formát. Tím se dostáváme k přepínačům -u-U. Tento formát kolem samotných rozdílů obsahuje sjednocený (unified) kontext. Tedy neobsahuje pouze změněné řádky, ale i pár řádků okolo. Přepínač -U umožňuje nastavit velikost kontextu, přičemž -u nastavuje napevno 3 řádky. Přepínač -u je tedy ekvivalentem -U3. Výstup může vypadat takto:

    diff -u pole.c.old pole.c
    --- pole.c.old  2010-01-26 16:17:07.854861691 +0100
    +++ pole.c      2010-01-26 16:17:13.320576007 +0100
    @@ -10,4 +10,6 @@
                    p[i] = i+1;
                    printf("%d\n", p[i]);
            }
    +       free(p);
    +       return;
     }
    

    Zde si můžete všimnout třířádkového kontextu kolem změny. Pod změnou již tři řádky nebyly, proto je tam pouze jeden. Když je více změn poblíž u sebe (v rámci kontextu), tak se vygeneruje rozdíl do jednoho bloku.

    Přepínače -c-C jsou podobné -u-U, ovšem s tím rozdílem, že kontext kolem změn není sjednocený, ale identický s originálem.

    S přepínačem -b diff ignoruje mezery před konci řádků.

    Dále byly standardizovány přepínače -e-f. První z nich zajistí generování výstupu, který je vhodným vstupem pro program ed. Druhý vyprodukuje podobný alternativní formát.

    Jako poslední zmíním přepínač -r, který aktivuje rekurzivní režim. Lze pomocí něj vygenerovat rozdíl z více souborů najednou:

    diff -ru program-1.0/ program-1.0.1/
    

    patch

    link

    Nástroj patch slouží k aplikování patchů (záplat), které umí generovat výše zmíněný program diff.

    Základní použití vypadá takto:

    patch -i nejaky_patch.diff
    

    Nejdříve si popíšeme nejzákladnější přepínače. Tím hlavním je -p. Vysvětlíme si jej rovnou na příkladu. Hlavička kontextového patche, který byl generován rekurzivně (viz výše), může vypadat třeba takto:

    --- program-1.0/main.c 		2010-01-31 16:09:17.511327226 +0100
    +++ program-1.0.1/main.c 	2010-01-31 16:09:36.300575801 +0100
    

    Teď si představte situaci, kdy máte adresář se zdrojovými kódy nazvaný program-1.0 a záplatu s názvem program-1.0-1.0.1.patch, která obsahuje rozdíly mezi verzemi 1.0 a 1.0.1. Jak je aplikovat?

    # zkopírujeme si zdrojáky do nového adresáře
    cp -a program-1.0 program-1.0.1
    # vstoupíme do nového adresáře
    cd program-1.0.1/
    # aplikujeme patch
    patch -p1 -i ../program-1.0-1.0.1.patch
    

    Takže co dělá -p? Ovlivňuje cesty k souborům, které program vyčte z hlavičky záplaty. Program dostane cestu program-1.0.1/main.c, jenže tam – relativně k adresáři, ze kterého patch spouštíme – soubor není. Je totiž přímo tam, tedy správně by bylo main.c. Přepínač -p s argumentem 1 v tomto případě z cesty odstraní jeden adresář zleva, takže zbyde jen main.c přesně tak, jak potřebujeme. Vzhledem k tomu, že když -p nezadáme, tak se odstraní celá cesta a použije se pouze název souboru, by se v tomto případě patch aplikoval i bez -p. Ovšem s -p0 by to nešlo z výše zmiňovaného důvodu; program by hledal program-1.0.1/main.c a nic by nenašel.

    Dalším důležitý přepínač je -i, kterému jako argument zadáváme cestu k záplatě. To ale není jediný způsob, jak programu předat záplatu. Když totiž nedostane žádný soubor, tak čeká na vstup. Můžeme použít klasické přesměrování shellu. Tato vlastnost se ovšem hodí především při aplikaci komprimovaného patche, protože můžeme využít unixové roury k tomu, abychom se vyhnuli jednomu dočasnému souboru.

    # předání záplaty pomocí přesměrování
    patch < x.diff
    # rozbalenou záplatu rovnou pošleme programu
    bzcat patch-2.6.33-rc6.bz2 | patch -p1
    

    Přepínač -R slouží ke změně podstaty aplikování záplaty. Zkrátka, když už je záplata aplikovaná, pomocí stejného příkazu navíc s -R můžete změny zase vrátit.

    Pomocí přepínače -d si můžete ušetřit použití příkazu cd před záplatováním, protože když mu jako argument zadáte platnou cestu, nejdříve se do ní přepne.

    Normálně se program snaží zjistit typ záplaty sám, ale chcete-li to z nějakého důvodu obejít, lze si to vynutit pomocí přepínačů. Pro kontextovou záplatu použijte -c, pro ed -e, pro normální -n a pro sjednocenou -u.

    Užitečný přepínač je -b, který zajistí zálohování každého změněného souboru – před jeho změnou je soubor zkopírován s příponou .orig.

           

    Hodnocení: 100 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

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

    Komentáře

    Vložit další komentář

    Prcek avatar 3.2.2010 00:25 Prcek | skóre: 43 | Jindřichův Hradec / Brno
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Diff jsem nikdy nechápal, a teď na to nejsem o moc líp :-D.
    Člověk je takový, jak vypadá... A já vypadám jako pravá, nefalšovaná děvka!!!
    3.2.2010 00:37 Ladislav Hagara | skóre: 106 | blog: Ride the Raven
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Denně používám colordiff, lépe se mi dívá na obarvené rozdíly. Občas sáhnu po vimdiff. Do Thunderbirda doporučuji nainstalovat colorediffs rozšíření, ...
    3.2.2010 09:03 fraxinus | skóre: 20 | blog: fraxinus
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    dobra vec je aj program meld
    3.2.2010 10:54 Jaris | skóre: 19 | blog: Jaris
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    alebo vimdiff
    3.2.2010 14:46 Zomp | skóre: 1
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    A nebo v KDE grafický Kompare (nadstavba nad diff, či čímkoliv dle výběru; samozřejmostí je porovnávání "vzdálených" souborů přes KIO a podobně).
    Prcek avatar 3.2.2010 15:47 Prcek | skóre: 43 | Jindřichův Hradec / Brno
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Jo ta grafická verze už se mi líbí víc :-). Pěkně oba dokumenty vedle sebe a barevně označené úseky, kde se soubory liší, to už je pro mě víc stravitelné.
    Člověk je takový, jak vypadá... A já vypadám jako pravá, nefalšovaná děvka!!!
    Prcek avatar 3.2.2010 15:50 Prcek | skóre: 43 | Jindřichův Hradec / Brno
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Aha teď teprve jsem si všiml, že nemám Kompare ale KDiff3, ale asi to bude prašť jako uhoď.
    Člověk je takový, jak vypadá... A já vypadám jako pravá, nefalšovaná děvka!!!
    Fill avatar 4.2.2010 08:27 Fill | skóre: 19 | blog: Fill | Třebíč
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Výstup obyčejného diffu lze též úspěšně obarvit pomocí obecného nástroje na barvení kdečeho - GNU source-highlight.
    3.2.2010 06:20 Ash | skóre: 53
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    První číslo (4) značí řádek, na kterém začíná změna. ... Další číslo (5) značí řádek, na kterém změna začíná.

    Tohle asi jen tak někdo neznalý diffu nepochopí, bude to chtít rozlišovat mezi jednotlivými soubory.
    3.2.2010 10:32 kmarty | skóre: 15
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Bez muceni se priznavam ze tenhle (vlastne vychozi) format diffu jsem poradne nikdy nepochopil a od chvile co jsem objevil unified format jsem se uz ani nesnazil.
    3.2.2010 13:07 trekker.dk | skóre: 72
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Což nic nemění na tom, že těch pár vět po sobě nedává moc smysl.
    Quando omni flunkus moritati
    5.2.2010 00:09 Ash | skóre: 53
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Bez mučení vězte že 4a5,6 znamená, že za řádek 4 se přidá (add) řádky pět a šest druhého souboru.
    5.2.2010 11:14 kmarty | skóre: 15
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Diky. Ale asi si to stejne mou oblibu neziska.
    3.2.2010 06:31 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Když už je řeč o diffu coby nástroji pro generování patchů, nemělo by se zapomenout na důležitý přepínač -N. Bez něj totiž diff v rekurzivním režimu, existuje-li soubor jen v jednom stromu, pouze napíše, že tomu tak je. Nově přidané soubory tedy nejsou v patchi obsaženy a patch nelze použít k vytvoření nové verze ze staré. S přepínačem -N se v takovém případě diff chová, jako by ve druhém stromu soubor existoval a byl prázdný.
    3.2.2010 09:15 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Chtělo by to zmínit i kontextový formát (-c), i když jsem ho v praxi nikdy neviděl. Ale byl to právě ten, který kontext zavedl. Bez toho asi není příliš jasné, kde se vzal název unified. Ten vznikl pravděpodobně proto, že tento formát sjednocuje výhody obou starších formátů.

    Z klasického si vzal dva stavy, tudíž lepší čitelnost. A z kontextového kontext a rovněž podporu pro tvorbu diffu z více souborů, což s klasickým formátem nejde. Gnu diff sice tuto informaci přidá, ale protože výsledek stejně patch nevezme, musel by se diff rozdělit a aplikovat postupně.
    When your hammer is C++, everything begins to look like a thumb.
    3.2.2010 10:08 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše wdiff
    Na řádkově orientovaný text (obvykle zdrojový kód nebo konfigurační soubory) je diff výborný. Ale na běžném textu (formátovaném do odstavců), kde se mění třeba jen pár slov uprostřed dlouhého řádku, dává přehlednější výstup nástroj wdiff(1). Používám na dokumentaci nebo korektury textu.
    Jiří Svoboda avatar 3.2.2010 13:51 Jiří Svoboda | skóre: 37 | blog: cat /dev/mind | Prostějov
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Z mnoha dalších přepínačů diffu se docela často hodí "-y" aneb "--side-by-side".
    3.2.2010 19:00 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    A co diff3, bude?
    In Ada the typical infinite loop would normally be terminated by detonation.
    4.2.2010 18:14 kralyk z abclinuxu | skóre: 29 | blog:
    Rozbalit Rozbalit vše Re: Unixové nástroje – 8 (diff a patch)
    Supr, díky za článek, přehledný souhrn práce s diff a patch mi dycky chyběl...

    Založit nové vláknoNahoru

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