6

我需要一些帮助来找出组织我的 Android 项目的最佳方式(或最佳实践)。为简单起见,假设我的 Android Eclipse 工作区是C:\Android\Projects\. 在该文件夹中,我喜欢将应用程序与库分开,并且我还有另外两个文件夹C:\Android\Projects\ApplicationsC:\Android\Projects\Components.

对于一个项目,我从 GitHub 克隆了一个库到Components文件夹中,假设C:\Android\Projects\Componentes\SampleLib(在该文件夹中有两个文件夹TheLibTheLibExample)。我的应用程序被创建到C:\Android\Projects\Applications\MyTestApp. 然后我按照这些说明将库包含到应用程序中。

现在假设我想使用 GitHub 与开源社区共享我的应用程序。我将创建一个存储库并将所有内容推C:\Android\Projects\Applications\MyTestApp送到某个存储库中。

如果有人想分叉我的应用程序甚至帮助我,它将需要库来编译和运行它,这不包含在我的项目本身中。该default.properties文件将具有类似的内容android.library.reference.1=../Components/SampleLib/TheLib,并且有人也需要手动克隆该库,并且他需要将其放置在相同的相对路径中,否则它会弄乱我的应用程序的源代码控制。

我能想到解决这个问题的唯一方法是像这样组织我的工作区:

C:\Android\Projects\Applications\MyTestApp\TheApp
C:\Android\Projects\Applications\MyTestApp\TheLib
C:\Android\Projects\Componentes\SampleLib

我的存储库应该充满来自C:\Android\Projects\Applications\MyTestApp\.

但是当库更新时会发生什么?我不能简单地提取新更改,我需要将它们复制到TheLib文件夹中。在以前的文件夹组织中,这将不需要,因为我引用的是原始克隆存储库而不是副本。

那我该怎么办?我应该使用选项一并让任何分叉我的项目的人按照他们认为合适的方式处理库依赖项,还是我应该使用第二个选项并通过在原始文件夹中提取更改时保持两个文件夹同步来给每个人更多的工作。存储库?

4

3 回答 3

4

也许 git submodules 会解决你的问题。

于 2011-09-20T17:54:01.213 回答
2

个人认为Android的库项目是FAIL设计。荒谬的是,我想要引用/使用其他代码的唯一方法是获取另一个完整的项目并在 IDE 配置级别设置所有内容。什么是图书馆?它应该是一个以归档格式编译和打包的可重用组件。根据他们的重要说明Library project storage location,我认为没有一个简单的解决方法可以打破僵局并将库作为真正的库进行管理。如果您的库不是那么 androidized,请尝试将编写/构建作为普通 jar 库并使用 maven 管理 jar 库构建/发布和项目依赖项。

嗯,谷歌称它为 Android Library Project而不是 Android Library是合理的。

于 2011-09-19T22:28:19.890 回答
1

我个人认为 git 子模块并没有完全为库依赖提供一个非常易于使用和强大的系统。

Git 子树是更好的选择。我找到了一个非常有用的指南,它解释了如何做到这一点。

基本上,您可以创建一个包含依赖项的子文件夹,并在该子文件夹中克隆存储库:

$ mkdir vendor
$ git remote add -f ABS https://github.com/JakeWharton/ActionBarSherlock
$ git merge -s ours --no-commit ABS/master
$ git read-tree --prefix=vendor/ABS/ -u ABS/master
$ git commit -m "Merged ABS into vendor/ABS/"
# Now another lib
$ git remote add -f Crouton https://github.com/keyboardsurfer/Crouton
$ git merge -s ours --no-commit Crouton/master
$ git read-tree --prefix=vendor/Crouton/ -u Crouton/master
$ git commit -m "Merged Crouton into vendor/Crouton/"

然后,在此示例中,您将拥有两个 repos/libs vendor/;您只需要将它们添加到您的 IDE/构建系统中。

Git 分支和修改比子模块更容易和更直接。

我什至创建了一个小脚本,可以为库列表自动执行此过程。

于 2013-06-13T13:50:02.483 回答