SlideShare a Scribd company logo
1 of 26
Git
Git är svårt och enkelt
Efter det här så fattar ni förhoppningsvis lite
mer hur Git funkar
Steg 1
Börja med lokalt repository, för hoppyprojekt
Gör säkerhetskopior av mappen
Lär dig hur man använder indexet och lokala
branches
Steg 2
Jobba med andra
git pull / push
git mergetool
snygga till revisionshistoriken genom git rebase
Kan du göra det här med SVN?
Steg 3
Sätt upp remote-branchar (serverbranchar)
Lär dig powertools och bli kär:
git add --patch
git rebase --interactive
git cherrypick
git reflog
Steg 4
Jobba decentraliserat, dvs fler remotes
Git sparar snapshots inte deltan
svn:
git:
Gits datamodell är
väldigt enkel
• Fyra sorters saker sparas i .git/objects
Blobbar - Filer
Träd - En lista på filer och mappar
Commits - En checkin
Tag - En pekare på en commit
• Alla objekt referereras via dess SHA-1, som är en
funktion av filens inehåll
• Branchar ligger utanför, i .git/refs/heads
Blobben inehåller inte info om filnamn etc, bara filens
innehåll
Om man kopierar en fil till ett annat ställe med ett
annat namn, så kommer det inte skapas en ny blob.
Om du ändrar en bokstav i filen så skapas en ny blob
som får en ny SHA-1
Träd
Ett träd inehåller ett gäng pekare (SHA-1or) till blobbar
och andra träd.
git ls-tree fb3a8bdd0ce
100644 blob 63c918c667fa005ff12ad89437f2fdc80926e21c .gitignore
100644 blob 5529b198e8d14decbe4ad99db3f7fb632de0439d .mailmap
100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3 COPYING
040000 tree 2fb783e477100ce076f6bf57e4a6f026013dc745 Documentation
100755 blob 3c0032cec592a765692234f1cba47dfdcc3a9200 GIT-VERSION-GEN
100644 blob 289b046a443c0647624607d471289b2c7dcd470b INSTALL
100644 blob 4eb463797adc693dc168b926b6932ff53f17d0b1 Makefile
100644 blob 548142c327a6790ff8821d67c2ee1eff7a656b52 README
Commit Objekt
Trädet som refereras är rotfoldern i projektet.
En Commit kan ha en eller flera Commits som parents.
Det är så git håller koll på historiken.
Tag
Objektet som refereras är en commit
THAT’S IT!
Vi gör en commit och taggar den:
Bra att veta
Git tar generellt aldrig bort någonting - lägger
bara till.
Om man vet hur man gör kan man alltid återgå
dit man var - git reflog
En branch är bara en pekare till en
commit
➜ ls .git/refs/heads
total 16-rw-r--r-- 1 mkotsalainen CODomain Users 41B Nov 29 16:47
dev-rw-r--r-- 1 mkotsalainen CODomain Users 41B Dec 5 17:23
master
➜ cat .git/refs/heads/master
7d46c2560a41193e03b77720b628cd5aa89e1ae2
➜ cat .git/HEADref: refs/heads/master
Brancharna pekar på deras sista commit
HEAD pekar på din utcheckade branch
git checkout -b iss53
eller
git branch iss53
git checkout iss53
vim foo.txt
git commit -am ‘en commit på iss53’
git checkout -b hotfix master
vim bar.txt
git commit -am “ok nu har jag gjort min hotfix”
git checkout master
git merge hotfix
Fast-foward merge
konflikter kan aldrig uppstå
git branch -d hotfix
git checkout master
git merge iss53
git gör en sk. three-way-
merge mellan c4 c5 och deras
gemensama ancestor c2

More Related Content

Featured

How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
ThinkNow
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
 

Featured (20)

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 

Git

  • 1. Git
  • 2. Git är svårt och enkelt Efter det här så fattar ni förhoppningsvis lite mer hur Git funkar
  • 3. Steg 1 Börja med lokalt repository, för hoppyprojekt Gör säkerhetskopior av mappen Lär dig hur man använder indexet och lokala branches
  • 4. Steg 2 Jobba med andra git pull / push git mergetool snygga till revisionshistoriken genom git rebase
  • 5. Kan du göra det här med SVN?
  • 6. Steg 3 Sätt upp remote-branchar (serverbranchar) Lär dig powertools och bli kär: git add --patch git rebase --interactive git cherrypick git reflog
  • 7. Steg 4 Jobba decentraliserat, dvs fler remotes
  • 8. Git sparar snapshots inte deltan svn: git:
  • 9. Gits datamodell är väldigt enkel • Fyra sorters saker sparas i .git/objects Blobbar - Filer Träd - En lista på filer och mappar Commits - En checkin Tag - En pekare på en commit • Alla objekt referereras via dess SHA-1, som är en funktion av filens inehåll • Branchar ligger utanför, i .git/refs/heads
  • 10. Blobben inehåller inte info om filnamn etc, bara filens innehåll Om man kopierar en fil till ett annat ställe med ett annat namn, så kommer det inte skapas en ny blob. Om du ändrar en bokstav i filen så skapas en ny blob som får en ny SHA-1
  • 11. Träd Ett träd inehåller ett gäng pekare (SHA-1or) till blobbar och andra träd. git ls-tree fb3a8bdd0ce 100644 blob 63c918c667fa005ff12ad89437f2fdc80926e21c .gitignore 100644 blob 5529b198e8d14decbe4ad99db3f7fb632de0439d .mailmap 100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3 COPYING 040000 tree 2fb783e477100ce076f6bf57e4a6f026013dc745 Documentation 100755 blob 3c0032cec592a765692234f1cba47dfdcc3a9200 GIT-VERSION-GEN 100644 blob 289b046a443c0647624607d471289b2c7dcd470b INSTALL 100644 blob 4eb463797adc693dc168b926b6932ff53f17d0b1 Makefile 100644 blob 548142c327a6790ff8821d67c2ee1eff7a656b52 README
  • 12. Commit Objekt Trädet som refereras är rotfoldern i projektet. En Commit kan ha en eller flera Commits som parents. Det är så git håller koll på historiken.
  • 13. Tag Objektet som refereras är en commit
  • 15.
  • 16.
  • 17. Vi gör en commit och taggar den:
  • 18.
  • 19. Bra att veta Git tar generellt aldrig bort någonting - lägger bara till. Om man vet hur man gör kan man alltid återgå dit man var - git reflog
  • 20. En branch är bara en pekare till en commit ➜ ls .git/refs/heads total 16-rw-r--r-- 1 mkotsalainen CODomain Users 41B Nov 29 16:47 dev-rw-r--r-- 1 mkotsalainen CODomain Users 41B Dec 5 17:23 master ➜ cat .git/refs/heads/master 7d46c2560a41193e03b77720b628cd5aa89e1ae2 ➜ cat .git/HEADref: refs/heads/master Brancharna pekar på deras sista commit HEAD pekar på din utcheckade branch
  • 21. git checkout -b iss53 eller git branch iss53 git checkout iss53
  • 22. vim foo.txt git commit -am ‘en commit på iss53’
  • 23. git checkout -b hotfix master vim bar.txt git commit -am “ok nu har jag gjort min hotfix”
  • 24. git checkout master git merge hotfix Fast-foward merge konflikter kan aldrig uppstå
  • 25. git branch -d hotfix
  • 26. git checkout master git merge iss53 git gör en sk. three-way- merge mellan c4 c5 och deras gemensama ancestor c2