Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Gitで始めるバージョン管理
Search
arm4
September 21, 2018
Technology
600
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Gitで始めるバージョン管理
arm4
September 21, 2018
More Decks by arm4
See All by arm4
Google Data Studio 101
fromarm4
0
180
5 Points Of Customizing Vuetify
fromarm4
4
1.4k
about abstract component design using slots of Vue.js
fromarm4
4
1.5k
laravel_lt_party_with_mokumoku_3
fromarm4
0
420
Make it happen in realtime with Laravel Echo and Pusher
fromarm4
0
1k
Trying to write a code with Laravel+Vue+TypeScript
fromarm4
0
590
Create a Laravel notification via Slack when batch jobs are finished
fromarm4
0
860
solving frontend issues
fromarm4
1
1.8k
Popular Vue.js UI Frameworks in 2019
fromarm4
2
890
Other Decks in Technology
See All in Technology
AIAU_UMEMOGU_ninomiya_slide
ninomiya_ii
0
240
日本 Fintech 未来予測レポート 2027〜2028年(手動編集版)
8maki
1
2.5k
Kiroで書いた 設計書 が AI レビューの 採点基準 になる
ezaki
0
130
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
2
420
AI時代のコスト管理を考えよう〜明日から使える実践AWSノウハウ~
yoshimi0227
0
320
GitHub Copilot 最新アップデート – 「一歩先」の実践活用術
moulongzhang
5
1.5k
PostgreSQL 19 新機能概要 OSC Hokkaido 2026
nori_shinoda
0
160
「勝手に広まる」人気 AI エージェントを爆速で作ろう!(AWS Summit Japan 2026講演資料)
minorun365
PRO
9
2k
iOS アプリの「これって不具合ですか?」を AI に調べてもらう
miichan
0
100
徹底討論!ECS vs EKS!
daitak
0
470
アジャイルな経理と Claude Code と経営の未来
kawaguti
PRO
3
160
2026年6月23日 Syncable Tech + Start Python Club にて
hamukazu
0
140
Featured
See All Featured
It's Worth the Effort
3n
188
29k
The Language of Interfaces
destraynor
162
27k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
200
Claude Code のすすめ
schroneko
67
230k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Speed Design
sergeychernyshev
33
1.9k
Music & Morning Musume
bryan
47
7.2k
Transcript
GitͰ࢝ΊΔ όʔδϣϯཧ by Arm4
͜Ε͔Β͢͜ͱ όʔδϣϯཧͬͯʁ gitͱʁ ϦϙδτϦͱʁ ϫʔΩϯάσΟϨΫτϦͱεςʔδϯά ΤϦΞ gitཧ͞ΕͨϑΝΠϧͷঢ়ଶ gitͷجຊతͳ͍ํ ϒϥϯνʹ͍ͭͯ ଞͷΤϯδχΞͱࢄ࡞ۀ͠Α͏
ຊͷલͷҙࣄ߲ ͋ͱͰΫΠζେձ͢ΔͷͰඞཁͳ͜ͱ ϝϞΛऔΔΑ͏ʹʂ
όʔδϣϯཧͬͯʁ
͜ͷલϦϦʔε ͨ͠ਓϘλϯ ͳΜ͚ͩͲɺ ͏গ͠ΦγϟϨ UIʹ͢Δόʔ δϣϯ̎ͷ͕ ܾ·ͬͨΑʂ PGͷϕϧࢠ SEͷN౻͞Μ
όʔδϣϯ̎ ̏ϲ݄ޙͷϦϦʔ ε༧ఆͰɺͦͷ ؒʹόʔδϣϯ ̍ʹෆ۩߹͕ݟ ͔ͭͬͨΒɺόʔ δϣϯ̍ͷվम Λ͠ͳ͍ͱ͍͚ ͳ͍ΑͶ PGͷϕϧࢠ
SEͷN౻͞Μ
όʔδϣϯ̍ͷίʔυҰࣜΛͯ͠ όʔδϣϯ̎ͷ։ൃΛਐΊΔʹ Ͳ͏͢Ε͍͍͔ͳ͊ʁ /sakimori_1_release /sakimori_1_develop /sakimori_2_develop /sakimori_2_develop_nto /sakimori_2_2_develop /sakimori_2_2_20180613
खಈόʔδϣϯཧ͕ ๊͍͑ͯͨ όʔδϣϯ͕૿͍͑ͯ͘͝ͱʹɺͲΕ͕࠷৽ͰͲΕ͕ਖ਼͍͠ͷ͔ ผͰ͖ͳ͘ͳ͍ͬͯ͘ɻ ୭͕Ͳ͜Λमਖ਼ͨ͠ͷ͔͔Βͳ͍ɻ όʔδϣϯຖͷίʔυͷࠩͷநग़͕༰қ͡Όͳ͍ɻ όοΫΞοϓΛऔΓΕΔͱޙΓ͕Ͱ͖ͳ͍͕ɺࡉ͔͘όοΫ ΞοϓΛऔΓ͗͢ΔͱɺࠞཚΛট͘ɻ ಉ͡ϑΝΠϧΛಉ࣌ʹෳͷਓ͕मਖ਼͢Δ͜ͱ͕Ͱ͖ͳ͍ɻ ্ॻ͖͢ΔͭΓͷͳ͍ϑΝΠϧΛ্ॻ͖ͯ͠͠·͏ɻ
͜͏͍͏Λղܾͯ͘͠ΕΔΑ͏ͳ όʔδϣϯཧͷπʔϧ͕ ͋ͬͨΒ͍͍ͷʹͳ͊ ʊਓਓਓਓਓਓਓਓਓਓਓਓਓਓʊ ʼɹόʔδϣϯཧπʔϧരɹʻ ʉY^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Y^Yʉ
࠷ॳʹొͨ͠ όʔδϣϯཧγεςϜͷߏ ͦΕͧΕͷ࡞ۀऀɺαʔ όʔʹ͋ΔதԝϦϙδτϦ ͔ΒιʔείʔυΛ࣋ͬͯ ͖ͯฤू͠ɺฤू͕ऴΘͬ ͨΒதԝϦϙδτϦʹ ө͢Δͱ͍͏ߏɻ ϦϙδτϦʹมߋͷཤྺ ͕ه͞ΕΔɻ
ूதܕόʔδϣϯཧγεςϜ Subversion CVS Perforce
͜ΕͰ ಉ͡ϑΝΠϧͷιʔείʔυΛ ಉ࣌ʹमਖ਼Ͱ͖ΔΑ͏ʹͳͬͨ͠ όʔδϣϯཧ ؆୯ʹͰ͖ΔΑ͏ʹͳͬͨʂ ͔͠͠ ूதܕόʔδϣϯཧγεςϜʹ ͕͋ͬͨɾɾɾ
ूதܕόʔδϣϯཧγεςϜͷ தԝϦϙδτϦͷ͋Δαʔό͕μϯ͢Δͱɺڞ ಉ࡞ۀ͕Ͱ͖ͳ͘ͳΔɻ ࡞ۀཤྺΛهͨ͠தԝϦϙδτϦ͕োͳͲͷ ཧ༝Ͱഁଛ͢Δͱɺࠓ·Ͱͷཤྺ͕ফࣦͯ͠͠· ͏ɻ αʔόʹଓͰ͖ͳ͍Α͏ͳωοτϫʔΫͷো ͕͋Δͱ࡞ۀཤྺΛه͢Δ͜ͱ͕Ͱ͖ͳ͍ɻ
͜ΕΒͷΛղܾ͢Δ όʔδϣϯཧγεςϜ͕ ੜ
gitͱʁ
ࢄܕόʔδϣϯཧγεςϜ Git MercurialʢϚʔΩϡϦΞϧʣ Bazaarʢόβʔʣ
ࢄܕόʔδϣϯཧγεςϜͷ ߏ ࢄܕͰɺϩʔΧϧڥ ʢࣗͷPCʣʹมߋཤ ྺΛؚΉશͳϦϙδτϦ ͷෳ͕࡞͞ΕΔͱ͍͏ Έɻ ωοτϫʔΫʹଓ͍ͯ͠ ͳͯ͘ཤྺͷௐࠪมߋ ͷهΛߦ͏ࣄ͕ग़དྷΔɻ
Git ։ൃऀLinus TorvaldsʢϦʔφεɾτʔόϧζʣ ϦʔφεLinuxΧʔωϧͷ։ൃऀͰ͋Δ LinuxΧʔωϧͷιʔείʔυཧʹ༻͍ΔͨΊ ʹ2005ʹ։ൃ͞Εͨࢄܕͷόʔδϣϯཧ γεςϜ
ϦϙδτϦͱʁ
repository ʲ໊ʳ 1. ऩೲʦอଘʧॴɺݿ 2. തؗɺඒज़ؗ 3. Լຒॴɺุ 4. ʤࣝͳͲͷʥๅݿɺ๛ͳ͑
ɾA griot in West Africa is a repository of oral tradition. : ΞϑϦΧͷάϦΦޱ ಄ঝͷๅݿͰ͋Δɻ 5. ʤൿີΛଧͪ໌͚ΒΕΔʥ৴པͰ͖Δਓ
ϦϙδτϦ ϓϩδΣΫτͷϑΝΠϧσΟϨΫτϦͷ ঢ়ଶΛهͯ͠อ͓ͯ͘͠ॴ
̎छྨͷϦϙδτϦ ϦϞʔτϦϙδτϦ αʔόʹઃஔͯ͠ෳਓͰίʔυΛڞ༗͢Δͨ ΊͷϦϙδτϦ ϩʔΧϧϦϙδτϦ ֤ΤϯδχΞ͕ͦΕͧΕͷϩʔΧϧPC্Ͱ͏ ϦϙδτϦ
ϦϙδτϦʹ֨ೲ͢Δͷ ΞϓϦέʔγϣϯͷιʔείʔυ ΞϓϦέʔγϣϯʹ༻͢Δը૾ ଞͷਓ͕ΞϓϦέʔγϣϯͷߏங දࣔʹඞཁͳͷ
ϦϙδτϦʹ֨ೲ͠ͳ͍ͷ ͦΕͧΕ͕Πϯετʔϧͯ͠͏ Α͏ͳ֤छϥΠϒϥϦ ݸਓతͳΤσΟλͳͲͷઃఆϑΝ Πϧ Mac OSͰউखʹ࡞ΒΕΔΰϛϑΝ Πϧʢ.DS_Storeʣ Do Not
Commit Please!!
ϫʔΩϯάσΟϨΫτϦͱ εςʔδϯάΤϦΞ
ϑΝΠϧͷঢ়ଶΛཧ͢Δ ̏ͭͷΤϦΞ ϫʔΩϯάσΟϨΫτϦ ʢ࡞ۀσΟϨΫτϦɺ࡞ۀπϦʔʣ ϦϙδτϦ͔ΒऔΓग़͞ΕͨҰͭͷಛఆͷόʔδϣϯͷϑΝΠϧ܈ εςʔδϯάΤϦΞ ʢΠϯσοΫεʣ ࣍ͷίϛοτʹؚ·͍ͤͨϑΝΠϧͷमਖ਼ཤྺͷใΛه͓ͯ͘͠ ॴ ϦϙδτϦ
ʢGitσΟϨΫτϦʣ όʔδϣϯ͝ͱͷϑΝΠϧͷमਖ਼ཤྺΛอ͓ͯ͘͠ॴ
ཧతͳॴ /.git ~ /objects index ~ index.html /images /css /js
ϫʔΩϯά σΟϨΫτϦ εςʔδϯά ΤϦΞ ϦϙδτϦ
ϫʔΫϑϩʔ
gitཧ͞ΕͨϑΝΠϧͷঢ়ଶ
ະ ( untracked ) มߋ͞Ε͍ͯͳ͍ ( unmodified ) มߋ͞Ε͍ͯΔ (
modified ) εςʔδ͞Ε͍ͯΔ ( staged )
gitͷجຊతͳ͍ํ
gitͷΠϯετʔϧ MacʹΠϯετʔϧ͢Δ߹ɺhomebrewͰΠϯε τʔϧ CentOSʹΠϯετʔϧ͢Δ߹ɺҎԼͷϖʔδ ͳͲΛࢀߟʹyumͰΠϯετʔϧ https://qiita.com/wslife/items/7572cdba2d60a00a3ffc
ॳظઃఆ Ϣʔβ໊ɺE-mailΞυϨεɺΧϥʔͷઃఆ࠷ݶ͓ͯ͘͠ http://blog.asial.co.jp/845 git config --global user.name "hoge" git config
--global user.email
[email protected]
git config --global color.ui auto git config --list git config
ϔϧϓΛ֬ೝ͢Δ git help
gitϦϙδτϦΛ࡞Δ(ϦϙδτϦͷॳظԽ) git init
ϑΝΠϧͷঢ়ଶͷ֬ೝ git status
ϑΝΠϧͷঢ়ଶΛදུ͢ه ?? = untracked ' ' = unmodified M =
modified A = added D = deleted R = renamed C = copied U = updated but unmerged
εςʔδϯάΤϦΞͷొ git add
มߋΛϦϙδτϦʹه͢Δ git commit
ϑΝΠϧΛίϛοτ͠Εͨͱ͖ git commit −−amend
ϑΝΠϧΛআ͠gitͷ͔Β֎͢ git rm ※gitʹ·ͩ͞Ε͍ͯͳ͍ϑΝΠϧɺ͜ͷίϚϯυͰ আͰ͖ͳ͍ɻ ※มߋ͕εςʔδ͞Ε͍ͯΔϑΝΠϧɺ-f ΦϓγϣϯͰڧ ੍తʹআ͠ͳ͚ΕͳΒͳ͍ɻ
ϑΝΠϧΛ͠gitͷ͔Β֎͢ git rm −−cached
ίϛοτཤྺΛ֬ೝ͢Δ git log
ศརͳlogͷΦϓγϣϯ git log -p diffΛՃ͑ͨίϛοτϩάʢύονΛදࣔʣ git log -2 දࣔ͢ΔίϛοτϩάͷΛࢦఆ git
log --stat มߋ͞ΕͨϑΝΠϧΛදࣔ(౷ܭใɺεςʔλεΛදࣔ) git log --pretty=oneline ίϛοτϩάΛ̍ߦͰදࣔ git log --pretty=format:"%h - %an, %ar : %s" ϋογϡ - ίϛοτͨ͠ਓͷ໊લ, ૬ର : ໊݅
git log --graph ϒϥϯνͷϚʔδཤྺΛΞεΩʔάϥϑͰදࣔͯ͘͠ΕΔ git log --since=2weeks git log --since=2018-06-07
͍͔ͭΒͰҾֻ͚ͬΔ git log --until=2weeks ͍ͭ·ͰͰҾֻ͚ͬΔ git log --author=beruko ίϛοτͨ͠ਓͰҾֻ͚ͬΔ git log --grep=ސ٬ ໊݅ͰҾֻ͚ͬΔ git log database/seeds/MenuSeeder.php มߋͷ͋ͬͨϑΝΠϧͷύεͰҾֻ͚ͬΔ git log --pretty="%h %an -%s" --author=nto --since="2018-05-01" -- until="2018-05-31" 20185݄ʹnto͞Μͷίϛοτͨ͠ཤྺͷΈΛදࣔ
ࠩΛ֬ೝ͢Δ git diff
༷ʑͳdiffΛදࣔ͢Δ git diff ݱࡏͷϫʔΫσΟϨΫτϦͱεςʔδϯάΤϦΞͱͷࠩΛදࣔ git diff --cached git diff --staged
εςʔδϯάΤϦΞͱ࠷৽ͷίϛοτ(HEAD)ͱͷࠩΛදࣔ git diff HEAD ݱࡏͷϫʔΫσΟϨΫτϦͱ࠷৽ͷίϛοτ(HEAD)ͷࠩΛදࣔ͢Δ git diff HEAD^ git diff HEAD^..HEAD ࠷৽ͷίϛοτͱ࠷৽ͷίϛοτͷͻͱͭલͱͷࠩΛදࣔ͢Δ git diff <ίϛοτϋογϡ> ݱࡏͷϫʔΫσΟϨΫτϦͱಛఆͷίϛοτͱͷࠩΛදࣔ
git diff <ίϛοτϋογϡ>..<ίϛοτϋογϡ> ίϛοτಉ࢜Λൺֱͨࠩ͠Λදࣔ git diff <ϒϥϯν໊>..<ϒϥϯν໊> ϒϥϯνಉ࢜ͷࠩΛදࣔ git diff
-- <ϑΝΠϧͷύε> ಛఆͷύεͷΈͷdiffΛදࣔɻύεͷΈࢦఆ͢Δ߹--লུ Մೳ git diff <ϒϥϯν໊>..<ϒϥϯν໊> -- <ϑΝΠϧͷύε> ಛఆͷϑΝΠϧΛผͷϒϥϯνͱൺֱͨࠩ͠Λදࣔ git diff --word-diff ࠩΛจࣈϨϕϧͰൺֱ͢Δ git diff --diff-filter=M मਖ਼ͨ͠ϑΝΠϧͷdiffͷΈΛදࣔ͢ΔΦϓγϣϯ
εςʔδͨ͠ϑΝΠϧͷऔΓফ͠ git reset ※git resetΦϓγϣϯΛ͚࣮ͭͯߦ͢ΔͱେมةݥͳίϚϯ υͳͷͰؒҧ͑ͯΦϓγϣϯΛ͚ͭͳ͍Α͏ʹҙʂ
ϫʔΩϯάσΟϨΫτϦͷ มߋΛऔΓফ͢ git checkout -- .