- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在重新构建我们现有的代码库。我们正在转向 SVN,并预计软件事件会增加,而我需要一个可扩展且强大的结构。
我希望我们的要求与其他公司的要求没有太大不同,所以我会从你们那里得到一些反馈。
问题
我有很多项目:库和应用程序。应用程序依赖于库,并且某些库相互依赖。
我们有多种产品。每个产品都是一个 MSI,其中包含一些库和一些应用程序。
这些项目是 C++ 的,它们之间的依赖关系是头文件和导入库/DLL - 我们目前正在 Windows 下开发,但最终将移植到 MACOS 和 Linux。
虽然每个项目对于其中一些项目来说都是独立的实体,但我们最终还是会同时更新其中的几个项目。例如,在开发 app_0 时,我们可能会更改 lib_a 中的一些代码(可能是错误修复、添加功能等)。但我们不想强制开发人员必须始终检查项目依赖项的源代码。
潜在的解决方案
每个项目都位于 SVN 中自己的目录中,并有一个“dependency.txt”文件,其中列出了它所需的 header 、.libs 和 .dll,以及应在磁盘上创建这些文件的位置。 checkout 项目后,脚本会自动解析该文件以检索依赖项。头文件从 SVN 检索(部分 checkout ),而二进制文件则从服务器获取。
项目遵循通常的主干/标签/分支结构。
在磁盘上,每个项目都位于其自己的目录中,采用扁平结构。输出目录包含二进制文件,这些二进制文件可以通过构建项目生成,也可以作为处理“dependency.txt”文件的结果从服务器复制。
此结构意味着我们可以处理project_1,而无需检查lib_a 的源代码。但我们仍然可以将库 checkin “./lib_a”并使用其源代码,而无需对project_1进行任何修改,因为 header 和导入库的位置保持不变。
“安装程序”项目用于发布软件。该项目将检查发布所需的所有项目并构建它们。
在发布期间,将为所有项目创建“发布”分支。所有应该进入版本的更改都将提交给它。这样我们只需要在结帐(跟踪发布分支)上运行更新即可获取最新的更改。
最佳答案
有几种处理依赖性问题的方法:
使用发布存储库并将您的库和头文件视为已发布的软件。您可以使用 wget
提取正确版本的库和头文件。优点是您无需将大块二进制代码 checkin Subversion 存储库。 Subversion 确实可以处理二进制文件,但它们会占用您存储库中的大量空间。
您可以使用svn:externals
属性。这允许您自动在另一个目录中包含另一个存储库目录。但是,要非常非常小心!
假设您有以下内容:
trunk/project_A
trunk/project_B
trunk/subproject
您希望在 project_A
中包含 trunk/subproject
,并在 project_A
上设置以下属性:
$ svn propset svn:externals "/trunk/subproject subproject" .
当您分支project_A时,您的子项目仍将位于主干上。不是你想要的。如果您标记 project_A
,该标记将不是快照,因为 subproject
仍然指向主干。有几种方法可以解决这个问题:
使用相对目录。即,svn propset "svn:externals ../subproject"subproject .
。这将确保当您分支 project_A
时,它将查看子项目的分支而不是主干。当您标记 project_A
时。该标签将指向子项目的相同标签。问题是您必须使用project_A 分支并标记您的子项目。
使用特定版本。您可以使用-r
参数将子项目的特定版本固定到project_A,也可以简单地使用标签。无论哪种方式,您都及时卡住了子项目。警告:如果有人 checkout project_A,他们可以修改子项目,即使它位于标记目录上。您将需要某种预提交 Hook 来防止某人更改标签。
关于SVN:跨项目共享公共(public)库/代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16416836/
在做了一些重构之后,在 Eclipse 中,Subversion 在提交时开始提示。我不知道如何解决它。我已经设法删除(并提交了删除 GPFragmentRef.java 。 >niclas@nl:~
我想找出我与前一段时间合并的内容(我只是忘记了),而我的印象是“ svn propget svn:mergeinfo”将打印此类信息。 我正在与进行合并的计算机不同的计算机上运行此计算机。 有任何想法
我要求我的一个开发人员为每个开发人员提供一个不同的主干副本,以便在/branches 中工作(以他们自己的名义)。 该开发人员在颠覆方面没有经验(我也没有),所以我试图通过将主干复制到每个分支文件夹并
我已经使用 git-svn 从工作中克隆了一个 SVN 存储库。在初始克隆期间,我提供了一个 SVN 作者文件。当我进行初始克隆时,git 将 authorsfile 设置为绝对路径。但是,我在工作机
我试图了解常规 svn://和 svn+ssh://访问在颠覆存储库安全性方面的差异。 我已经在自定义端口和 IP 地址中设置了我的 subversion 存储库,并在防火墙上打开了相同的端口,并将存
好吧,我知道这是一个贫民窟设置,但至于为什么,它只是“那些东西”中的另一个。 这是设置。 在 subversion 中,我在一个 repo 中有两个项目: svn/path/projectA svn/
我们目前遇到包含空白的目录问题,这些目录是 svn auth 文件中规则的一部分。所以我们想要基于路径的授权,并且有一个包含以下内容的文件: [/] * = rw [/junk of me] * =
我目前在一台服务器上使用一个 svn 存储库,但为了使其更安全。我在另一台服务器上设置了另一个 svn 存储库,如何使用主服务器上 svn 中的信息镜像辅助服务器上的 svn? 最佳答案 您可以使用
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 4 年前。 Improve this qu
最近我对本地 svn 配置文件进行了一系列更改。我主要纠正了大约 15 种不同文件类型的 svn:mime-type 属性。现在我需要根据这个新配置重置所有以前 checkin 的文件。 SVN 似乎
我最近获得了一个新职位,发现他们没有版本控制。 我将大部分时间花在 Visual Studio 上,过去我使用过(由以前的公司预装)AnkhSVN 和 Visual SVN,他们都使用 Visual
有没有办法恢复svn repo的结帐? 我不小心检查了用户文件夹中的大量代码库,手动删除所有内容真的很痛苦,有没有办法删除工作副本? 有没有类似 svn autoclean ? 最佳答案 SVN 并不
我们想将我们的代码从本地 SVN 服务器移动到托管解决方案,我们应该如何将代码复制并重新导入到托管 SVN 服务器。主要问题是我们不想在重新导入时指向旧的 svn 数据文件。 最佳答案 我认为 svn
我创建了一个分支,然后对需要合并到分支中的主干进行了更改。 TortoiseSVN 有一个非常方便的合并分支->主干实用程序,但是要这样做,我是否必须手动合并特定的修订范围? 最佳答案 使用 SVN
是否有一种简单的方法可以将目录从一个存储库复制到另一个存储库并复制所有历史记录? 最佳答案 最简单的方法是使用: svnadmin dump path/to/repos > repos.out 这将为
我在 Linux 机器上有 3 个 svn 存储库 Main Project -trunk -branches -tags Project A -trunk -branches
我需要使用 SVN 的一些功能,如分支、历史记录、还原、修订我的本地代码副本,但我只想在某个时候提交到服务器存储库,当我完成本地开发时。有可能吗?谢谢。 最佳答案 这就是 Subversion 的模型
我已经用 svn merge -r COMMITTED:PREV 恢复了我最后一次意外的 SVN 提交。 看起来文件现在没问题了,但我仍然在 svn 日志中看到那个意外提交. 还好吗?我可以从历史记录
我正在寻找一种自动将工作副本中的所有未版本控制文件“svn add”到我的 SVN 存储库的好方法。 我有一个实时服务器,可以创建一些应该受源代码控制的文件。我想要一个简短的脚本,我可以运行它来自动添
我有一个 SVN 项目的只读访问权限。我检查了该项目,现在我想处理本地副本(并希望一路对其进行版本控制,但我不能在同一个 SVN 中,因为我没有访问权限,而是我刚刚创建了一个分支)所以,我创建了一个新
我是一名优秀的程序员,十分优秀!