Tôi có hai dự án SVN được sử dụng từ kho lưu trữ SVN khác bằng svn: externals .
Làm thế nào tôi có thể có cấu trúc bố trí kho lưu trữ tương tự trong Git?
git submodule
bây giờ có thể mô phỏng svn:external
(kể từ tháng 3 năm 2013).
Tôi có hai dự án SVN được sử dụng từ kho lưu trữ SVN khác bằng svn: externals .
Làm thế nào tôi có thể có cấu trúc bố trí kho lưu trữ tương tự trong Git?
git submodule
bây giờ có thể mô phỏng svn:external
(kể từ tháng 3 năm 2013).
Câu trả lời:
Git có hai cách tiếp cận tương tự, nhưng không chính xác tương đương với svn: externals:
Subtree hợp nhất chèn mã của dự án bên ngoài vào một thư mục con riêng trong repo của bạn. Điều này có một quy trình chi tiết để thiết lập và sau đó rất dễ dàng cho những người dùng khác, bởi vì nó được tự động đưa vào khi kho lưu trữ được kiểm tra hoặc nhân bản. Đây có thể là một cách thuận tiện để bao gồm một phụ thuộc trong dự án của bạn.
Thật dễ dàng để kéo các thay đổi từ dự án khác, nhưng rất phức tạp để gửi lại các thay đổi. Và nếu dự án khác phải hợp nhất từ mã của bạn, lịch sử dự án sẽ được hợp nhất và hai dự án thực sự trở thành một.
Các mô đun con Git ( thủ công ) liên kết đến một cam kết cụ thể trong kho lưu trữ của dự án khác, giống như svn: externals với một-r
đối số. Các mô hình con rất dễ thiết lập, nhưng tất cả người dùng phải quản lý các mô hình con, không được tự động đưa vào thanh toán (hoặc nhân bản).
Mặc dù rất dễ để gửi các thay đổi trở lại dự án khác, nhưng làm như vậy có thể gây ra vấn đề nếu repo đã thay đổi. Do đó, nói chung là không phù hợp để gửi các thay đổi trở lại dự án đang được phát triển tích cực.
svn:externals
. Với phiên bản 1.5, cú pháp đã được thay đổi thành định dạng linh hoạt hơn. Những gì đã được thêm là địa chỉ URL tương đối.
Như tôi đã đề cập trong " Bản cập nhật phiên bản mới của Git ", bạn có thể đạt được tính năng bên ngoài SVN tương tự với các mô hình con Git 1.8.2:
git config -f .gitmodules submodule.<path>.branch <branch>
Điều này là đủ để một mô hình con đi theo một nhánh (như trong cam kết LATEST của một nhánh từ xa của một mô đun con ngược dòng ). Tất cả bạn cần làm là:
git submodule update --remote
Điều đó sẽ cập nhật các mô hình con.
Thêm chi tiết trong " git submodule
theo dõi mới nhất ".
Để chuyển đổi một mô hình con hiện có thành một nhánh theo dõi một nhánh : xem tất cả các bước trong " Mô đun con Git: Chỉ định một nhánh / thẻ ".
svn:externals
?
--depth
nhưng nó không thực sự giải quyết vấn đề.
Tôi là tác giả của công cụ gil (git links)
Tôi có một giải pháp thay thế cho vấn đề - công cụ gil (git links)
Nó cho phép mô tả và quản lý các phụ thuộc kho git phức tạp.
Ngoài ra, nó cung cấp một giải pháp cho vấn đề phụ thuộc đệ quy đệ quy git .
Xem xét bạn có các phụ thuộc dự án sau: biểu đồ phụ thuộc kho lưu trữ git mẫu
Sau đó, bạn có thể xác định .gitlinks
tệp với mô tả quan hệ kho lưu trữ:
# Projects
CppBenchmark CppBenchmark https://github.com/chronoxor/CppBenchmark.git master
CppCommon CppCommon https://github.com/chronoxor/CppCommon.git master
CppLogging CppLogging https://github.com/chronoxor/CppLogging.git master
# Modules
Catch2 modules/Catch2 https://github.com/catchorg/Catch2.git master
cpp-optparse modules/cpp-optparse https://github.com/weisslj/cpp-optparse.git master
fmt modules/fmt https://github.com/fmtlib/fmt.git master
HdrHistogram modules/HdrHistogram https://github.com/HdrHistogram/HdrHistogram_c.git master
zlib modules/zlib https://github.com/madler/zlib.git master
# Scripts
build scripts/build https://github.com/chronoxor/CppBuildScripts.git master
cmake scripts/cmake https://github.com/chronoxor/CppCMakeScripts.git master
Mỗi dòng mô tả liên kết git theo định dạng sau:
Cuối cùng, bạn phải cập nhật kho lưu trữ mẫu gốc của mình:
# Clone and link all git links dependencies from .gitlinks file
gil clone
gil link
# The same result with a single command
gil update
Kết quả là bạn sẽ sao chép tất cả các dự án cần thiết và liên kết chúng với nhau theo một cách thích hợp.
Nếu bạn muốn cam kết tất cả các thay đổi trong một số kho lưu trữ với tất cả các thay đổi trong kho lưu trữ được liên kết con, bạn có thể thực hiện bằng một lệnh duy nhất:
gil commit -a -m "Some big update"
Các lệnh kéo, đẩy hoạt động theo cách tương tự:
gil pull
gil push
Công cụ Gil (git links) hỗ trợ các lệnh sau:
usage: gil command arguments
Supported commands:
help - show this help
context - command will show the current git link context of the current directory
clone - clone all repositories that are missed in the current context
link - link all repositories that are missed in the current context
update - clone and link in a single operation
pull - pull all repositories in the current directory
push - push all repositories in the current directory
commit - commit all repositories in the current directory
Thông tin thêm về vấn đề phụ thuộc đệ quy git đệ quy .
gil
.