/trunk + ProjectA + ProjectB + Common + ProjectCore + References
ProjectA和ProjectB将提供最终产品,每个产品都有自己的发布生命周期.两个项目都使用ProjectCore中的相同公共库.
ProjectCore也有自己的发布生命周期.
在ProjectA和ProjectB中,我们想要引用ProjectCore的库.在ProjectCore成功发布生命周期后,ProjectCore-libs被添加到SVN. ProjectCore-libs被添加到References文件夹中.
通过这样做,我们释放(冻结)我们的ProjectCore构建,作为一个经过全面测试的组件.所以我们有多个Core-lib版本:
> RLS_Core_1.00
> RLS_Core_1.01
> RLS_Core_2.00
> RLS_Core_3.00
由于我们将已发布的库(dll)添加到SVN,因此ProjectA和ProjectB可以引用它们.
这样做的最佳方法是什么?
方法1
将ProjectCore-libs添加到名为RLS_Core_X_XX的References下的新文件夹中的SVN.
在ProjectA和ProjectB的解决方案中,我们添加对此唯一文件夹的引用:./ turunk / Common / References / RLS_Core_X_XX.
方法2
将ProjectCore-libs添加到一个相同的文件夹References / Core下的SVN.如果其中有一个“旧”版本,它将是一个提交.
在ProjectA和ProjectB的解决方案中,我们添加了一个对./trunk/Common/References/Core的引用.我们使用SVN外部属性来定义必须为ProjectA和ProjectB使用Core-lib的哪个版本.
在这两种方法中,开发人员明确地需要决定他想要在他的项目中使用哪些Core-libs.除非由于缺少功能而必须升级,否则该规则将保留相同的Core-libs.
方法1:在项目解决方案中编辑.方法2:在外部属性中编辑.
什么方法是首选的?
解决方法
完成此操作后,(并且由于您需要将所有引用包含在构建的程序集中),最好将已发布的程序集分别复制到每个项目的Reference子文件夹中.
这样,无论何时创建分支,您都拥有所需版本的确切快照,并且它独立于常见的开发.
换一种说法:
/RepoRoot + ProjectA + branches + tags + v1.0 + v1.1 + trunk + references (includes 3rd-party and ProjectCore) + ProjectB + branches + tags + v0.8 + v1.2 + trunk + references + ProjectCore + branches + tags + v2.0 + v2.1 + trunk + references
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。