Git submodule Cheatsheet (Polski)

git clone <url> --recursive

Utwórz submodule w aktualnie istniejącym repo

Jeśli chcesz zaktualizować ścieżkę do submodule (tzn. gdzie submodule będzie przechowywany w lokalnym Clone use

git submodule init
git mv oldpath/submodule newpathsubmodule
git submodule update

proszę zauważyć, że zmieni to wpis w,plik gitmodule i możesz nie chcieć go zatwierdzać i przez większość czasu będziesz używać tylkogit submodule update --init ponieważ będzie on bardziej zgodny z SCM

Usuń nieużywany Submodule

Remove referencing lines in .gitmodules
Remove referencing lines in .git/config
rm -rf submodule-dir/
git add
git commit -m "removing submodule"

upewnij się, że sprawdzasz status submodule po usunięciu.

Sprawdź stan podmoduł

podmoduły Git używają Rev commit innego repozytorium i będziesz musiał wypchnąć te zmiany do głównego repo, jeśli chcesz je zaktualizować.,

są one sprawdzane podczas sprawdzania instalacji rev, która wskazuje na podmoduł

$ git log bats
commit aa69c87bd96cb6aa0d586b871cfdd4da3abe0d3e
Author: <[email protected]>
Date: Tue Sep 13 23:47:58 2016 +0900 Set up basic BATS test framework$ git cat-file -p aa69
tree b6e54e3e4a1e6aeae3a46d1c296a08dbd2bfd10a
parent e7134d506995dce59a14df8dd8d49a7a2e844a8d
author <[email protected]> 1473778078 +0900
committer <[email protected]>1473783135 +0900$ git cat-file -p b6e54
100644 blob 82520ca123af9986966f282a109093cf39780722 .gitignore
100644 blob c1ddd1345dfd5b028dd16d55ae5f8aed286a019a .gitmodules
100644 blob b3d51add840a46d2590a3809905f0ebb980471f9 README.md
100755 blob 067db410b175787f5621b7737552e5e0558c7a3a Test
160000 commit 03608115df2071fff4eaaff1605768c275e5f81f bats ### Commit from another repository ###
040000 tree cc240386f9cc2546ec383b9d7afc7f432bf70f69 t

pociągnij podmoduł po klonowaniu repozytorium

# Your repository will have .gitmodules file
cd ~/repository
git submodule update --init # Adding --recursive here will also update the submodule's submodule if it exists

zaktualizuj adres URL repozytorium .git / config from .gitmodules również

git submodule sync # Adding --recursive here will also update the submodule's submodule if it exists

Checkout konkretna gałąź w podmodule

domyślnie Twój podmoduł będzie sprawdzał konkretną repozytorium podczas zatwierdzania do głównego repozytorium. Jeśli chcesz użyć gałęzi w podmodule (na przykład stabilne gałęzie), musisz dodać gałąź.,plik gitmodules i użyj

git submodule update --remote

Jeśli nie podałeś żadnych gałęzi i użyłeś --remote automatycznie pobierze gałąź główną. Jeśli rozwijasz podmoduł, możesz użyć --merge lub --rebase jako wygody

rozwijając w Podmodule

Możesz użyć specjalnego przycisku, jeśli chcesz zaktualizować swój podmoduł z głównego repo

Możesz również użyć foreach comamand

$ git submodule foreach 'git stash'
Entering 'CryptoLibrary'
No local changes to save
Entering 'DbConnector'
Saved working directory and index state WIP on stable: 82d2ad3 Merge from origin/stable
HEAD is now at 82d2ad3 Merge from origin/stable

wreszcie możesz użyć tych aliasów, aby poprawić swój przepływ pracy

Dodaj komentarz

Twój adres email nie zostanie opublikowany. Pola, których wypełnienie jest wymagane, są oznaczone symbolem *