- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我最近在 GitHub 上打开了一个存储库。我是 Git 的新手。与新来者一样,我使用默认名称和电子邮件提交,我按照最好的菜鸟传统,发现了五次提交,为时已晚。现在有趣的事情开始了,因为我开始搜索有关如何更改这些提交的作者和提交者姓名的信息。美好的。我基本上找到了以下信息和大量副本:
How to remove selected commit log entries from a Git repository while keeping their changes?
Change the author and committer name and e-mail of multiple commits in Git
这个问题似乎并不少见。我只能说没有一个解决方案有效。其中一半是相同 git filter-branch -f --env-filter
脚本的变体。我尝试多次处理该脚本。问题是应用脚本后,我无法推送。 “快进被拒绝”或类似的东西。好吧,继续前进的唯一方法就是 pull 。 pull 后,所有旧信息又出现了+带有新信息的新分支。我已经坐在这里,有四个分支,以最令人震惊的方式 merge ,所有分支都包含相同的信息,但作者姓名不同,包括我想删除的那个。
好吧,简而言之,我还尝试删除选定的提交,这会产生我无法解决的令人毛骨悚然的冲突(如何???),并将一些提交压缩为具有正确作者的新提交信息,这会导致当前项目状态被破坏。更好的是,我在执行 git rebase -i
后有时会遇到段错误,我在这里得到通知:http://lists-archives.org/git/729800-rebase-i-segmentation-fault-and-another-problem.html是完全合乎逻辑的。唯一(谢天谢地)起作用的是 git rebase --abort
,它多次救了我的命。
我希望我的挫败感不会排斥你,而是让你开心并激励你帮助我。我想:
最终删除上述作者信息
奖励:去除包含相同信息的所有分支。
但是我对第一个也很满意,如果删除过去的分支而不破坏当前状态的障碍对于 git 新手来说太多了。提前致谢。
最佳答案
The problem is that after applying the script, I cannot push. "Fast-forward pushes rejected" or something like that.
如果您尝试修改历史记录,则无法避免此问题。 Git 拒绝推送,因为它会导致数据丢失;在这种情况下,数据是旧作者。你只需要用 --force
标志来 git push
来告诉它你确定你在做什么。
Git 中的困惑问题很难解决。如果 master
是一团糟,我通常会使用 git checkout HEAD~
回溯历史,直到我回到事情并不糟糕的时候。然后我 git branch --force master
将 master
重置到那个点。最后,我使用 git branch -D badBranch
删除了所有杂乱的分支。
小心。
关于git - 更改以前提交的作者姓名 : Fast-forward pushes rejected,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7221132/
以下操作是否完全相同: request.setAttribute(name,"visited"); requestDispatcher.forward(request,response) 和
有两个 header 用于处理请求转发。首先是 X-Forwarded-For第二个是 Forwarded . 我应该使用哪一个? X-Forwarded-For 是事实上的,而 Forwarded
看the documentation for std::forward , template constexpr T&& forward( typename std::remove_reference
给定一个手电筒的nn.Module带有预前钩,例如 import torch import torch.nn as nn class NeoEmbeddings(nn.Embedding):
为了在我的 ASP.NET 应用程序中获取客户端 IP 地址,我使用了 X-Forwarded-For,并从列表中获取第一个 IP 地址(根据我找到的信息,有一个客户端,代理1、代理2..)。但我最近
以下 header 有什么区别? X 转发主机 X 转发服务器 在 Apache 作为代理、Tomcat 作为源服务器的设置中,我在到达 Tomcat 的 HTTP 请求中看到它们。值是(这是我自己的
假设我想要一个通用的高阶函数。最常见的方法是: 一个。通用 lambda auto F1 = [](auto f) { /*...*/ } B.函数模板 template auto F2(F&& f)
为了在我的 ASP.NET 应用程序中获取客户端 IP 地址,我使用了 X-Forwarded-For,并从列表中获取第一个 IP 地址(根据我找到的信息,有一个客户端,代理 1、代理 2 ..)。但
我有一个场景,我想使用 Context.Forward 将上下文转发到另一个对话框,它工作得很好。现在,如果我更新代码以获取对话框堆栈并使用 DialogStack.Forward,则会导致 Stac
我遇到了 std::forward 的两种变体与可变参数模板参数一起使用。 template void foo(Args&&... arga) { bar(std::forward(args
考虑 std::apply 的可能实现: namespace detail { template constexpr decltype(auto) apply_impl(F &&f, Tuple &
我在 Foo Controller 中有一个需要参数的 Action 方法: public function fooAction($one, $two) { $a = one; $b
这些功能是否等效? template void foo(T && t) { bar(std::forward(t)); } template void foo2(T && t) {
在建立从 Fedora 23 到 Centos 7 的 ssh 连接时,我遇到了一个不幸的问题。命令 ssh -X user@centos7和 ssh -Y user@centos7都打印 警告:没有
作为从 Struts 1.x 迁移到 Spring Boot 的一部分,我一直在努力正确转发应有的信息。 最初的 Struts 版本依赖于 web.xml,尽管我想将该项目转换为更新的、完全基于 Ja
我使用了net = cv2.dnn.readNetFromCaffe(protoFile, WeightsFile),然后循环播放实时视频帧以使用net.forward()") bre
我注册了域名 www.a.com 然后我将屏蔽(使用 GoDaddy)流量从 www.a.com 转发到 www.really.long.url.com,因此用户在访问我的网站时只会在地址栏中看到 w
我有一个域,例如 domain.org以及地址为 http://server/node/myname 的服务器上的托管空间. 我如何映射 domain.org至 http://server/node/
我有jsp,具体取决于我正在转发到另一个页面的某些条件。 我有/myjsp/first.jsp 其代码如下, 在这段代码中,if flow come to else 条件控
前向声明和前向引用有什么区别? 在我看来,前向声明是当你声明一个尚未实现的函数时,但这不正确吗?您是否必须查看特定情况以声明案例“前向引用”或“前向声明”? 最佳答案 一个 前向声明是在实现和使用方法
我是一名优秀的程序员,十分优秀!