- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我很困惑如何使用 git archive
.
我有一个 git 存储库,其中文件夹 Foo、Bar 和 Baz 位于顶层。我需要以类似 SVN 的方式导出文件夹 Foo 以进行快速测试部署。
我了解到我可以使用 git-archive
在SVN-ish export sort of way .
但事情是这样的,以下工作正常:
git archive master | tar -x -C ~/destination
它会在目标 文件夹中生成Foo、Bar、Baz 文件夹。
但是,以下将出错 fatal not a valid object name
:
git archive master/foo | tar -x -C ~/destination
寻找 git archive
的概要程序我看到它可以使用 <tree-ish> [path]
作为参数(相关部分的概要):
git archive <tree-ish> [path...]
如果 master/foo
不是 tree-ish
,那又是什么?
最佳答案
“树状”是指最终指向(子)目录的任何标识符(如 the Gitrevisions documentation 中指定的)树(Git 将目录称为“树”和“树对象”)。
在原发帖者的例子中,foo
是他想要的目录指定。在 Git 中指定(子)目录的正确方法是使用这个“树状”语法(来自 the Git revisions documentation 的第 15 项):
<rev>:<path>
, e.g.HEAD:README
,:README
,master:./README
A suffix
:
followed by a path names the blob or tree at the given path in the tree-ish object named by the part before the colon.
因此,换句话说, master:foo
是正确的语法,而不是 master/foo
。
这是提交式和树式标识符的完整列表(来自 the Gitrevisions documentation , thanks to LopSae for pointing itout ):
----------------------------------------------------------------------
| Commit-ish/Tree-ish | Examples
----------------------------------------------------------------------
| 1. <sha1> | dae86e1950b1277e545cee180551750029cfe735
| 2. <describeOutput> | v1.7.4.2-679-g3bee7fb
| 3. <refname> | master, heads/master, refs/heads/master
| 4. <refname>@{<date>} | master@{yesterday}, HEAD@{5 minutes ago}
| 5. <refname>@{<n>} | master@{1}
| 6. @{<n>} | @{1}
| 7. @{-<n>} | @{-1}
| 8. <refname>@{upstream} | master@{upstream}, @{u}
| 9. <rev>^ | HEAD^, v1.5.1^0
| 10. <rev>~<n> | master~3
| 11. <rev>^{<type>} | v0.99.8^{commit}
| 12. <rev>^{} | v0.99.8^{}
| 13. <rev>^{/<text>} | HEAD^{/fix nasty bug}
| 14. :/<text> | :/fix nasty bug
----------------------------------------------------------------------
| Tree-ish only | Examples
----------------------------------------------------------------------
| 15. <rev>:<path> | HEAD:README, :README, master:./README
----------------------------------------------------------------------
| Tree-ish? | Examples
----------------------------------------------------------------------
| 16. :<n>:<path> | :0:README, :README
----------------------------------------------------------------------
标识符 #1-14 都是“commit-ish”,因为它们都会导致提交,但是因为提交也指向目录树,所以它们最终都会导致(子)目录树对象,因此也可以用作“树状”。
#15 在引用(子)目录时也可以用作树状结构,但它也可用于识别特定文件。当它提到文件时,我不是确定它是否仍然被认为是“树状”,或者如果行为更像“blob-ish”(Git将文件称为“blob”)。
在最低级别,Git 使用四种基本的方式跟踪源代码对象:
这些对象中的每一个都有自己的 sha1 哈希 ID,因为 Linus Torvalds 设计了Git 类似于 content- addressable 文件系统,即可以检索文件基于它们的内容(sha1 ID 是从文件内容生成的)。临 Git本书给出了 this example diagram :
许多 Git 命令可以接受提交和(子)目录的特殊标识符树木:
“提交式”是最终导致提交对象的标识符。例如,
tag -> commit
“树状”是最终导致树(即目录)对象的标识符。
tag -> commit -> project-root-directory
因为提交对象总是指向一个目录树对象(根你项目的目录),任何“commit-ish”的标识符都是定义,也是“树状”。换言之,任何指向commit 对象也可用于引导(子)目录树对象。
但是由于目录树对象从不指向 Git 版本控制中的提交系统,并非指向(子)目录树的每个标识符也可以用于指向提交。换句话说,一组“commit-ish”标识符是“树状”标识符集的严格子集。
如 the documentation ( thanks to Trebor for helpingme find it ) 中所述:
<tree>
Indicates a tree object name.
<commit>
Indicates a commit object name.
<tree-ish>
Indicates a tree, commit or tag object name. A command that takes a
<tree-ish>
argument ultimately wants to operate on a<tree>
object but automatically dereferences<commit>
and<tag>
objects that point at a<tree>
.<commit-ish>
Indicates a commit or tag object name. A command that takes a
<commit-ish>
argument ultimately wants to operate on a<commit>
object but automatically dereferences<tag>
objects that point at a<commit>
.
不能用作 commit-ish 的树形标识符集是
<rev>:<path>
,它直接到目录树,不提交对象。例如,HEAD:subdirectory
。
目录树 对象的 Sha1 标识符。
关于git - tree-ish 在 Git 中是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4044368/
我想实现一个可以按颜色过滤图像的搜索。我的图像模型包含多达 10 个出现在该特定图像中的 UIColors,现在我想要一个过滤器,例如蓝色,绿色,红色,黄色。我如何检查(以指定的容差)该特定图像是否包
问题 Git 中 commit-ish 和 tree-ish 的具体例子是什么? Stack Overflow 问题 "What does tree-ish mean in git?" deals与
如果我需要,比如说,在 asm.js 模块中找到一个数字的整数部分和小数部分,我该怎么做?没有standard operators在 intish 和 doubleish 类型之间转换;即使 Math
我拥有的是一组用户和一组网络,这些用户需要在各种网络上拥有不同的电子邮件地址——有些是内部的,有些是外部的,有些是开发的,而且他们都有自己的命名& 寻址方案。 到目前为止,我所拥有的是简化的,删除了无
我有一个使用 jquery 的 javascript 函数: my.namespace.loadSomeStuff = function() { $.get('/Services/loadSt
首先,这是用于模式匹配的,所以请记住这一点,因为您可能有完全不同的解决方案,我想听听。 我有这一系列数据(暂时称它为 mystring)。 string a = get_starting_letter
我正在尝试在 P5js 中编写一个小型图形可视化工具,但我找不到可遵循的简单(-ish)算法。 我已经找到了使用 D3 来完成此操作的方法,并且我发现了一些密集的教科书片段(如 this ),但我正在
我正在尝试在 P5js 中编写一个小型图形可视化工具,但我找不到可遵循的简单(-ish)算法。 我已经找到了使用 D3 来完成此操作的方法,并且我发现了一些密集的教科书片段(如 this ),但我正在
public static boolean Xish 此方法应按以下顺序接受两个参数:要检查的单词的字符串和由要检查的字母组成的字符串。例如,如果一个单词以任意顺序包含字母 e、l 和 f,则该单词被
整个早上我都在用这个代码撞墙,最后决定来这里寻求帮助。 我有以下标记。 Summary THIS IS AN IMAGE "> 以及下面的 Jquery。 $(".cs").live('click',
所以我正在做一些关于回调函数的练习,我想自己尝试一下,并将它与 setTimeout 方法一起使用,令我惊讶的是,它没有按预期工作。请问我做错了什么在这里。 function first(number
我需要创建可以手动填写并以数字方式阅读的表格。我计划使用一种带有行和列的 scantron 式格式,用户只需在相应单元格的圆圈中着色,计算机就会根据单元格矩阵中的 xy 位置知道该值。就像一个exce
我正在尝试编写一个程序,作为其功能的一部分,它会连续捕获视频并实时或尽可能接近实时地计算给定帧的视频数据的平均亮度。这是我第一次涉足任何视频东西/iOS 相机东西,所以除了我自己的东西之外,我有点把我
我在 mySQL 数据库中有下表(注意:这些是总结的,因此它们与这个问题相关,一些列已被省略)。 author (id, username, password etc.) thread (id, ti
由于我无法控制的原因,我必须将带有一些 Unicode 字符的(英语)文本转换为 ASCII(以便在别处进一步处理)。例如: Deutsche Börse 当我这样做时: u'Deutsche Bör
我不断使用以下代码进行 segmentation 。将 4000 更改为 1000 可使代码运行良好。我会认为我这里有足够的内存...我该如何解决这个问题? #include #include #
我有一个对象列表,我想以随机顺序连续访问这些对象。 我想知道是否有一种方法可以确保随机值并不总是相似。 例子。 我的列表是队列列表,我试图交错这些值以生成用于测试的真实场景。 我并不是特别想要队列 1
我有一种情况需要优化无序集的创建。预期的元素数量约为 5-25M。我的第一个想法是我应该事先准备好所有数据并做一些类似的事情 unordered_set s(data); 代替 for (auto&
我有一个使用大图像作为背景的网站。这是一个大小为 134KB 的 jpeg - 到目前为止我真的无法得到它。我已经在低质量 jpeg 设置的 photoshop 中将其保存为网络。它的尺寸是:1920
在数组中的相同索引位置使用来自多个数组的参数创建类的新实例的“ruby-ish”方法是什么? 例如,我目前在做: array1.each_with_index { |element, i|
我是一名优秀的程序员,十分优秀!