Chào mọi người. Bài viết trước mình đã giới thiệu về Android Library và cách publish lên remote (cụ thể ở đây là Jitpack.io)
Tiếp nối chuỗi bài liên quan đến Library này.
Hôm nay mình đưa ra một tình huống. Khi bạn muốn thay đổi (add, update, fix, …) thứ gì đó trên Library. Sau khi thay đổi source xong, theo thứ tự bạn phải update version của nó -> tạo bản release trên git -> send chúng lên JitPack -> Mong đợi chúng không có lỗi gì. Tiếp đến là bên Project chính, các bạn update version của Library trên Project chính và tiếp đó check nó chạy ổn không. Các bước này sẽ tiếp tục lặp lại nếu như source mà bạn code trong Lib của bạn bị fail.
Tình huống trên gây ra sự mất time và sự chờ đợi. Để giải quyết bài toán trên mình thấy có một giải pháp đó là Local Maven Repository.
Tất nhiên Lib của bạn thường chứa Sample App để sử dụng tất cả các tính năng của Library, vì vậy bạn có thể kiểm tra xem nó có hoạt động hay không mà không cần toàn bộ quá trình mình liệt kê ở trên, nhưng đôi khi vẫn chưa đủ và bạn cần phải kiểm tra trên dự án mà bạn thật sự muốn triển khai Library trên đó.
Những lợi ích mà Local Maven Repository có thể thấy được là:
- Đưa cho bạn 1 lựa chọn nếu bạn chỉ muốn lưu Android Library hoặc module dưới local như là một maven repository trong máy tính của bạn. Từ đó bạn có import dependency một cách trực tiếp vào Project của bạn như thể nó đã từng được publish.
- Đưa ra giải pháp phù hợp để tiết kiệm về mặt thời gian, tránh sự chờ đợi không cần thiết, cũng như tạo ra sự chủ động cho Developer trong quá trình phát triển.
Nào chúng ta cùng đi vào các bước để triển khai.
-
Đầu tiên như thiết lập 2 project mà chúng ta đã setup trước đó: CalculatedApp (Main Project) and CalculatedLib (Lib)
-
Library
- Trong file build.gradle, thêm plugin
- Định nghĩa artifactId và groupId
-
Add Config
- Nếu Lib của bạn là single module, hoặc là có nhiều modules nhưng các modules không có sự phụ thuộc lẫn nhau.
- Nếu Project của bạn có nhiều module là các thư viện độc lập và một module là là tập hợp của các lib đó.
- Tip: Nếu project của bạn chứa nhiều modules. Để config chúng, chúng ta phải tạo cho mỗi một Lib một config giống như trên. Để đơn giản hơn chúng ta có thể tạo 1 file publish_local.gradle file. Trong file này mình cài đặt trong một config chung cho các Lib.
Trong mỗi lib mình chỉ cần set-up groupId và artifactId tương ứng
Đặc biệt là add link dẫn đến file config tổng
- Publish To Maven Local
Tất cả những gì cần lúc này là run task: publishToMavenLocal
Hoặc chạy lệnh Terminal:
<pre> ./gradlew clean ./gradlew build ./gradlew publishToMavenLocal
</pre>Cụ thể ở đây là 2 file:
-
File .pom chứa thông tin của Lib (dạng XML)
-
File .aar là file Lib được build ra
-
Cuối cùng là Add dependency và config vào Project chính sử dụng thư viện của bạn
- Enable mavenLocal() repository vào file Build Systems
- Chú ý là add mavenLocal() vào đầu danh sách. Cần lưu ý rằng việc có mavenLocal ở đầu danh sách sẽ giúp bạn luôn chọn các thư viện có sẵn trong thư mục ~/ .m2 / repository / trước tiên
Tiếp Theo, Add dependency tương ứng vào Project chính và sử dụng functions Library trong source code chính.
Vâng. Đó là chia sẻ nhỏ của mình liên quan đến Library, publish remote vs local của chúng.
Các bạn có thể tham khảo source code mình để bên dưới.
Mong rằng bài viết của mình đâu đấy sẽ giúp các bạn trong cộng đồng Android GST mình. Hẹn gặp lại trong bài viết sắp tới.
Source code:
1 comment
nếu bạn dùng jetbrains ide hoặc android studio thì có thể config dependency link trực tiếp vào project mà 😀