我的宝石文件包含这样的行...
gem 'mygem', :git => "git@github.com:me/mygem.git", :tag => '1.2.3'
实际的 gemspec 包含此代码,该代码会根据您签出的 SHA 自动对 gem 进行版本控制......
s.version = begin
head_sha = %x{git rev-parse HEAD}.strip
tag_version = %x{git name-rev --tags --name-only #{head_sha}}.strip
untracked_files = (%x{git ls-files --others --exclude-standard}.strip != '')
_diff_status_only = %x{git diff --quiet --exit-code HEAD}
head_diff = ($?.exitstatus != 0)
version = (tag_version =~ /^d+.d+.d+$/) ? tag_version : "0.0.0.#{head_sha[0..7]}"
dev_tag = (untracked_files || head_diff) ? '-dev' : ''
version + dev_tag
end
。这行得通。如果我签出一个标签并运行"gem build mygem.gemspec",它会正确进行版本控制。
问题是今天,出于某种原因,它可能与新的红宝石、新的捆绑器、新版本的红宝石解释器有关,当捆绑器获取该宝石并安装时,生成的 Gemfile.lock 看起来像这样......
GIT
remote: git@github.com:me/mygem.git
revision: ffffffffffffffffffffffffffffffff
tag: 1.2.3
specs:
mygem (1.2.3.pre.dev)
哪个组件决定在版本号中添加".pre.dev"?
如何让它停止?
正如我在发布此内容时所担心的那样,事实证明这是用户错误。
% git status
On branch master
Your branch is up-to-date with 'origin/master'.
nothing to commit, working tree clean
% ruby -e 'puts Gem::Specification.load("nullgem.gemspec").version'
1.0.0
% touch file_not_in_git
% git status
On branch master
Your branch is up-to-date with 'origin/master'.
Untracked files:
(use "git add <file>..." to include in what will be committed)
file_not_in_git
nothing added to commit but untracked files present (use "git add" to track)
% ruby -e 'puts Gem::Specification.load("nullgem.gemspec").version'
1.0.0.pre.dev
当自我版本控制 gem 确定它是版本"1.0.0">并带有一些本地更改并将自身版本版本为"1.0.0-dev"时,Gem::Specification.load 会生成 gem 版本"1.2.3.pre.dev">
问题是实际损坏的 gem(不是这个测试 gem(,有一个要构建的本机扩展,当它运行时,它会在目录中创建文件使 gem 将自身版本化为"-dev"。
"错误"在自我版本控制代码中,而不是捆绑器或 gem 系统中的任何内容。