Git
Git er et versjonskontrollsystem, en type programvare. Det kjennetegnes ved å være distribuert og ikke mappehierarki-basert (se Egenskaper). Et viktig designkriterium for Git var hastighet ved sammenfletting (merging). Git ble påbegynt av Linus Torvalds, men på et tidlig tidspunkt overtatt av Junio Hamano, som nå leder videre utvikling og vedlikehold. Blant andre distribuerte versjonskontrollsystemer kan nevnes Mercurial, som ble startet omtrent samtidig med Git, og Bitkeeper, en kommersiell forløper som var den viktigste inspirasjonskilden for Git.
Egenskaper[rediger | rediger kilde]
- Distribuert: Git har egne kommandoer, pull og push, for synkronisering med andre repositorier. Dette muliggjør alle-til-alle-synkronisering (ikke bare alle-til-én, som i CVS og SVN). Dessuten, uten implisitt synkronisering trenger man for eksempel ikke å være koblet til nettverk hele tiden for å kunne jobbe. Hovedpoenget med distribusjon i versjonskontrollsystemet er å kunne støtte desentralisert arbeidsflyt, for eksempel tillitsbasert pyramidestruktur, som er typisk for store prosjekter basert på åpen kildekode. Til gjengjeld, for sentralisert arbeidsflyt, blir det flere kommandoer for brukeren å skrive; det som heter commit i CVS og SVN, vil i Git tilsvare sekvensen commit, pull og push.
- Ikke mappehierarki-basert: Undermapper av repositoriet er ikke repositorier (i motsetning til CVS og SVN). Dette er i seg selv en ulempe, men gjør Git i stand til å forstå navneendringer og flytting av filer. Dette har flere fordeler: ikke bare unngås dobbeltlagring hver gang en fil flyttes eller endrer navn, men hvis man også er påpasselig med å bruke Gits mv-kommando, vil historikken dens følge med, og handlingen vil ikke skape konflikt med eventuelle endringer av innholdet.
- Sjekksum av innhold: Alt innhold i et Git-repositorium er indeksert etter sha1-sum. I tilfelle bitfeil i lagring eller overføring, kan man være rimelig sikker på at det vil oppdages. En slik sjekksum har den egenskap at den kan regnes ut dersom man har innholdet og den vil også endres dersom innholdet endres. Git bruker dette både som nøkler til innhold og for å oppdage endringer mellom arbeidskatalog og Git-repositorium.
- Bedre til merge enn til branch: (Dette også i motsetning til CVS og SVN).
Eksempel på bruk[rediger | rediger kilde]
Følgene avsnitt gir eksempler på hvordan man kan bruke git via kommandolinje / terminal. Den tar utgangspunkt i at man med kommandolinje har navigert frem til en mappe som inneholder en fil ved navn "kildekode.cpp".
git init
Lager et nytt git respository i mappen du kjører kommandoen. Det er her alle kildefiler og versjoner av disse lagres.
git add kildekode.cpp
Legger til filen kildekode.cpp midlertidig til versjonen av prosjektet du jobber på. Hvis dette ikke er oppgitt vil du dytte opp til master versjonen (master branch).
git commit -m "lagt til første kildekodefil"
Gjør en commit på endringer og opprettelse av nye filer til versjonen av prosjektet du jobber på. Det vil si at endringene blir lagt til permanent og at disse dukker opp i loggen med meldingen "lagt til første kildekodefil".
git log --graph
Viser loggen til git prosjektet som er i mappen du befinner deg i. Flagget "--graph" lager en grafisk illustrasjon av hvordan de forskjellige versjonene av prosjektet er flettet sammen. Loggen inneholder også hvem som utførte commiten, og når dette ble gjort.
Eksterne lenker[rediger | rediger kilde]
- (en) gits offisielle nettsted
- (en) Kategori:Git – bilder, video eller lyd på Wikimedia Commons
|