- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
查看this示例显示 refspecs 可以过滤目录/命名空间,如下所示:
+refs/heads/qa/*:refs/remotes/origin/qa/*
但是我正在尝试优化提取,而我正在使用的 repo 协议(protocol)有这样命名的分支:
当尝试过滤这些时,我得到:
版本 6.0.0
有什么方法可以在获取中过滤这些,还是我需要获取所有远程头?
致命:无效的 refspec '+refs/heads/release*:refs/remotes/upstream/release*'
最佳答案
Git 2.6+(2015 年第 3 季度)将允许这种 refspec!
参见 commit cd377f4 , commit 53a8555 (2015 年 7 月 22 日)作者 Jacob Keller (jacob-keller
) .
(由 Junio C Hamano -- gitster
-- merge 于 commit 8d3981c ,2015 年 8 月 3 日)
refs
: loosen restriction on wildcard "*
" refspecsLoosen restrictions on refspecs by allowing patterns that have a "
*
" within a component instead of only as the whole component.Remove the logic to accept a single "
*
" as a whole component fromcheck_refname_format()
, and implement an extended form of that logic in check_refname_component().
Pass the pointer to the flags argument to the latter, as it has to clearREFNAME_REFSPEC_PATTERN
bit when it sees "*
".Teach
check_refname_component()
function to allow an asterisk "*
" only whenREFNAME_REFSPEC_PATTERN
is set in the flags, and drop the bit after seeing a "*", to ensure that one side of a refspec contains at most one asterisk.This will allow us to accept refspecs such as
for/bar*:foo/baz*
.
Any refspec which functioned before shall continue functioning with the new logic.
原始答案(2013 年)
这似乎是不可能的,因为这种限制促进了 remote.c
完成的 refs 匹配。 .
这可以追溯到 Git 1.5.6.5(2008 年 8 月)和 commit b2a5627 ( Daniel Barkalow ) 强制执行“通配符 refspec 必须以斜杠和星号结尾”的规则:
A wildcard refspec is internally parsed into a refspec structure with
src
anddst
strings.
Many parts of the code assumed that these do not include the trailing "/*
" when matching the wildcard pattern with an actual ref we see at the remote.
What this meant was that we needed to make sure not just that the prefix matched, and also that a slash followed the part that matched.But a codepath that scans the result from
ls-remote
and finds matching refs forgot to check the "matching part must be followed by a slash" rule.
This resulted in "refs/heads/b1" from the remote side to mistakenly match the source side of "refs/heads/b/*:refs/remotes/b/*
" refspec.Worse, the refspec crafted internally by "
git-clone
", and a hardcoded preparsed refspec that is used to implement "git-fetch --tags
", violated this "parsed widcard refspec does not end with slash" rule; simply adding the "matching part must be followed by a slash" rule then would have broken codepaths that use these refspecs.This commit changes the rule to require a trailing slash to parsed wildcard refspecs.
IOW, "refs/heads/b/*:refs/remotes/b/*
" is parsed assrc = "refs/heads/b/"
anddst = "refs/remotes/b/"
.
This allows us to simplify the matching logic because we only need to do aprefixcmp()
to notice "refs/heads/b/one
" matches and "refs/heads/b1
" does not.
OP Monte Goulding指出 commit 46220ca ( diff ) 作为这条规则的起源(Git 1.5.5,2007 年 4 月)
We tightened the refspec validation code in an earlier commit ef00d15 (Tighten refspec processing, 2008-03-17) per my suggestion, but the suggestion was misguided to begin with and it broke this usage:
$ git push origin HEAD~12:master
The syntax of push refspecs and fetch refspecs are similar in that they are both colon separated LHS and RHS (possibly prefixed with a
+
to force), but the similarity ends there.
For example, LHS in a push refspec can be anything that evaluates to a valid object name at runtime (except when colon and RHS is missing, or it is a glob), while it must be a valid-looking refname in a fetch refspec.
To validate them correctly, the caller needs to be able to say which kind of refspecs they are.
It is unreasonable to keep a single interface that cannot tell which kind it is dealing with, and ask it to behave sensibly.This commit separates the parsing of the two into different functions, and clarifies the code to implement the parsing proper (i.e. splitting into two parts, making sure both sides are wildcard or neither side is).
关于git - 是否可以在目录命名空间以外的地方使用 refspec 中的过滤器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20450003/
我正在为我的程序编写安装脚本,它应该在 Linux/Unix 操作系统上运行。以下文件的默认目录是什么: 可执行文件(程序)。程序应通过从命令行键入其名称来执行。 共享库。 第三方共享库(程序未开源,
我有一堆用户、组和应用程序注册,我的 MVC 应用程序使用 AAD 数据进行身份验证和授权。是否可以将 Azure Active Directory 从一个租户(目录)迁移到另一个租户(目录)?如果可
查看 cljsbuild 文档 https://github.com/emezeske/lein-cljsbuild :cljsbuild { :builds [{ ; The
忽略已经版本控制的文件 如果你不小心添加了一些应该被忽略的文件,你如何将它们从版本控制中去除而不会丢失它们?或许你有自己的IDE配置文件,不是项目的一部分,但将会花费很多时间使之按照自己的方式工作。
我想使用\tableofcontents 命令,但没有目录从新页面开始或在末尾创建新页面,并且所有内容都是单倍行距。我怎样才能做到这一点?我假设使用 tocloft,但有哪些选择? 谢谢 最佳答案 试
我有一些 javascript 菜单代码,可以在单独的目录中正常工作。但是,当我尝试从同一目录中调用相同的 .js 文件时,它不会看到这些文件。 以下内容来自另一个目录: script type="t
我有这样的路径: /my/path/to/important_folder 在同一级别上,我还有其他文件和文件夹想要在达到与 important_folder 相同的级别时列出。 我的文件夹可能更深,
1、获取文件路径实现 1.1 获取当前文件路径 ? 1
我正在使用最新版本的 NTEmacs。 我写了一个名为“.dir-locals.el”的文件,如下所示。 ((nil . ((tab-width . 8) (fill-column .
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
在我的 .vimrc 中有这些行 :set foldmethod=marker :set foldmarker=SECTION:,ENDSECTION: 用于自定义代码折叠。在我的文件中,相关语言的注
在 fish 中: for x in * echo $x end *这里包括所有目录和文件,如何只列出文件(或目录)? 最佳答案 fish 没有很多花哨的通配语法。但是,目录可以像这样迭代: f
这是我的目录结构: ├── src │ ├── helpers │ │ ├── __init__.py │ │ ├── foo.py │ │ └── bar.py │
我想递归重命名文件夹/目录名称并找到 this solution所以。但是这个命令没有效果 find . -type f -exec rename 's/old/new/' '{}' \; 这是一个正
我想在相册中创建一个文件夹,并希望将图像保存在创建的相册中。 这可能吗?有什么办法可以做到这一点吗? 我已经搜索过,大多数人都说这是不可能的。 感谢您的帮助。 最佳答案 您也许可以使用AssetsLi
如何在python中使用用户定义的名称创建临时文件/目录。我知道 tempfile .但是我看不到任何以文件名作为参数的函数。 注意:我需要这个来对包含临时文件的临时目录上的 glob(文件名模式匹配
我在项目中使用JaCoCo Gradle插件。 作为问题的一个示例,我的大部分代码都在com.me.mysoftware包下。 我正在使用代码生成器来生成build/generated/java/..
我正在尝试使用 Gradle 开始运行 jar 文件 我的任务如下所示: task startServer(type: Exec) { workingDir file("${buildDir}/a
如何在 Ant 中定义一个目录集,其中包括两个目录:项目的基目录和子目录“test”? 看起来您无法使用“/”、“.”或“”专门包含目录集的根目录。例如,这包括“./test”,但不包括“.”:
我正在使用 CTAGs 包,它使用 Sublime Text 2 生成两个文件 .tags 和 .tags_sorted_by_file。 那么当我进行项目搜索(CMD + SHIFT + F)时,如
我是一名优秀的程序员,十分优秀!