我的Gemfile包含这样一行......
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"它版本本身。
问题在于今天,出于某种原因,它可能与新的rubygems,新的捆绑器,新版本的ruby解释器有关,当bundler抓取那个gem并安装时,生成的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"到版本号?
如何让它停止?
答案 0 :(得分:0)
我担心发布此消息时,结果是用户错误。
% 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”。
“bug”在自我版本代码中,而不是捆绑器或gem系统中的任何内容。