阻止捆绑器(或其他什么)将".pre.dev"添加到 gem 版本



我的宝石文件包含这样的行...

  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 系统中的任何内容。

相关内容

  • 没有找到相关文章

最新更新