问题标签 [pre-commit]
For questions regarding programming in ECMAScript (JavaScript/JS) and its various dialects/implementations (excluding ActionScript). Note JavaScript is NOT the same as Java! Please include all relevant tags on your question; e.g., [node.js], [jquery], [json], [reactjs], [angular], [ember.js], [vue.js], [typescript], [svelte], etc.
git - 处理 git 中重叠更改的建议?
我对 git repo 中的某些代码进行了两次更改,但我想为每个更改单独提交。这些更改并不冲突,但它们确实重叠——也就是说,它们进行独立的更改,有时碰巧在同一条线上。这意味着这git add --patch
行不通。
此类更改的一个示例可能是在所有逗号后添加空格以符合编码标准,并通过在函数前面加上字符串来命名空间。
是否有任何与 git 相关的智能方法来处理这种冲突,或者是从头开始并撤消其中一个更改的唯一选择?
git - 如何撤消保留先前上演版本的“git add”?(索引有历史吗?)
我有一个类似于How to undo 'git add' before commit? ,但有一个重要区别:
背景:
我正在运行一些生成文件的代码,完成后我将添加到我的存储库中。生成文件的代码是新代码,并且在不断变化,所以我有时会多次运行它,并进行更改。
在此过程中,我将生成的文件添加到索引中,因此它们将为最后的一次大提交做好准备。这也允许我检查我对代码的更改是否会在输出中产生更改,如果是,这些更改是什么。但是......我不小心在一个文件上运行了另一个 git add ,该文件同时出现在Changes to be committed
部分(作为 a new file
)和部分Changes not staged for commit
(作为modified
)中。我打算在它上面运行一个 git diff ,但我滑倒并重新添加了它,所以现在我没有办法区分它(我知道),所以......
问题:
有没有办法只撤消最后的暂存操作,这样以前添加的版本仍然/再次在索引中,修改后的文件将再次在我的工作树中,以便我可以区分它?
这些都没有提交或任何东西,因为目标是在我完成这一小轮开发时将它们全部提交。我真的很喜欢 git 通常可以在新文件提交之前向我显示对新文件的更改......但是......我错过了一个机会,现在想知道是否有办法找回它。?
到目前为止,我查找的内容似乎能够让我回到上一次提交(无文件)或文件的当前状态(无论如何我都有),但不能回到上一次提交的中间状态索引中的版本,这从来都不是提交的一部分。任何关于这是否可能的提示(即使是一个可靠的答案,最好是解释为什么会这样)将不胜感激。
svn - 提交被预提交挂钩 SVN 阻止
我的服务器上有颠覆,当我尝试提交时,出现如下错误:
然后我尝试检查 /var/log/httpd/error_log 中的错误日志
我收到如下错误:
那是什么错误?
如何解决这个问题?
msbuild - Perforce 的预提交构建工具
是否有任何工具可用于为 Perforce 运行预提交构建并在成功执行时自动提交更改?
我正在寻找一个服务器端解决方案(与 JetBrains teamcity VS addin 不同,它从客户端执行 + 有一些其他限制,例如无法添加作业 ID),它还可以排队多个签到
git - 在预提交挂钩中测试将要提交的内容
挂钩运行时pre-commit
,存储库可能不干净。因此,如果您天真地运行您的测试,它们将不会与您正在提交的内容相冲突,而是与您的工作树中发生的任何事情相冲突。
显而易见的事情是git stash --keep-index --include-untracked
在开头pre-commit
和git pop
结尾处。这样您就可以针对(纯)索引进行测试,这正是我们想要的。
git add --patch
不幸的是,如果您使用(特别是如果您编辑大块),这会生成合并冲突标记,因为stash@{0}
提交后的内容可能与工作树不匹配。
另一种常见的解决方案是克隆存储库并在新的临时存储库中运行测试。这样做有两个问题:
- 我们还没有提交,所以我们不能轻易地获得我们将要提交的状态的存储库的副本;和
- 我的测试可能对当前工作目录的位置很敏感,例如由于本地环境配置。
git stash --keep-index --include-untracked
如何在不引入合并冲突标记且不修改 post-commit 的情况下将我的工作树恢复到它之前的任何状态HEAD
?
svn - 颠覆限制访问一个文件的增长版本
我试图发现在颠覆中对文件实施写限制的最佳方法。
随着时间的推移,这个文件会有很多标签和分支。一个特定的用户,用户构建,必须有权访问此文件(在所有可能的分支或标签中),而没有其他权限。
如您所见,这不是一组有限的文件,而是一个文件,随着时间的推移,它将被复制到各种分支和标签。但是,我们可以确保文件名在文件树中是唯一的。
为了实现这个限制,在用户'build'上,对于所有名为'changelog.txt'的文件,我想实现一个预提交脚本。
这是最好的方法吗?
谢谢!
git - 如何将预提交文件签入到 git 存储库
我尝试在 myrepo/.git/hooks/pre-commit 中添加一个新的预提交。为什么我在运行时没有看到这个预先提交的新文件
状态
我需要打开一些 git 配置或设置?
谢谢
svn - 无法在 SVN 存储库中提交文件删除;内部错误:非修改文件更改
我似乎不再能够在我的存储库中提交文件删除。
我觉得很奇怪,这在网上找不到。
任何想法?
我正在使用乌龟 1.7.7 和 SVN 1.7.6
我的预提交.bat
和我的预提交钩子
提前致谢
git - git pre-commit 代码修改在提交之后而不是之前应用
我编写了一个预提交挂钩来增加源中的版本号。为什么在提交后应用更改?在提交之前我能做些什么呢?
我知道不建议进行此类自动更改。但从技术上讲,无论如何这应该是可能的。我在 Ubuntu 9.10 上使用 git 1.6.3.3。
git - 如何仅对暂存内容运行 git pre-commit 检查?
假设git status
给出这个:
在这种情况下,只有对 file1.cc 所做的一些更改已为下一次提交暂存/索引。
我运行一个预提交脚本来运行一个样式检查器:
正如这里所建议的,我在运行样式检查之前存储未暂存的文件,然后将它们弹出。但是,在仅暂存文件中的某些更改的情况下,当我在预提交挂钩的末尾弹出存储时,这会导致合并冲突。
有什么更好的方法来做到这一点?我想对即将提交的文件的暂存版本运行样式检查。