Základní pojmy Mercurialu
Decentralizovaný model Mercurialu může být pro nového uživatele matoucí. Tato stránka se pokouší osvětlit některé z jeho základních pojmů.
Contents
Co je v repozitáři
Repozitář Mercurialu obsahuje pracovní adresář a úložný prostor:
Složka store obsahuje úplnou historii projektu. Na rozdíl od tradičních SCM, kde existuje pouze jedna centrální kopie této historie, je každý pracovní adresář spojen se svou vlastní kopii historie. To umožňuje paralelní vývoj projektů.
Pracovní adresář obsahuje kopii projektových souborů ze zadaného času (např. rev. 2) včetně tagů a ignorovaných souborů, které jsou rovněž verzovány.
Potvrzení změn
Provedením příkazu commit se změny v pracovním adresáři zapíší do nového changesetu (neboli nové revize). Změny se vztahují k rodičovské revizi:
Revize 4 byla vytvořena v situaci, kdy pro pracovní adresář byla aktuální revize 2 v době, kdy už existovala revize 3. Revize 4 tvoří novou větev v historii changesetů.
Revize, changesety, čela a tip
Mercurial sdružuje změny jednoho či více souborů do jednotlivých atomických (nedělitelných) changesetů, které jsou revizemi celého projektu. Každému changesetu je přiřazeno pořadové číslo revize. Protože Mercurial umožňuje necentralizovaný paralelní vývoj projektů, bývají tato čísla u různých uživatelů různá. Proto Mercurial uděluje každé revizi také globální ID changesetu. Jsou to čtyřicetimístná hexadecimální čísla, jež mohou být zkrácena na libovolně krátký počet znaků, pokud mají jednoznačný význam, jako např. "e38487".
Větvení a slučování se může vyskytnout kdekoliv v historii revizí. Každá nesloučená větev vytváří nové čelo (head) historie revizí. V naší ukázce jsou čely revize 5 a 6. Revize 6 je považována za tip repozitáře, čelo s nejvyšším číslem revize. Revize 4 je sloučený changeset, protože má dva rodičovské changesety (revize 2 a 3).
Klonování, slučování, akce pull a update
Začněme s Alenkou, jejíž repozitář vypadá následovně:
Pracovní adresář je opět uváděn jako poslední (potenciální) changeset.
Bertík si vytvoří klon tohoto repozitáře a tím získá úplnou, nezávislou lokální kopii Alenčiny složky 'store' ve svém vlastním adresáři:
Bertík nyní může pracovat nezávisle na Alence. Vytvoří dvě změny e,f, které potvrdí příkazem commit:
Alenka si vytvoří svou vlastní paralelní změnu g:
Nyní se Bertík synchronizuje s Alenkou pomocí příkazu pull. Tímto příkazem přitáhne všechny změny Alenčina repozitáře (zde pouze změnu g) do 'store' svého repozitáře. Protože Bertíkova změna e a Alenčina změna g mají stejného rodiče, vytvoří se za revizí d nová větev g, která jako nejnovější nese také označení tip. Všimneme si, že se Bertíkův pracovní adresář přikazem pul nezměnil:
Bertík dále provede příkaz merge (sloučení), který spojí jeho poslední revizi (f) s posledním changesetem (tipem) jeho repozitáře (g). Jeho pracovní adresář má nyní dvě rodičovské revize (f, g):
Po kontrole, že sloučení je v pořádku, vytvoří Bertík příkazem commit sloučený changeset h ve svém 'store':
Když si nyní Alenka přetáhne (příkazem pull) změny od Bertíka, přejdou do jejího 'store' revize e,f a h:
Všimneme si, že provedením příkazu pull se Alenčin pracovní adresář nezměnil. Ta musí ještě provést příkaz update aby synchronizovala svůj pracovní adresář se sloučeným changesetem h (tip). Ten se stane rodičovským changesetem jejího pracovního adresáře.
Nyní jsou Alenčin a Bertíkův repozitář opět stejné.
Necentralizovaný systém
Mercurial je zcela necentralizovaný (distributed) systém. Uživatelé si mohou volně definovat své topologie pro sdílení změn (viz CommunicatingChanges):
Na rozdíl od centralizovaných systémů správy verzí, u nichž experimentování může končit pohromou, u systémů DVCS, jako je Mercurial si prostě vytvoříme klon a experimentujeme. Pokud jsme s výsledkem spokojeni, předáme jej dál, pokud ne, můžeme klonovaný repozitář smazat a zkusit něco jiného.
Co Mercurial neumí
Mnozí uživatelé SVN/CVS mohou mylně očekávat, že lze v jednom repozitáři sledovat více projektů. Pro toto použití není Mercurial stavěn.
Pokud je nezbytně nutné hostovat více projektů v jednom místě, je možné zkusit nástroj Subrepositář, který byl zaveden v Mercurialu 1.3 nebo starší ForestExtension.