Compare commits
19 commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
22ddfc8f11 | ||
|
|
a0377b1ffd | ||
|
|
90cd529668 | ||
|
|
fa57346f58 | ||
|
|
1e04690321 | ||
|
|
2eaad8232d | ||
|
|
75b09f7e8d | ||
|
|
9e44781e77 | ||
|
|
919ffce26d | ||
|
|
7c8c132498 | ||
|
|
6513316579 | ||
|
|
42aa79b591 | ||
|
|
db598b5391 | ||
|
|
bedc1b6cdd | ||
|
|
107d894245 | ||
|
|
b596581271 | ||
|
|
0cd757ceed | ||
|
|
58141e4182 | ||
|
|
0847d7265b |
35 changed files with 902 additions and 3771 deletions
|
|
@ -1 +0,0 @@
|
||||||
1
|
|
||||||
13
.gitignore
vendored
13
.gitignore
vendored
|
|
@ -1,6 +1,7 @@
|
||||||
/*/
|
/ruby-2.*.tar.bz2
|
||||||
/ruby-*.tar.xz
|
/ruby-2.2.0.tar.xz
|
||||||
/rexml-*.gem
|
/ruby-2.2.1.tar.xz
|
||||||
/*.rpm
|
/ruby-2.2.2.tar.xz
|
||||||
|
/ruby-2.2.3.tar.xz
|
||||||
!/plans/
|
/ruby-2.2.4.tar.xz
|
||||||
|
/ruby-2.2.5.tar.xz
|
||||||
|
|
|
||||||
4
abrt_prelude.rb
Normal file
4
abrt_prelude.rb
Normal file
|
|
@ -0,0 +1,4 @@
|
||||||
|
begin
|
||||||
|
require 'abrt'
|
||||||
|
rescue LoadError
|
||||||
|
end
|
||||||
51
config.h
Normal file
51
config.h
Normal file
|
|
@ -0,0 +1,51 @@
|
||||||
|
/*
|
||||||
|
* This config.h is a wrapper include file for the original ruby/config.h,
|
||||||
|
* which has been renamed to ruby/config-<arch>.h. There are conflicts for the
|
||||||
|
* original ruby/config.h on multilib systems, which result from arch-specific
|
||||||
|
* configuration options. Please do not use the arch-specific file directly.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This wrapped is addpated from SDL's one:
|
||||||
|
* http://pkgs.fedoraproject.org/cgit/SDL.git/tree/SDL_config.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef ruby_config_wrapper_h
|
||||||
|
#error "ruby_config_wrapper_h should not be defined!"
|
||||||
|
#endif
|
||||||
|
#define ruby_config_wrapper_h
|
||||||
|
|
||||||
|
#if defined(__i386__)
|
||||||
|
#include "ruby/config-i386.h"
|
||||||
|
#elif defined(__ia64__)
|
||||||
|
#include "ruby/config-ia64.h"
|
||||||
|
#elif defined(__powerpc64__)
|
||||||
|
#include <endian.h>
|
||||||
|
#if __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
|
||||||
|
#include "ruby/config-ppc64.h"
|
||||||
|
#else
|
||||||
|
#include "ruby/config-ppc64le.h"
|
||||||
|
#endif
|
||||||
|
#elif defined(__powerpc__)
|
||||||
|
#include "ruby/config-ppc.h"
|
||||||
|
#elif defined(__s390x__)
|
||||||
|
#include "ruby/config-s390x.h"
|
||||||
|
#elif defined(__s390__)
|
||||||
|
#include "ruby/config-s390.h"
|
||||||
|
#elif defined(__x86_64__)
|
||||||
|
#include "ruby/config-x86_64.h"
|
||||||
|
#elif defined(__arm__)
|
||||||
|
#include "ruby/config-arm.h"
|
||||||
|
#elif defined(__alpha__)
|
||||||
|
#include "ruby/config-alpha.h"
|
||||||
|
#elif defined(__sparc__) && defined (__arch64__)
|
||||||
|
#include "ruby/config-sparc64.h"
|
||||||
|
#elif defined(__sparc__)
|
||||||
|
#include "ruby/config-sparc.h"
|
||||||
|
#elif defined(__aarch64__)
|
||||||
|
#include "ruby/config-aarch64.h"
|
||||||
|
#else
|
||||||
|
#error "The ruby-devel package is not usable with the architecture."
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef ruby_config_wrapper_h
|
||||||
230
macros.rubygems
230
macros.rubygems
|
|
@ -2,226 +2,36 @@
|
||||||
%gem_dir %{_datadir}/gems
|
%gem_dir %{_datadir}/gems
|
||||||
%gem_archdir %{_libdir}/gems
|
%gem_archdir %{_libdir}/gems
|
||||||
|
|
||||||
# %gem_prerelease - Provides prerelease string if available.
|
|
||||||
#
|
|
||||||
# Usage: %gem_prerelease [custom_gem_name]
|
|
||||||
#
|
|
||||||
# If avilable, prints prerelease string, which is a %prerelease macro by
|
|
||||||
# default. When [custom_gem_name] is provided, the custom_gem_name is used to
|
|
||||||
# derive %custom_gem_name_prerelease macro, which can be predefined.
|
|
||||||
#
|
|
||||||
# Please note that for the prerelease macros are the dashes in
|
|
||||||
# [custom_gem_name] replaced by underscores.
|
|
||||||
#
|
|
||||||
%gem_prerelease() %{?1:%{expand:%%{?%{gsub %{1} - _}_prerelease}}}%{!?1:%{?prerelease}}
|
|
||||||
|
|
||||||
# %gem_version - Provides version string (including prerelease if available).
|
|
||||||
#
|
|
||||||
# Usage: %gem_version [custom_gem_name]
|
|
||||||
#
|
|
||||||
# Prints version (including prerelease string), that is %version macro by
|
|
||||||
# default. When [custom_gem_name] is provided, the custom_gem_name is used to
|
|
||||||
# derive %custom_gem_name_version macro which needs to be predefined.
|
|
||||||
#
|
|
||||||
# Please note that for the version macros are the dashes in [custom_gem_name]
|
|
||||||
# replaced by underscores.
|
|
||||||
#
|
|
||||||
%gem_version() %{?1:%{expand:%{%{gsub %{1} - _}_version}}}%{!?1:%{version}}%{gem_prerelease %{?1}}
|
|
||||||
|
|
||||||
# %gem_name_version - Provides gem_name-version string.
|
|
||||||
#
|
|
||||||
# Usage: %gem_name_version [custom_gem_name]
|
|
||||||
#
|
|
||||||
# Prints gem_name-version string, by default joining %gem_name, %version and
|
|
||||||
# %prerelease macros. When [custom_gem_name] is provided, the
|
|
||||||
# custom_gem_name is joined with version as provided by %gem_version macro.
|
|
||||||
#
|
|
||||||
%gem_name_version() %{?1}%{!?1:%{gem_name}}-%{gem_version %{?1}}
|
|
||||||
|
|
||||||
# Common gem locations and files.
|
# Common gem locations and files.
|
||||||
#
|
%gem_instdir %{gem_dir}/gems/%{gem_name}-%{version}
|
||||||
# These macros leverages %gem_name_version macro and accepts custom gem_name.
|
%gem_extdir_mri %{gem_archdir}/%{name}/%{gem_name}-%{version}
|
||||||
#
|
%gem_libdir %{gem_instdir}/lib
|
||||||
# -d Use default gem install location.
|
%gem_cache %{gem_dir}/cache/%{gem_name}-%{version}.gem
|
||||||
#
|
%gem_spec %{gem_dir}/specifications/%{gem_name}-%{version}.gemspec
|
||||||
%gem_instdir() %{gem_dir}/gems/%{gem_name_version %{?1}}
|
%gem_docdir %{gem_dir}/doc/%{gem_name}-%{version}
|
||||||
%gem_extdir_mri() %{gem_archdir}/%{name}/%{gem_name_version %{?1}}
|
|
||||||
%gem_libdir() %{gem_instdir %{?1}}/lib
|
|
||||||
%gem_cache() %{gem_dir}/cache/%{gem_name_version %{?1}}.gem
|
|
||||||
%gem_spec(d) %{gem_dir}/specifications%{?-d:/default}/%{gem_name_version %{?1}}.gemspec
|
|
||||||
%gem_docdir() %{gem_dir}/doc/%{gem_name_version %{?1}}
|
|
||||||
%gem_plugin() %{gem_dir}/plugins/%{?1}%{!?1:%{gem_name}}_plugin.rb
|
|
||||||
|
|
||||||
|
# Install gem into appropriate directory.
|
||||||
# %gem_install - Install gem into appropriate directory.
|
# -n<gem_file> Overrides gem file name for installation.
|
||||||
#
|
# -d<install_dir> Set installation directory.
|
||||||
# Usage: %gem_install [options]
|
|
||||||
#
|
|
||||||
# -n <gem_file> Overrides gem file name for installation.
|
|
||||||
# -d <install_dir> Set installation directory.
|
|
||||||
#
|
|
||||||
%gem_install(d:n:) \
|
%gem_install(d:n:) \
|
||||||
mkdir -p %{-d*}%{!?-d:.%{gem_dir}} \
|
mkdir -p %{-d*}%{!?-d:.%{gem_dir}} \
|
||||||
\
|
\
|
||||||
CONFIGURE_ARGS="--with-cflags='%{optflags}' --with-cxxflags='%{optflags}' --with-ldflags='%{build_ldflags}' $CONFIGURE_ARGS" \\\
|
CONFIGURE_ARGS="--with-cflags='%{optflags}' $CONFIGURE_ARGS" \\\
|
||||||
gem install \\\
|
gem install \\\
|
||||||
-V \\\
|
-V \\\
|
||||||
--local \\\
|
--local \\\
|
||||||
--build-root %{-d*}%{!?-d:.} \\\
|
--install-dir %{-d*}%{!?-d:.%{gem_dir}} \\\
|
||||||
|
--bindir .%{_bindir} \\\
|
||||||
--force \\\
|
--force \\\
|
||||||
--document=ri,rdoc \\\
|
--document=ri,rdoc \\\
|
||||||
%{-n*}%{!?-n:%{gem_name}-%{version}%{?prerelease}.gem} \
|
%{-n*}%{!?-n:%{gem_name}-%{version}.gem} \
|
||||||
%{nil}
|
%{nil}
|
||||||
|
|
||||||
|
# For rubygems packages we want to filter out any provides caused by private
|
||||||
# The 'read' command in %%gemspec_* macros is not essential, but it is usefull
|
# libs in %%{gem_archdir}.
|
||||||
# to make the sript appear in build log.
|
|
||||||
|
|
||||||
|
|
||||||
# %gemspec_add_dep - Add dependency into .gemspec.
|
|
||||||
#
|
#
|
||||||
# Usage: %gemspec_add_dep -g <gem> [options] [requirements]
|
# Note that this must be invoked in the spec file, preferably as
|
||||||
#
|
# "%{?rubygems_default_filter}", before any %description block.
|
||||||
# Add dependency named <gem> to .gemspec file. The macro adds runtime
|
%rubygems_default_filter %{expand: \
|
||||||
# dependency by default. The [requirements] argument can be used to specify
|
%global __provides_exclude_from %{?__provides_exclude_from:%{__provides_exclude_from}|}^%{gem_extdir_mri}/.*\\\\.so$ \
|
||||||
# the dependency constraints more precisely. It is expected to be valid Ruby
|
}
|
||||||
# code.
|
|
||||||
#
|
|
||||||
# -s <gemspec_file> Overrides the default .gemspec location.
|
|
||||||
# -d Add development dependecy.
|
|
||||||
#
|
|
||||||
%gemspec_add_dep(g:s:d) \
|
|
||||||
read -d '' gemspec_add_dep_script << 'EOR' || : \
|
|
||||||
gemspec_file = '%{-s*}%{!?-s:%{_builddir}/%{gem_name}-%{version}%{?prerelease}.gemspec}' \
|
|
||||||
\
|
|
||||||
name = '%{-g*}' \
|
|
||||||
requirements = %{*}%{!?1:nil} \
|
|
||||||
\
|
|
||||||
type = :%{!?-d:runtime}%{?-d:development} \
|
|
||||||
\
|
|
||||||
spec = Gem::Specification.load(gemspec_file) \
|
|
||||||
abort("#{gemspec_file} is not accessible.") unless spec \
|
|
||||||
\
|
|
||||||
dep = spec.dependencies.detect { |d| d.type == type && d.name == name } \
|
|
||||||
if dep \
|
|
||||||
dep.requirement.concat requirements \
|
|
||||||
else \
|
|
||||||
spec.public_send "add_#{type}_dependency", name, requirements \
|
|
||||||
end \
|
|
||||||
File.write gemspec_file, spec.to_ruby \
|
|
||||||
EOR\
|
|
||||||
echo "$gemspec_add_dep_script" | ruby \
|
|
||||||
unset -v gemspec_add_dep_script \
|
|
||||||
%{nil}
|
|
||||||
|
|
||||||
|
|
||||||
# %gemspec_remove_dep - Remove dependency from .gemspec.
|
|
||||||
#
|
|
||||||
# Usage: %gemspec_remove_dep -g <gem> [options] [requirements]
|
|
||||||
#
|
|
||||||
# Remove dependency named <gem> from .gemspec file. The macro removes runtime
|
|
||||||
# dependency by default. The [requirements] argument can be used to specify
|
|
||||||
# the dependency constraints more precisely. It is expected to be valid Ruby
|
|
||||||
# code. The macro fails if these specific requirements can't be removed.
|
|
||||||
#
|
|
||||||
# -s <gemspec_file> Overrides the default .gemspec location.
|
|
||||||
# -d Remove development dependecy.
|
|
||||||
#
|
|
||||||
%gemspec_remove_dep(g:s:d) \
|
|
||||||
read -d '' gemspec_remove_dep_script << 'EOR' || : \
|
|
||||||
gemspec_file = '%{-s*}%{!?-s:%{_builddir}/%{gem_name}-%{version}%{?prerelease}.gemspec}' \
|
|
||||||
\
|
|
||||||
name = '%{-g*}' \
|
|
||||||
requirements = %{*}%{!?1:nil} \
|
|
||||||
\
|
|
||||||
type = :%{!?-d:runtime}%{?-d:development} \
|
|
||||||
\
|
|
||||||
spec = Gem::Specification.load(gemspec_file) \
|
|
||||||
abort("#{gemspec_file} is not accessible.") unless spec \
|
|
||||||
\
|
|
||||||
dep = spec.dependencies.detect { |d| d.type == type && d.name == name } \
|
|
||||||
if dep \
|
|
||||||
if requirements \
|
|
||||||
requirements = Gem::Requirement.create(requirements).requirements \
|
|
||||||
requirements.each do |r| \
|
|
||||||
unless dep.requirement.requirements.reject! { |dependency_requirements| dependency_requirements == r } \
|
|
||||||
abort("Requirement '#{r.first} #{r.last}' was not possible to remove for dependency '#{dep}'!") \
|
|
||||||
end \
|
|
||||||
end \
|
|
||||||
spec.dependencies.delete dep if dep.requirement.requirements.empty? \
|
|
||||||
else \
|
|
||||||
spec.dependencies.delete dep \
|
|
||||||
end \
|
|
||||||
else \
|
|
||||||
abort("Dependency '#{name}' was not found!") \
|
|
||||||
end \
|
|
||||||
File.write gemspec_file, spec.to_ruby \
|
|
||||||
EOR\
|
|
||||||
echo "$gemspec_remove_dep_script" | ruby \
|
|
||||||
unset -v gemspec_remove_dep_script \
|
|
||||||
%{nil}
|
|
||||||
|
|
||||||
|
|
||||||
# %%gemspec_add_file - Add files to various files lists in .gemspec.
|
|
||||||
#
|
|
||||||
# Usage: %%gemspec_add_file [options] <file>
|
|
||||||
#
|
|
||||||
# Add files to .gemspec file. <file> is expected to be valid Ruby code.
|
|
||||||
# Path to file is expected. Does not check real files in any way.
|
|
||||||
# By default, `files` list is edited.
|
|
||||||
#
|
|
||||||
# -s <gemspec_file> Overrides the default .gemspec location.
|
|
||||||
# -t Edit test_files only.
|
|
||||||
# -r Edit extra_rdoc_files only.
|
|
||||||
#
|
|
||||||
%gemspec_add_file(s:tr) \
|
|
||||||
read -d '' gemspec_add_file_script << 'EOR' || : \
|
|
||||||
gemspec_file = '%{-s*}%{!?-s:%{_builddir}/%{gem_name}-%{version}%{?prerelease}.gemspec}' \
|
|
||||||
\
|
|
||||||
abort("gemspec_add_file: Use only one '-t' or '-r' at a time.") if "%{?-t}%{?-r}" == "-t-r" \
|
|
||||||
\
|
|
||||||
filenames = %{*}%{!?1:nil} \
|
|
||||||
filenames = Array(filenames) \
|
|
||||||
\
|
|
||||||
spec = Gem::Specification.load(gemspec_file) \
|
|
||||||
abort("#{gemspec_file} is not accessible.") unless spec \
|
|
||||||
\
|
|
||||||
spec.%{?-t:test_}%{?-r:extra_rdoc_}files += filenames \
|
|
||||||
File.write gemspec_file, spec.to_ruby \
|
|
||||||
EOR\
|
|
||||||
echo "$gemspec_add_file_script" | ruby \
|
|
||||||
unset -v gemspec_add_file_script \
|
|
||||||
%{nil}
|
|
||||||
|
|
||||||
|
|
||||||
# %%gemspec_remove_file - Remove files from various files lists in .gemspec.
|
|
||||||
#
|
|
||||||
# Usage: %%gemspec_remove_file [options] <file>
|
|
||||||
#
|
|
||||||
# Remove files from .gemspec file. <file> is expected to be valid Ruby code.
|
|
||||||
# Path to file is expected. Does not check/remove real files in any way.
|
|
||||||
# By default, `files` list is edited. File has to be removed from `test_files`
|
|
||||||
# first in order to be removable from `files`.
|
|
||||||
#
|
|
||||||
# -s <gemspec_file> Overrides the default .gemspec location.
|
|
||||||
# -t Edit test_files only.
|
|
||||||
# -r Edit extra_rdoc_files only.
|
|
||||||
#
|
|
||||||
%gemspec_remove_file(s:tr) \
|
|
||||||
read -d '' gemspec_remove_file_script << 'EOR' || : \
|
|
||||||
gemspec_file = '%{-s*}%{!?-s:%{_builddir}/%{gem_name}-%{version}%{?prerelease}.gemspec}' \
|
|
||||||
\
|
|
||||||
abort("gemspec_remove_file: Use only one '-t' or '-r' at a time.") if "%{?-t}%{?-r}" == "-t-r" \
|
|
||||||
\
|
|
||||||
filenames = %{*}%{!?1:nil} \
|
|
||||||
filenames = Array(filenames) \
|
|
||||||
\
|
|
||||||
spec = Gem::Specification.load(gemspec_file) \
|
|
||||||
abort("#{gemspec_file} is not accessible.") unless spec \
|
|
||||||
\
|
|
||||||
spec.%{?-t:test_}%{?-r:extra_rdoc_}files -= filenames \
|
|
||||||
File.write gemspec_file, spec.to_ruby \
|
|
||||||
EOR\
|
|
||||||
echo "$gemspec_remove_file_script" | ruby \
|
|
||||||
unset -v gemspec_remove_file_script \
|
|
||||||
%{nil}
|
|
||||||
|
|
|
||||||
|
|
@ -13,28 +13,12 @@ module Gem
|
||||||
end
|
end
|
||||||
private :previous_but_one_dir_to
|
private :previous_but_one_dir_to
|
||||||
|
|
||||||
##
|
|
||||||
# Detects --install-dir option specified on command line.
|
|
||||||
|
|
||||||
def opt_install_dir?
|
|
||||||
@opt_install_dir ||= ARGV.include?('--install-dir') || ARGV.include?('-i')
|
|
||||||
end
|
|
||||||
private :opt_install_dir?
|
|
||||||
|
|
||||||
##
|
|
||||||
# Detects --build-root option specified on command line.
|
|
||||||
|
|
||||||
def opt_build_root?
|
|
||||||
@opt_build_root ||= ARGV.include?('--build-root')
|
|
||||||
end
|
|
||||||
private :opt_build_root?
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# Tries to detect, if arguments and environment variables suggest that
|
# Tries to detect, if arguments and environment variables suggest that
|
||||||
# 'gem install' is executed from rpmbuild.
|
# 'gem install' is executed from rpmbuild.
|
||||||
|
|
||||||
def rpmbuild?
|
def rpmbuild?
|
||||||
@rpmbuild ||= ENV['RPM_PACKAGE_NAME'] && (opt_install_dir? || opt_build_root?)
|
(ARGV.include?('--install-dir') || ARGV.include?('-i')) && ENV['RPM_PACKAGE_NAME']
|
||||||
end
|
end
|
||||||
private :rpmbuild?
|
private :rpmbuild?
|
||||||
|
|
||||||
|
|
@ -88,7 +72,6 @@ module Gem
|
||||||
# warnings otherwise issued by Ruby.
|
# warnings otherwise issued by Ruby.
|
||||||
|
|
||||||
remove_method :default_dir if method_defined? :default_dir
|
remove_method :default_dir if method_defined? :default_dir
|
||||||
remove_method :default_specifications_dir if method_defined? :default_specifications_dir
|
|
||||||
remove_method :default_path if method_defined? :default_path
|
remove_method :default_path if method_defined? :default_path
|
||||||
remove_method :default_bindir if method_defined? :default_bindir
|
remove_method :default_bindir if method_defined? :default_bindir
|
||||||
remove_method :default_ext_dir_for if method_defined? :default_ext_dir_for
|
remove_method :default_ext_dir_for if method_defined? :default_ext_dir_for
|
||||||
|
|
@ -97,35 +80,20 @@ module Gem
|
||||||
# RubyGems default overrides.
|
# RubyGems default overrides.
|
||||||
|
|
||||||
def default_dir
|
def default_dir
|
||||||
if opt_build_root?
|
if Process.uid == 0
|
||||||
Gem.default_dirs[:system][:gem_dir]
|
|
||||||
elsif Process.uid == 0
|
|
||||||
Gem.default_dirs[:local][:gem_dir]
|
Gem.default_dirs[:local][:gem_dir]
|
||||||
else
|
else
|
||||||
Gem.user_dir
|
Gem.user_dir
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
##
|
|
||||||
# Path to specification files of default gems.
|
|
||||||
|
|
||||||
def default_specifications_dir
|
|
||||||
@default_specifications_dir ||= File.join(Gem.default_dirs[:system][:gem_dir], "specifications", "default")
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
||||||
# Default gem load path
|
|
||||||
|
|
||||||
def default_path
|
def default_path
|
||||||
path = default_dirs.collect {|location, paths| paths[:gem_dir]}
|
path = default_dirs.collect {|location, paths| paths[:gem_dir]}
|
||||||
path.unshift Gem.user_dir if File.exist? Gem.user_home
|
path.unshift Gem.user_dir if File.exist? Gem.user_home
|
||||||
path
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def default_bindir
|
def default_bindir
|
||||||
if opt_build_root?
|
if Process.uid == 0
|
||||||
Gem.default_dirs[:system][:bin_dir]
|
|
||||||
elsif Process.uid == 0
|
|
||||||
Gem.default_dirs[:local][:bin_dir]
|
Gem.default_dirs[:local][:bin_dir]
|
||||||
else
|
else
|
||||||
File.join [Dir.home, 'bin']
|
File.join [Dir.home, 'bin']
|
||||||
|
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
summary: Test plan with all Fedora tests
|
|
||||||
discover:
|
|
||||||
how: fmf
|
|
||||||
url: https://src.fedoraproject.org/tests/ruby.git
|
|
||||||
execute:
|
|
||||||
how: tmt
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
From 994ee4c17fb8c217ab0335df55620c6bdb5d5cbe Mon Sep 17 00:00:00 2001
|
|
||||||
From: tompng <tomoyapenguin@gmail.com>
|
|
||||||
Date: Fri, 26 Dec 2025 04:57:12 +0900
|
|
||||||
Subject: [PATCH] Fix comment_location for merged ClassModule
|
|
||||||
|
|
||||||
---
|
|
||||||
lib/rdoc/code_object/class_module.rb | 7 ++++++-
|
|
||||||
test/rdoc/code_object/class_module_test.rb | 6 ++++++
|
|
||||||
2 files changed, 12 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/lib/rdoc/code_object/class_module.rb b/lib/rdoc/code_object/class_module.rb
|
|
||||||
index b6bed352a2..d7ee36f950 100644
|
|
||||||
--- a/lib/rdoc/code_object/class_module.rb
|
|
||||||
+++ b/lib/rdoc/code_object/class_module.rb
|
|
||||||
@@ -477,7 +477,12 @@ def merge(class_module)
|
|
||||||
document = document.merge other_document
|
|
||||||
|
|
||||||
@comment = RDoc::Comment.from_document(document)
|
|
||||||
- @comment_location = document
|
|
||||||
+
|
|
||||||
+ @comment_location = if document.parts.first.is_a?(RDoc::Markup::Document)
|
|
||||||
+ document.parts.map { |doc| [doc, doc.file] }
|
|
||||||
+ else
|
|
||||||
+ [[document, document.file]]
|
|
||||||
+ end
|
|
||||||
end
|
|
||||||
|
|
||||||
cm = class_module
|
|
||||||
|
|
@ -1,166 +0,0 @@
|
||||||
require 'tmpdir'
|
|
||||||
require 'tempfile'
|
|
||||||
require 'fileutils'
|
|
||||||
# Available in Ruby upstream sources under tool/lib/envutil.rb
|
|
||||||
# Required for finding and setting up the built ruby binary.
|
|
||||||
require 'envutil'
|
|
||||||
|
|
||||||
module RPMTestHelper
|
|
||||||
def setup
|
|
||||||
@tmpdir = Dir.mktmpdir
|
|
||||||
@tempfiles = []
|
|
||||||
end
|
|
||||||
|
|
||||||
def teardown
|
|
||||||
@tempfiles.each do |file|
|
|
||||||
file.close
|
|
||||||
file.unlink
|
|
||||||
end
|
|
||||||
|
|
||||||
FileUtils.rmtree(@tmpdir)
|
|
||||||
end
|
|
||||||
|
|
||||||
GENERATOR_SCRIPT = ENV['GENERATOR_SCRIPT'].clone.freeze
|
|
||||||
if GENERATOR_SCRIPT.nil? || GENERATOR_SCRIPT == ''
|
|
||||||
raise "GENERATOR_SCRIPT is not specified." \
|
|
||||||
"Specify the ENV variable with absolute path to the generator."
|
|
||||||
end
|
|
||||||
|
|
||||||
Dependency = Struct.new('Dependency', :name, :requirements) do
|
|
||||||
def to_rpm_str
|
|
||||||
"rubygem(#{self.name})"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def make_gemspec(gem_info)
|
|
||||||
file = Tempfile.new('req_gemspec', @tmpdir)
|
|
||||||
# Fake gemspec with enough to pass most checks
|
|
||||||
# Rubygems uses to validate the format.
|
|
||||||
gemspec_contents = <<~EOF
|
|
||||||
# -*- encoding: utf-8 -*-
|
|
||||||
# stub: #{gem_info.name} #{gem_info.version} ruby lib
|
|
||||||
|
|
||||||
Gem::Specification.new do |s|
|
|
||||||
s.name = "#{gem_info.name}".freeze
|
|
||||||
s.version = "#{gem_info.version}"
|
|
||||||
|
|
||||||
s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
|
|
||||||
s.require_paths = ["lib".freeze]
|
|
||||||
s.authors = ["John Doe".freeze]
|
|
||||||
s.bindir = "bin".freeze
|
|
||||||
s.date = "2023-12-15"
|
|
||||||
s.description = "Fake gemspec helper for testing Rubygem Generators".freeze
|
|
||||||
s.email = ["example@example.com".freeze]
|
|
||||||
s.files = ["LICENSE.txt".freeze, "lib/#{gem_info.name}.rb".freeze, "#{gem_info.name}.gemspec".freeze]
|
|
||||||
s.homepage = "https://pkgs.fedoraproject.org/rpms/ruby".freeze
|
|
||||||
s.licenses = ["MIT".freeze]
|
|
||||||
s.required_ruby_version = Gem::Requirement.new(">= 2.5.0".freeze)
|
|
||||||
s.rubygems_version = "3.3.5".freeze
|
|
||||||
s.summary = "Fake gemspec for testing Rubygem Generators".freeze
|
|
||||||
|
|
||||||
if s.respond_to? :specification_version then
|
|
||||||
s.specification_version = 4
|
|
||||||
end
|
|
||||||
|
|
||||||
if s.respond_to? :add_runtime_dependency then
|
|
||||||
#{gem_info.gemspec_runtime_dep_str}
|
|
||||||
else
|
|
||||||
#{gem_info.gemspec_dep_str}
|
|
||||||
end
|
|
||||||
end
|
|
||||||
EOF
|
|
||||||
|
|
||||||
file.write gemspec_contents
|
|
||||||
file.rewind
|
|
||||||
@tempfiles << file
|
|
||||||
file
|
|
||||||
end
|
|
||||||
|
|
||||||
# Caller is expected to close subprocess stdin via #close_write
|
|
||||||
# in order to let subprocess proceed if the process is reading
|
|
||||||
# from STDIN in a loop.
|
|
||||||
def rb_subprocess(*args)
|
|
||||||
args = [GENERATOR_SCRIPT] if args.empty?
|
|
||||||
ruby = EnvUtil.rubybin
|
|
||||||
f = IO.popen([ruby] + args, 'r+') #, external_encoding: external_encoding)
|
|
||||||
yield(f)
|
|
||||||
ensure
|
|
||||||
f.close unless !f || f.closed?
|
|
||||||
end
|
|
||||||
|
|
||||||
def run_generator_single_file(gem_info)
|
|
||||||
lines = []
|
|
||||||
gemspec_f = make_gemspec(gem_info)
|
|
||||||
|
|
||||||
rb_subprocess do |io|
|
|
||||||
io.write gemspec_f.path
|
|
||||||
io.close_write
|
|
||||||
lines = io.readlines
|
|
||||||
end
|
|
||||||
|
|
||||||
lines
|
|
||||||
end
|
|
||||||
|
|
||||||
def helper_rubygems_dependency
|
|
||||||
"ruby(rubygems)"
|
|
||||||
end
|
|
||||||
|
|
||||||
class GemInfo
|
|
||||||
attr_accessor :name, :version, :dependencies
|
|
||||||
|
|
||||||
def initialize(name: 'foo', version: '1.2.3', dependencies: [])
|
|
||||||
@name = name
|
|
||||||
@version = version
|
|
||||||
@dependencies = dependencies
|
|
||||||
end
|
|
||||||
|
|
||||||
def dependencies=(other)
|
|
||||||
raise ArgumentError, "#{self.class.name}##{__method__.to_s}: Expected array of `Dependency' elements" \
|
|
||||||
unless other.is_a?(Array) && other.all? { |elem| elem.respond_to?(:name) && elem.respond_to?(:requirements) }
|
|
||||||
|
|
||||||
@dependencies = other
|
|
||||||
end
|
|
||||||
|
|
||||||
def to_rpm_str
|
|
||||||
"rubygem(#{self.name})"
|
|
||||||
end
|
|
||||||
|
|
||||||
def gemspec_dep_str
|
|
||||||
return '' if self.dependencies.nil? || self.dependencies.empty?
|
|
||||||
@dependencies.inject("") do |memo, dep|
|
|
||||||
memo += if dep.requirements && !dep.requirements.empty?
|
|
||||||
%Q|s.add_dependency(%q<#{dep.name}>.freeze, #{handle_dep_requirements(dep.requirements)})|
|
|
||||||
else
|
|
||||||
%Q|s.add_dependency(%q<#{dep.name}>.freeze)|
|
|
||||||
end
|
|
||||||
|
|
||||||
memo += "\n"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def gemspec_runtime_dep_str
|
|
||||||
return '' if self.dependencies.nil? || self.dependencies.empty?
|
|
||||||
|
|
||||||
@dependencies.inject("") do |memo, dep|
|
|
||||||
memo += if dep.requirements && !dep.requirements.empty?
|
|
||||||
%Q|s.add_runtime_dependency(%q<#{dep.name}>.freeze, #{handle_dep_requirements(dep.requirements)})|
|
|
||||||
else
|
|
||||||
%Q|s.add_runtime_dependency(%q<#{dep.name}>.freeze)|
|
|
||||||
end
|
|
||||||
|
|
||||||
memo += "\n"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def handle_dep_requirements(reqs)
|
|
||||||
raise ArgumentError, "#{self.class.name}##{__method__.to_s}: Reqs must be an array." \
|
|
||||||
unless reqs.is_a? Array
|
|
||||||
raise ArgumentError, "#{self.class.name}##{__method__.to_s}: Reqs must not be empty for this method." \
|
|
||||||
if reqs.empty?
|
|
||||||
|
|
||||||
'[ "' + reqs.join('", "') + '" ]'
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
25
ruby-1.9.3-mkmf-verbose.patch
Normal file
25
ruby-1.9.3-mkmf-verbose.patch
Normal file
|
|
@ -0,0 +1,25 @@
|
||||||
|
From 28cc0749d6729aa2444661ee7b411e183fe220b0 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
|
Date: Mon, 19 Nov 2012 15:14:51 +0100
|
||||||
|
Subject: [PATCH] Verbose mkmf.
|
||||||
|
|
||||||
|
---
|
||||||
|
lib/mkmf.rb | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/lib/mkmf.rb b/lib/mkmf.rb
|
||||||
|
index 682eb46..e6b1445 100644
|
||||||
|
--- a/lib/mkmf.rb
|
||||||
|
+++ b/lib/mkmf.rb
|
||||||
|
@@ -1859,7 +1859,7 @@ SRC
|
||||||
|
SHELL = /bin/sh
|
||||||
|
|
||||||
|
# V=0 quiet, V=1 verbose. other values don't work.
|
||||||
|
-V = 0
|
||||||
|
+V = 1
|
||||||
|
Q1 = $(V:1=)
|
||||||
|
Q = $(Q1:0=@)
|
||||||
|
ECHO1 = $(V:1=@#{CONFIG['NULLCMD']})
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
||||||
|
|
@ -0,0 +1,58 @@
|
||||||
|
From 996012f6abe0ce4d68a2de9f249935c6d5b467bc Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
|
Date: Fri, 4 Oct 2013 22:13:11 +0200
|
||||||
|
Subject: [PATCH] Allow to specify addition preludes by configuration option.
|
||||||
|
|
||||||
|
---
|
||||||
|
Makefile.in | 2 ++
|
||||||
|
common.mk | 2 +-
|
||||||
|
configure.in | 7 +++++++
|
||||||
|
3 files changed, 10 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/Makefile.in b/Makefile.in
|
||||||
|
index 7e8ed82..7916993 100644
|
||||||
|
--- a/Makefile.in
|
||||||
|
+++ b/Makefile.in
|
||||||
|
@@ -114,6 +114,8 @@ XRUBY_LIBDIR = @XRUBY_LIBDIR@
|
||||||
|
XRUBY_RUBYLIBDIR = @XRUBY_RUBYLIBDIR@
|
||||||
|
XRUBY_RUBYHDRDIR = @XRUBY_RUBYHDRDIR@
|
||||||
|
|
||||||
|
+OPTIONAL_PRELUDES = @OPTIONAL_PRELUDES@
|
||||||
|
+
|
||||||
|
#### End of system configuration section. ####
|
||||||
|
|
||||||
|
MAJOR= @MAJOR@
|
||||||
|
diff --git a/common.mk b/common.mk
|
||||||
|
index 5cfbc3d..3f0a82e 100644
|
||||||
|
--- a/common.mk
|
||||||
|
+++ b/common.mk
|
||||||
|
@@ -117,7 +117,7 @@ ALLOBJS = $(NORMALMAINOBJ) $(MINIOBJS) $(COMMONOBJS) $(INITOBJS)
|
||||||
|
GOLFOBJS = goruby.$(OBJEXT) golf_prelude.$(OBJEXT)
|
||||||
|
|
||||||
|
DEFAULT_PRELUDES = $(GEM_PRELUDE)
|
||||||
|
-PRELUDE_SCRIPTS = $(srcdir)/prelude.rb $(srcdir)/enc/prelude.rb $(DEFAULT_PRELUDES)
|
||||||
|
+PRELUDE_SCRIPTS = $(srcdir)/prelude.rb $(srcdir)/enc/prelude.rb $(DEFAULT_PRELUDES) $(OPTIONAL_PRELUDES)
|
||||||
|
GEM_PRELUDE = $(srcdir)/gem_prelude.rb
|
||||||
|
PRELUDES = {$(srcdir)}prelude.c {$(srcdir)}miniprelude.c
|
||||||
|
GOLFPRELUDES = {$(srcdir)}golf_prelude.c
|
||||||
|
diff --git a/configure.in b/configure.in
|
||||||
|
index 0e371e2..d4f1dcb 100644
|
||||||
|
--- a/configure.in
|
||||||
|
+++ b/configure.in
|
||||||
|
@@ -4209,6 +4209,13 @@ AC_SUBST(rubyarchhdrdir)dnl
|
||||||
|
AC_SUBST(sitearchhdrdir)dnl
|
||||||
|
AC_SUBST(vendorarchhdrdir)dnl
|
||||||
|
|
||||||
|
+AC_ARG_WITH(prelude,
|
||||||
|
+ AS_HELP_STRING([--with-prelude=FILE-LIST], [specify additional preludes separated by space]),
|
||||||
|
+ [prelude=$withval])
|
||||||
|
+if test "$prelude" != ""; then
|
||||||
|
+ AC_SUBST(OPTIONAL_PRELUDES, $prelude)
|
||||||
|
+fi
|
||||||
|
+
|
||||||
|
AC_ARG_WITH(mantype,
|
||||||
|
AS_HELP_STRING([--with-mantype=TYPE], [specify man page type; TYPE is one of man and doc]),
|
||||||
|
[
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
||||||
|
|
@ -1,18 +1,18 @@
|
||||||
From e1293f665128b0d9c5bfa0b5beeab4afebf07e6a Mon Sep 17 00:00:00 2001
|
From 07c666ba5c3360dd6f43605a8ac7c85c99c1721f Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
Date: Tue, 1 Oct 2013 12:22:40 +0200
|
Date: Tue, 1 Oct 2013 12:22:40 +0200
|
||||||
Subject: [PATCH] Allow to configure libruby.so placement.
|
Subject: [PATCH] Allow to configure libruby.so placement.
|
||||||
|
|
||||||
---
|
---
|
||||||
configure.ac | 5 +++++
|
configure.in | 5 +++++
|
||||||
1 file changed, 5 insertions(+)
|
1 file changed, 5 insertions(+)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.in b/configure.in
|
||||||
index a64358fada..b3bdfad1eb 100644
|
index 37d9a62..553d4d0 100644
|
||||||
--- a/configure.ac
|
--- a/configure.in
|
||||||
+++ b/configure.ac
|
+++ b/configure.in
|
||||||
@@ -3556,6 +3556,11 @@ AS_IF([test ${multiarch+set}], [
|
@@ -3425,6 +3425,11 @@ if test ${multiarch+set}; then
|
||||||
])
|
fi
|
||||||
|
|
||||||
archlibdir='${libdir}/${arch}'
|
archlibdir='${libdir}/${arch}'
|
||||||
+AC_ARG_WITH(archlibdir,
|
+AC_ARG_WITH(archlibdir,
|
||||||
|
|
@ -23,3 +23,6 @@ index a64358fada..b3bdfad1eb 100644
|
||||||
sitearchlibdir='${libdir}/${sitearch}'
|
sitearchlibdir='${libdir}/${sitearch}'
|
||||||
archincludedir='${includedir}/${arch}'
|
archincludedir='${includedir}/${arch}'
|
||||||
sitearchincludedir='${includedir}/${sitearch}'
|
sitearchincludedir='${includedir}/${sitearch}'
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,34 +1,80 @@
|
||||||
From 6062f4976c5b51f8b952b9f6745175be7b1c5ff9 Mon Sep 17 00:00:00 2001
|
From e24d97c938c481450ed80ec83e5399595946c1ae Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
Date: Fri, 8 Feb 2013 22:48:41 +0100
|
Date: Fri, 8 Feb 2013 22:48:41 +0100
|
||||||
Subject: [PATCH] Prevent duplicated paths when empty version string is
|
Subject: [PATCH] Prevent duplicated paths when empty version string is
|
||||||
configured.
|
configured.
|
||||||
|
|
||||||
---
|
---
|
||||||
configure.ac | 3 ++-
|
configure.in | 15 +++++++++------
|
||||||
loadpath.c | 12 ++++++++++++
|
loadpath.c | 12 ++++++++++++
|
||||||
tool/mkconfig.rb | 2 +-
|
tool/mkconfig.rb | 2 +-
|
||||||
3 files changed, 15 insertions(+), 2 deletions(-)
|
3 files changed, 22 insertions(+), 7 deletions(-)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.in b/configure.in
|
||||||
index 2bc5153141..a64358fada 100644
|
index 17ed3ed..5843651 100644
|
||||||
--- a/configure.ac
|
--- a/configure.in
|
||||||
+++ b/configure.ac
|
+++ b/configure.in
|
||||||
@@ -4472,7 +4472,8 @@ AS_CASE(["$ruby_version_dir_name"],
|
@@ -4015,8 +4015,6 @@ AS_CASE(["$target_os"],
|
||||||
ruby_version_dir=/'${ruby_version_dir_name}'
|
rubyw_install_name='$(RUBYW_INSTALL_NAME)'
|
||||||
|
])
|
||||||
|
|
||||||
if test -z "${ruby_version_dir_name}"; then
|
-rubylibdir='${rubylibprefix}/${ruby_version}'
|
||||||
|
-rubyarchdir=${multiarch+'${rubyarchprefix}/${ruby_version}'}${multiarch-'${rubylibdir}/${arch}'}
|
||||||
|
|
||||||
|
rubyarchprefix=${multiarch+'${archlibdir}/${RUBY_BASE_NAME}'}${multiarch-'${rubylibprefix}/${arch}'}
|
||||||
|
AC_ARG_WITH(rubyarchprefix,
|
||||||
|
@@ -4046,6 +4044,7 @@ AC_ARG_WITH(ruby-version,
|
||||||
|
[ruby_version=full])
|
||||||
|
unset RUBY_LIB_VERSION
|
||||||
|
unset RUBY_LIB_VERSION_STYLE
|
||||||
|
+ruby_version_suffix=/'${ruby_version}'
|
||||||
|
AS_CASE(["$ruby_version"],
|
||||||
|
[full], [RUBY_LIB_VERSION_STYLE='3 /* full */'],
|
||||||
|
[minor], [RUBY_LIB_VERSION_STYLE='2 /* minor */'])
|
||||||
|
@@ -4062,30 +4061,34 @@ if test ${RUBY_LIB_VERSION_STYLE+set}; then
|
||||||
|
ruby_version="`$CPP -I. -I"${srcdir}" -I"${srcdir}/include" conftest.c | sed '/^ruby_version=/!d;s/ //g'`"
|
||||||
|
eval $ruby_version
|
||||||
|
elif test -z "${ruby_version}"; then
|
||||||
- AC_MSG_ERROR([No ruby version, No place for bundled libraries])
|
- AC_MSG_ERROR([No ruby version, No place for bundled libraries])
|
||||||
+ unset ruby_version_dir
|
+ unset ruby_version_suffix
|
||||||
+ AC_DEFINE(RUBY_LIB_VERSION_BLANK, 1)
|
+ AC_DEFINE(RUBY_LIB_VERSION_BLANK, 1)
|
||||||
|
else
|
||||||
|
RUBY_LIB_VERSION="${ruby_version}"
|
||||||
fi
|
fi
|
||||||
|
AC_SUBST(RUBY_LIB_VERSION_STYLE)
|
||||||
|
AC_SUBST(RUBY_LIB_VERSION)
|
||||||
|
|
||||||
rubylibdir='${rubylibprefix}'${ruby_version_dir}
|
+rubylibdir='${rubylibprefix}'${ruby_version_suffix}
|
||||||
|
+rubyarchdir=${multiarch+'${rubyarchprefix}'${ruby_version_suffix}}${multiarch-'${rubylibdir}/${arch}'}
|
||||||
|
+
|
||||||
|
AC_ARG_WITH(sitedir,
|
||||||
|
AS_HELP_STRING([--with-sitedir=DIR], [site libraries in DIR [[RUBY_LIB_PREFIX/site_ruby]], "no" to disable site directory]),
|
||||||
|
[sitedir=$withval],
|
||||||
|
[sitedir='${rubylibprefix}/site_ruby'])
|
||||||
|
-sitelibdir='${sitedir}/${ruby_version}'
|
||||||
|
+sitelibdir='${sitedir}'${ruby_version_suffix}
|
||||||
|
|
||||||
|
AC_ARG_WITH(sitearchdir,
|
||||||
|
AS_HELP_STRING([--with-sitearchdir=DIR],
|
||||||
|
[architecture dependent site libraries in DIR [[SITEDIR/SITEARCH]], "no" to disable site directory]),
|
||||||
|
[sitearchdir=$withval],
|
||||||
|
- [sitearchdir=${multiarch+'${rubysitearchprefix}/site_ruby/${ruby_version}'}${multiarch-'${sitelibdir}/${sitearch}'}])
|
||||||
|
+ [sitearchdir=${multiarch+'${rubysitearchprefix}/site_ruby'${ruby_version_suffix}}${multiarch-'${sitelibdir}/${sitearch}'}])
|
||||||
|
|
||||||
|
AC_ARG_WITH(vendordir,
|
||||||
|
AS_HELP_STRING([--with-vendordir=DIR], [vendor libraries in DIR [[RUBY_LIB_PREFIX/vendor_ruby]], "no" to disable vendor directory]),
|
||||||
|
[vendordir=$withval],
|
||||||
|
[vendordir='${rubylibprefix}/vendor_ruby'])
|
||||||
|
-vendorlibdir='${vendordir}/${ruby_version}'
|
||||||
|
+vendorlibdir='${vendordir}'${ruby_version_suffix}
|
||||||
|
|
||||||
|
AC_ARG_WITH(vendorarchdir,
|
||||||
|
AS_HELP_STRING([--with-vendorarchdir=DIR],
|
||||||
diff --git a/loadpath.c b/loadpath.c
|
diff --git a/loadpath.c b/loadpath.c
|
||||||
index b8969e6998..bbfd4daa78 100644
|
index 9160031..0d4d953 100644
|
||||||
--- a/loadpath.c
|
--- a/loadpath.c
|
||||||
+++ b/loadpath.c
|
+++ b/loadpath.c
|
||||||
@@ -65,21 +65,33 @@ const char ruby_initial_load_paths[] =
|
@@ -65,22 +65,34 @@ const char ruby_initial_load_paths[] =
|
||||||
RUBY_SEARCH_PATH "\0"
|
RUBY_SEARCH_PATH "\0"
|
||||||
#endif
|
#endif
|
||||||
#ifndef NO_RUBY_SITE_LIB
|
#ifndef NO_RUBY_SITE_LIB
|
||||||
|
|
@ -58,15 +104,16 @@ index b8969e6998..bbfd4daa78 100644
|
||||||
RUBY_VENDOR_ARCH_LIB_FOR(RUBY_SITEARCH) "\0"
|
RUBY_VENDOR_ARCH_LIB_FOR(RUBY_SITEARCH) "\0"
|
||||||
+#ifndef RUBY_LIB_VERSION_BLANK
|
+#ifndef RUBY_LIB_VERSION_BLANK
|
||||||
RUBY_VENDOR_LIB "\0"
|
RUBY_VENDOR_LIB "\0"
|
||||||
+#endif
|
|
||||||
#endif
|
#endif
|
||||||
|
+#endif
|
||||||
|
|
||||||
RUBY_LIB "\0"
|
RUBY_LIB "\0"
|
||||||
|
#ifdef RUBY_THINARCH
|
||||||
diff --git a/tool/mkconfig.rb b/tool/mkconfig.rb
|
diff --git a/tool/mkconfig.rb b/tool/mkconfig.rb
|
||||||
index db74115730..2b01796abf 100755
|
index 07076d4..35e6c3c 100755
|
||||||
--- a/tool/mkconfig.rb
|
--- a/tool/mkconfig.rb
|
||||||
+++ b/tool/mkconfig.rb
|
+++ b/tool/mkconfig.rb
|
||||||
@@ -114,7 +114,7 @@
|
@@ -123,7 +123,7 @@ File.foreach "config.status" do |line|
|
||||||
val = val.gsub(/\$(?:\$|\{?(\w+)\}?)/) {$1 ? "$(#{$1})" : $&}.dump
|
val = val.gsub(/\$(?:\$|\{?(\w+)\}?)/) {$1 ? "$(#{$1})" : $&}.dump
|
||||||
case name
|
case name
|
||||||
when /^prefix$/
|
when /^prefix$/
|
||||||
|
|
@ -75,3 +122,6 @@ index db74115730..2b01796abf 100755
|
||||||
when /^ARCH_FLAG$/
|
when /^ARCH_FLAG$/
|
||||||
val = "arch_flag || #{val}" if universal
|
val = "arch_flag || #{val}" if universal
|
||||||
when /^UNIVERSAL_ARCHNAMES$/
|
when /^UNIVERSAL_ARCHNAMES$/
|
||||||
|
--
|
||||||
|
1.9.0
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,22 +1,25 @@
|
||||||
From 9e70f6e4b8771965a30ecfb6d1c6015df350ca55 Mon Sep 17 00:00:00 2001
|
From 2089cab72b38d6d5e7ba2b596e41014209acad30 Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
Date: Mon, 19 Nov 2012 14:37:28 +0100
|
Date: Mon, 19 Nov 2012 14:37:28 +0100
|
||||||
Subject: [PATCH] Always use i386.
|
Subject: [PATCH] Always use i386.
|
||||||
|
|
||||||
---
|
---
|
||||||
configure.ac | 2 ++
|
configure.in | 2 ++
|
||||||
1 file changed, 2 insertions(+)
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.in b/configure.in
|
||||||
index b3bdfad1eb..411322a27f 100644
|
index 553d4d0..03a4152 100644
|
||||||
--- a/configure.ac
|
--- a/configure.in
|
||||||
+++ b/configure.ac
|
+++ b/configure.in
|
||||||
@@ -4536,6 +4536,8 @@ AC_SUBST(vendorarchdir)dnl
|
@@ -4127,6 +4127,8 @@ AC_SUBST(vendorarchdir)dnl
|
||||||
AC_SUBST(CONFIGURE, "`echo $0 | sed 's|.*/||'`")dnl
|
|
||||||
AC_SUBST(configure_args, "`echo "${ac_configure_args}" | sed 's/\\$/$$/g'`")dnl
|
AC_SUBST(configure_args, "`echo "${ac_configure_args}" | sed 's/\\$/$$/g'`")dnl
|
||||||
|
|
||||||
+target_cpu=`echo $target_cpu | sed s/i.86/i386/`
|
+target_cpu=`echo $target_cpu | sed s/i.86/i386/`
|
||||||
+
|
+
|
||||||
AS_IF([test "${universal_binary-no}" = yes ], [
|
if test "${universal_binary-no}" = yes ; then
|
||||||
arch="universal-${target_os}"
|
arch="universal-${target_os}"
|
||||||
AS_IF([test "${rb_cv_architecture_available}" = yes], [
|
if test "${rb_cv_architecture_available}" = yes; then
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,41 +1,41 @@
|
||||||
From c7952996ac9738a14bea0a1a971fea13460a6c94 Mon Sep 17 00:00:00 2001
|
From 94da59aafacc6a9efe829529eb51385588d6f149 Mon Sep 17 00:00:00 2001
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
Date: Fri, 11 Nov 2011 13:14:45 +0100
|
Date: Fri, 11 Nov 2011 13:14:45 +0100
|
||||||
Subject: [PATCH] Allow to install RubyGems into custom location, outside of
|
Subject: [PATCH] Allow to install RubyGems into custom location, outside of
|
||||||
Ruby tree.
|
Ruby tree.
|
||||||
|
|
||||||
---
|
---
|
||||||
configure.ac | 5 +++++
|
configure.in | 5 +++++
|
||||||
loadpath.c | 4 ++++
|
loadpath.c | 4 ++++
|
||||||
template/verconf.h.tmpl | 3 +++
|
template/verconf.h.tmpl | 3 +++
|
||||||
tool/rbinstall.rb | 10 ++++++++++
|
tool/rbinstall.rb | 9 +++++++++
|
||||||
4 files changed, 22 insertions(+)
|
4 files changed, 21 insertions(+)
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
diff --git a/configure.in b/configure.in
|
||||||
index 411322a27f..b5f842a512 100644
|
index 03a4152..0e371e2 100644
|
||||||
--- a/configure.ac
|
--- a/configure.in
|
||||||
+++ b/configure.ac
|
+++ b/configure.in
|
||||||
@@ -4508,6 +4508,10 @@ AC_ARG_WITH(vendorarchdir,
|
@@ -4101,6 +4101,10 @@ AC_ARG_WITH(vendorarchdir,
|
||||||
[vendorarchdir=$withval],
|
[vendorarchdir=$withval],
|
||||||
[vendorarchdir=${multiarch+'${rubysitearchprefix}/vendor_ruby'${ruby_version_dir}}${multiarch-'${vendorlibdir}/${sitearch}'}])
|
[vendorarchdir=${multiarch+'${rubysitearchprefix}/vendor_ruby/${ruby_version}'}${multiarch-'${vendorlibdir}/${sitearch}'}])
|
||||||
|
|
||||||
+AC_ARG_WITH(rubygemsdir,
|
+AC_ARG_WITH(rubygemsdir,
|
||||||
+ AS_HELP_STRING([--with-rubygemsdir=DIR], [custom rubygems directory]),
|
+ AS_HELP_STRING([--with-rubygemsdir=DIR], [custom rubygems directory]),
|
||||||
+ [rubygemsdir=$withval])
|
+ [rubygemsdir=$withval])
|
||||||
+
|
+
|
||||||
AS_IF([test "${LOAD_RELATIVE+set}"], [
|
if test "${LOAD_RELATIVE+set}"; then
|
||||||
AC_DEFINE_UNQUOTED(LOAD_RELATIVE, $LOAD_RELATIVE)
|
AC_DEFINE_UNQUOTED(LOAD_RELATIVE, $LOAD_RELATIVE)
|
||||||
RUBY_EXEC_PREFIX=''
|
RUBY_EXEC_PREFIX=''
|
||||||
@@ -4532,6 +4536,7 @@ AC_SUBST(sitearchdir)dnl
|
@@ -4124,6 +4128,7 @@ AC_SUBST(sitearchdir)dnl
|
||||||
AC_SUBST(vendordir)dnl
|
AC_SUBST(vendordir)dnl
|
||||||
AC_SUBST(vendorlibdir)dnl
|
AC_SUBST(vendorlibdir)dnl
|
||||||
AC_SUBST(vendorarchdir)dnl
|
AC_SUBST(vendorarchdir)dnl
|
||||||
+AC_SUBST(rubygemsdir)dnl
|
+AC_SUBST(rubygemsdir)dnl
|
||||||
|
|
||||||
AC_SUBST(CONFIGURE, "`echo $0 | sed 's|.*/||'`")dnl
|
|
||||||
AC_SUBST(configure_args, "`echo "${ac_configure_args}" | sed 's/\\$/$$/g'`")dnl
|
AC_SUBST(configure_args, "`echo "${ac_configure_args}" | sed 's/\\$/$$/g'`")dnl
|
||||||
|
|
||||||
diff --git a/loadpath.c b/loadpath.c
|
diff --git a/loadpath.c b/loadpath.c
|
||||||
index bbfd4daa78..69677a9297 100644
|
index 623dc9d..74c5d9e 100644
|
||||||
--- a/loadpath.c
|
--- a/loadpath.c
|
||||||
+++ b/loadpath.c
|
+++ b/loadpath.c
|
||||||
@@ -94,6 +94,10 @@ const char ruby_initial_load_paths[] =
|
@@ -94,6 +94,10 @@ const char ruby_initial_load_paths[] =
|
||||||
|
|
@ -50,10 +50,10 @@ index bbfd4daa78..69677a9297 100644
|
||||||
#ifdef RUBY_THINARCH
|
#ifdef RUBY_THINARCH
|
||||||
RUBY_ARCH_LIB_FOR(RUBY_THINARCH) "\0"
|
RUBY_ARCH_LIB_FOR(RUBY_THINARCH) "\0"
|
||||||
diff --git a/template/verconf.h.tmpl b/template/verconf.h.tmpl
|
diff --git a/template/verconf.h.tmpl b/template/verconf.h.tmpl
|
||||||
index 9ba2bd6de5..4ec4ce9353 100644
|
index 79c003e..34f2382 100644
|
||||||
--- a/template/verconf.h.tmpl
|
--- a/template/verconf.h.tmpl
|
||||||
+++ b/template/verconf.h.tmpl
|
+++ b/template/verconf.h.tmpl
|
||||||
@@ -36,6 +36,9 @@
|
@@ -34,6 +34,9 @@
|
||||||
% if C["RUBY_SEARCH_PATH"]
|
% if C["RUBY_SEARCH_PATH"]
|
||||||
#define RUBY_SEARCH_PATH "${RUBY_SEARCH_PATH}"
|
#define RUBY_SEARCH_PATH "${RUBY_SEARCH_PATH}"
|
||||||
% end
|
% end
|
||||||
|
|
@ -64,31 +64,33 @@ index 9ba2bd6de5..4ec4ce9353 100644
|
||||||
% R = {}
|
% R = {}
|
||||||
% R["ruby_version"] = '"RUBY_LIB_VERSION"'
|
% R["ruby_version"] = '"RUBY_LIB_VERSION"'
|
||||||
diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb
|
diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb
|
||||||
index a9e6365b27..7117e65e82 100755
|
index b47b6e1..0b99408 100755
|
||||||
--- a/tool/rbinstall.rb
|
--- a/tool/rbinstall.rb
|
||||||
+++ b/tool/rbinstall.rb
|
+++ b/tool/rbinstall.rb
|
||||||
@@ -393,6 +393,7 @@ def CONFIG.[](name, mandatory = false)
|
@@ -317,6 +317,7 @@ sitelibdir = CONFIG["sitelibdir"]
|
||||||
vendorlibdir = CONFIG["vendorlibdir"]
|
sitearchlibdir = CONFIG["sitearchdir"]
|
||||||
vendorarchlibdir = CONFIG["vendorarchdir"]
|
vendorlibdir = CONFIG["vendorlibdir"]
|
||||||
end
|
vendorarchlibdir = CONFIG["vendorarchdir"]
|
||||||
+rubygemsdir = CONFIG["rubygemsdir"]
|
+rubygemsdir = CONFIG["rubygemsdir"]
|
||||||
mandir = CONFIG["mandir", true]
|
mandir = CONFIG["mandir", true]
|
||||||
docdir = CONFIG["docdir", true]
|
docdir = CONFIG["docdir", true]
|
||||||
enable_shared = CONFIG["ENABLE_SHARED"] == 'yes'
|
configure_args = Shellwords.shellwords(CONFIG["configure_args"])
|
||||||
@@ -1082,7 +1083,16 @@ def (bins = []).add(name)
|
@@ -505,7 +506,15 @@ end
|
||||||
install?(:local, :comm, :lib) do
|
install?(:local, :comm, :lib) do
|
||||||
prepare "library scripts", rubylibdir
|
prepare "library scripts", rubylibdir
|
||||||
noinst = %w[*.txt *.rdoc *.gemspec]
|
noinst = %w[README* *.txt *.rdoc *.gemspec]
|
||||||
+ # Bundler carries "rubygems.rb" file, so it must be specialcased :/
|
+ noinst += %w[*ubygems.rb rubygems/ datadir.rb] if rubygemsdir
|
||||||
+ noinst += %w[rubygems.rb rubygems/ bundler.rb bundler/] if rubygemsdir
|
|
||||||
install_recursive(File.join(srcdir, "lib"), rubylibdir, :no_install => noinst, :mode => $data_mode)
|
install_recursive(File.join(srcdir, "lib"), rubylibdir, :no_install => noinst, :mode => $data_mode)
|
||||||
+ if rubygemsdir
|
+ if rubygemsdir
|
||||||
+ noinst = %w[*.txt *.rdoc *.gemspec]
|
+ noinst = %w[obsolete.rb]
|
||||||
+ install_recursive(File.join(srcdir, "lib", "rubygems"), File.join(rubygemsdir, "rubygems"), :no_install => noinst, :mode => $data_mode)
|
+ install_recursive(File.join(srcdir, "lib", "rubygems"), File.join(rubygemsdir, "rubygems"), :mode => $data_mode)
|
||||||
|
+ install_recursive(File.join(srcdir, "lib", "rbconfig"), File.join(rubygemsdir, "rbconfig"), :no_install => noinst, :mode => $data_mode)
|
||||||
|
+ install(File.join(srcdir, "lib", "ubygems.rb"), File.join(rubygemsdir, "ubygems.rb"), :mode => $data_mode)
|
||||||
+ install(File.join(srcdir, "lib", "rubygems.rb"), File.join(rubygemsdir, "rubygems.rb"), :mode => $data_mode)
|
+ install(File.join(srcdir, "lib", "rubygems.rb"), File.join(rubygemsdir, "rubygems.rb"), :mode => $data_mode)
|
||||||
+ install_recursive(File.join(srcdir, "lib", "bundler"), File.join(rubylibdir, "bundler"), :no_install => noinst, :mode => $data_mode)
|
|
||||||
+ install(File.join(srcdir, "lib", "bundler.rb"), rubylibdir, :mode => $data_mode)
|
|
||||||
+ end
|
+ end
|
||||||
end
|
end
|
||||||
|
|
||||||
install?(:local, :comm, :hdr, :'comm-hdr') do
|
install?(:local, :comm, :hdr, :'comm-hdr') do
|
||||||
|
--
|
||||||
|
1.8.3.1
|
||||||
|
|
||||||
|
|
|
||||||
28
ruby-2.2.3-Generate-preludes-using-miniruby.patch
Normal file
28
ruby-2.2.3-Generate-preludes-using-miniruby.patch
Normal file
|
|
@ -0,0 +1,28 @@
|
||||||
|
From 9fedac991e717f0103d092275ac301e58c5cf010 Mon Sep 17 00:00:00 2001
|
||||||
|
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
||||||
|
Date: Tue, 2 Dec 2014 10:56:58 +0100
|
||||||
|
Subject: [PATCH] Generate preludes using miniruby.
|
||||||
|
|
||||||
|
---
|
||||||
|
common.mk | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/common.mk b/common.mk
|
||||||
|
index 76f1621..b0f6e28 100644
|
||||||
|
--- a/common.mk
|
||||||
|
+++ b/common.mk
|
||||||
|
@@ -782,9 +782,9 @@ $(PRELUDE_C): $(COMPILE_PRELUDE) \
|
||||||
|
$(PRELUDE_C): $(COMPILE_PRELUDE) \
|
||||||
|
{$(srcdir)}lib/rubygems/defaults.rb \
|
||||||
|
{$(srcdir)}lib/rubygems/core_ext/kernel_gem.rb \
|
||||||
|
- $(PRELUDE_SCRIPTS) $(LIB_SRCS)
|
||||||
|
+ $(PRELUDE_SCRIPTS) $(PREP) $(LIB_SRCS)
|
||||||
|
$(ECHO) generating $@
|
||||||
|
- $(Q) $(BASERUBY) $(srcdir)/tool/generic_erb.rb -I$(srcdir) -c -o $@ \
|
||||||
|
+ $(Q) $(MINIRUBY) $(srcdir)/tool/generic_erb.rb -I$(srcdir) -c -o $@ \
|
||||||
|
$(srcdir)/template/prelude.c.tmpl $(PRELUDE_SCRIPTS)
|
||||||
|
|
||||||
|
{$(VPATH)}golf_prelude.c: $(COMPILE_PRELUDE) {$(srcdir)}golf_prelude.rb
|
||||||
|
--
|
||||||
|
2.1.0
|
||||||
|
|
||||||
|
|
@ -0,0 +1,40 @@
|
||||||
|
From cf23ad429da3213fd3b1261c546dfa08e7dba2bf Mon Sep 17 00:00:00 2001
|
||||||
|
From: usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>
|
||||||
|
Date: Wed, 27 Apr 2016 13:17:50 +0000
|
||||||
|
Subject: [PATCH] * compile.c (new_label_body): missed backporting r54548 in
|
||||||
|
r54698. this fixes randomly test failure introduced by r54698. cf. [Bug
|
||||||
|
#12082]
|
||||||
|
|
||||||
|
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@54799 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
|
||||||
|
---
|
||||||
|
ChangeLog | 6 ++++++
|
||||||
|
compile.c | 2 ++
|
||||||
|
2 files changed, 8 insertions(+), 0 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/ChangeLog b/ChangeLog
|
||||||
|
index 2cfdb2c2..fe09b1e 100644
|
||||||
|
--- a/ChangeLog
|
||||||
|
+++ b/ChangeLog
|
||||||
|
@@ -1,3 +1,9 @@
|
||||||
|
+Wed Apr 27 22:16:04 2016 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||||
|
+
|
||||||
|
+ * compile.c (new_label_body): missed backporting r54548 in r54698.
|
||||||
|
+ this fixes randomly test failure introduced by r54698.
|
||||||
|
+ cf. [Bug #12082]
|
||||||
|
+
|
||||||
|
Fri Apr 29 20:11:38 2016 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
|
* test/ruby/test_time_tz.rb: Tests depends on Europe/Moscow removed
|
||||||
|
diff --git a/compile.c b/compile.c
|
||||||
|
index 001152a..cc8e748 100644
|
||||||
|
--- a/compile.c
|
||||||
|
+++ b/compile.c
|
||||||
|
@@ -929,6 +929,8 @@ new_label_body(rb_iseq_t *iseq, long line)
|
||||||
|
labelobj->label_no = iseq->compile_data->label_no++;
|
||||||
|
labelobj->sc_state = 0;
|
||||||
|
labelobj->sp = -1;
|
||||||
|
+ labelobj->set = 0;
|
||||||
|
+ labelobj->rescued = LABEL_RESCUE_NONE;
|
||||||
|
return labelobj;
|
||||||
|
}
|
||||||
|
|
||||||
63
ruby-2.2.6-Tests-depends-on-Europe-Moscow-removed.patch
Normal file
63
ruby-2.2.6-Tests-depends-on-Europe-Moscow-removed.patch
Normal file
|
|
@ -0,0 +1,63 @@
|
||||||
|
From d16ff5c412b90b2766be97a5d3d689c5a18528d3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>
|
||||||
|
Date: Fri, 29 Apr 2016 11:12:17 +0000
|
||||||
|
Subject: [PATCH] merge revision(s) 54706:
|
||||||
|
|
||||||
|
* test/ruby/test_time_tz.rb: Tests depends on Europe/Moscow removed
|
||||||
|
to avoid test failures due to the tzdata change.
|
||||||
|
https://github.com/eggert/tz/commit/8ee11a301cf173afb0c76e0315b9f9ec8ebb9d95
|
||||||
|
Found by naruse.
|
||||||
|
|
||||||
|
|
||||||
|
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@54815 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
|
||||||
|
---
|
||||||
|
ChangeLog | 7 +++++++
|
||||||
|
test/ruby/test_time_tz.rb | 13 -------------
|
||||||
|
2 files changed, 7 insertions(+), 13 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/ChangeLog b/ChangeLog
|
||||||
|
index fe09b1e..1351c74 100644
|
||||||
|
--- a/ChangeLog
|
||||||
|
+++ b/ChangeLog
|
||||||
|
@@ -1,3 +1,10 @@
|
||||||
|
+Fri Apr 29 20:11:38 2016 Tanaka Akira <akr@fsij.org>
|
||||||
|
+
|
||||||
|
+ * test/ruby/test_time_tz.rb: Tests depends on Europe/Moscow removed
|
||||||
|
+ to avoid test failures due to the tzdata change.
|
||||||
|
+ https://github.com/eggert/tz/commit/8ee11a301cf173afb0c76e0315b9f9ec8ebb9d95
|
||||||
|
+ Found by naruse.
|
||||||
|
+
|
||||||
|
Tue Apr 26 13:38:31 2016 NAKAMURA Usaku <usa@ruby-lang.org>
|
||||||
|
|
||||||
|
* README.EXT{,.ja}: `nul` should be uppercase.
|
||||||
|
diff --git a/test/ruby/test_time_tz.rb b/test/ruby/test_time_tz.rb
|
||||||
|
index fb1ab9b..96a03b7 100644
|
||||||
|
--- a/test/ruby/test_time_tz.rb
|
||||||
|
+++ b/test/ruby/test_time_tz.rb
|
||||||
|
@@ -169,13 +169,6 @@ def test_europe_lisbon
|
||||||
|
}
|
||||||
|
end if has_lisbon_tz
|
||||||
|
|
||||||
|
- def test_europe_moscow
|
||||||
|
- with_tz(tz="Europe/Moscow") {
|
||||||
|
- assert_time_constructor(tz, "1992-03-29 00:00:00 +0400", :local, [1992,3,28,23,0,0])
|
||||||
|
- assert_time_constructor(tz, "1992-03-29 00:59:59 +0400", :local, [1992,3,28,23,59,59])
|
||||||
|
- }
|
||||||
|
- end
|
||||||
|
-
|
||||||
|
def test_pacific_kiritimati
|
||||||
|
with_tz(tz="Pacific/Kiritimati") {
|
||||||
|
assert_time_constructor(tz, "1994-12-31 23:59:59 -1000", :local, [1994,12,31,23,59,59])
|
||||||
|
@@ -355,12 +348,6 @@ def self.gen_zdump_test(data)
|
||||||
|
Europe/London Sun Aug 10 01:00:00 1947 UTC = Sun Aug 10 02:00:00 1947 BST isdst=1 gmtoff=3600
|
||||||
|
Europe/London Sun Nov 2 01:59:59 1947 UTC = Sun Nov 2 02:59:59 1947 BST isdst=1 gmtoff=3600
|
||||||
|
Europe/London Sun Nov 2 02:00:00 1947 UTC = Sun Nov 2 02:00:00 1947 GMT isdst=0 gmtoff=0
|
||||||
|
-Europe/Moscow Sat Jan 18 23:59:59 1992 UTC = Sun Jan 19 01:59:59 1992 MSK isdst=0 gmtoff=7200
|
||||||
|
-Europe/Moscow Sun Jan 19 00:00:00 1992 UTC = Sun Jan 19 03:00:00 1992 MSK isdst=0 gmtoff=10800
|
||||||
|
-Europe/Moscow Sat Mar 28 19:59:59 1992 UTC = Sat Mar 28 22:59:59 1992 MSK isdst=0 gmtoff=10800
|
||||||
|
-Europe/Moscow Sat Mar 28 20:00:00 1992 UTC = Sun Mar 29 00:00:00 1992 MSD isdst=1 gmtoff=14400
|
||||||
|
-Europe/Moscow Sat Sep 26 18:59:59 1992 UTC = Sat Sep 26 22:59:59 1992 MSD isdst=1 gmtoff=14400
|
||||||
|
-Europe/Moscow Sat Sep 26 19:00:00 1992 UTC = Sat Sep 26 22:00:00 1992 MSK isdst=0 gmtoff=10800
|
||||||
|
Pacific/Kiritimati Sun Jan 1 09:59:59 1995 UTC = Sat Dec 31 23:59:59 1994 LINT isdst=0 gmtoff=-36000
|
||||||
|
Pacific/Kiritimati Sun Jan 1 10:00:00 1995 UTC = Mon Jan 2 00:00:00 1995 LINT isdst=0 gmtoff=50400
|
||||||
|
End
|
||||||
|
|
@ -1,22 +0,0 @@
|
||||||
From f833e213596b0bcfad8264a555eb5093303fb5f2 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jarek Prokop <jprokop@redhat.com>
|
|
||||||
Date: Thu, 25 Sep 2025 12:26:39 +0200
|
|
||||||
Subject: [PATCH] Add ruby_version_dir_name support for RDoc.
|
|
||||||
|
|
||||||
---
|
|
||||||
lib/rdoc/ri/paths.rb | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/lib/rdoc/ri/paths.rb b/lib/rdoc/ri/paths.rb
|
|
||||||
index 8e89b04e..731f9e36 100644
|
|
||||||
--- a/lib/rdoc/ri/paths.rb
|
|
||||||
+++ b/lib/rdoc/ri/paths.rb
|
|
||||||
@@ -10,7 +10,7 @@ module RDoc::RI::Paths
|
|
||||||
#:stopdoc:
|
|
||||||
require 'rbconfig'
|
|
||||||
|
|
||||||
- version = RbConfig::CONFIG['ruby_version']
|
|
||||||
+ version = RbConfig::CONFIG['ruby_version_dir_name'] || RbConfig::CONFIG['ruby_version']
|
|
||||||
|
|
||||||
BASE = File.join RbConfig::CONFIG['ridir'], version
|
|
||||||
|
|
||||||
|
|
@ -1,257 +0,0 @@
|
||||||
From 5406ea4b4b13db747e5c1f8341bb257b4da04435 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Tue, 31 Mar 2015 16:21:04 +0200
|
|
||||||
Subject: [PATCH 1/4] Use ruby_version_dir_name for versioned directories.
|
|
||||||
|
|
||||||
This disallows changing the ruby_version constant by --with-ruby-version
|
|
||||||
configuration options. The two places version numbers are disallowed as
|
|
||||||
well, since there are a lot of places which cannot handle this format
|
|
||||||
properly.
|
|
||||||
|
|
||||||
ruby_version_dir_name now specifies custom version string for versioned
|
|
||||||
directories, e.g. instead of default X.Y.Z, you can specify whatever
|
|
||||||
string.
|
|
||||||
---
|
|
||||||
configure.ac | 66 ++++++++++++++++++++++++---------------------
|
|
||||||
template/ruby.pc.in | 1 +
|
|
||||||
2 files changed, 36 insertions(+), 31 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
|
||||||
index 2bbce78fd0..9d8662369c 100644
|
|
||||||
--- a/configure.ac
|
|
||||||
+++ b/configure.ac
|
|
||||||
@@ -4422,9 +4422,6 @@ AS_CASE(["$target_os"],
|
|
||||||
rubyw_install_name='$(RUBYW_INSTALL_NAME)'
|
|
||||||
])
|
|
||||||
|
|
||||||
-rubylibdir='${rubylibprefix}/${ruby_version}'
|
|
||||||
-rubyarchdir=${multiarch+'${rubyarchprefix}/${ruby_version}'}${multiarch-'${rubylibdir}/${arch}'}
|
|
||||||
-
|
|
||||||
rubyarchprefix=${multiarch+'${archlibdir}/${RUBY_BASE_NAME}'}${multiarch-'${rubylibprefix}/${arch}'}
|
|
||||||
AC_ARG_WITH(rubyarchprefix,
|
|
||||||
AS_HELP_STRING([--with-rubyarchprefix=DIR],
|
|
||||||
@@ -4447,57 +4444,63 @@ AC_ARG_WITH(ridir,
|
|
||||||
AC_SUBST(ridir)
|
|
||||||
AC_SUBST(RI_BASE_NAME)
|
|
||||||
|
|
||||||
-AC_ARG_WITH(ruby-version,
|
|
||||||
- AS_HELP_STRING([--with-ruby-version=STR], [ruby version string for version specific directories [[full]] (full|minor|STR)]),
|
|
||||||
- [ruby_version=$withval],
|
|
||||||
- [ruby_version=full])
|
|
||||||
unset RUBY_LIB_VERSION
|
|
||||||
-unset RUBY_LIB_VERSION_STYLE
|
|
||||||
-AS_CASE(["$ruby_version"],
|
|
||||||
- [full], [RUBY_LIB_VERSION_STYLE='3 /* full */'],
|
|
||||||
- [minor], [RUBY_LIB_VERSION_STYLE='2 /* minor */'])
|
|
||||||
-AS_IF([test ${RUBY_LIB_VERSION_STYLE+set}], [
|
|
||||||
- {
|
|
||||||
- echo "#define RUBY_LIB_VERSION_STYLE $RUBY_LIB_VERSION_STYLE"
|
|
||||||
- echo '@%:@include "confdefs.h"'
|
|
||||||
- echo '#define STRINGIZE(x) x'
|
|
||||||
- test -f revision.h -o -f "${srcdir}/revision.h" || echo '#define RUBY_REVISION 0'
|
|
||||||
- echo '#include "version.h"'
|
|
||||||
- echo 'ruby_version=RUBY_LIB_VERSION'
|
|
||||||
- } > conftest.c
|
|
||||||
- ruby_version="`$CPP -I. -I"${srcdir}" -I"${srcdir}/include" conftest.c | sed '/^ruby_version=/!d;s/ //g'`"
|
|
||||||
- eval $ruby_version
|
|
||||||
-], [test -z "${ruby_version}"], [
|
|
||||||
- AC_MSG_ERROR([No ruby version, No place for bundled libraries])
|
|
||||||
-], [
|
|
||||||
- RUBY_LIB_VERSION="${ruby_version}"
|
|
||||||
-])
|
|
||||||
+RUBY_LIB_VERSION_STYLE='3 /* full */'
|
|
||||||
+{
|
|
||||||
+echo "#define RUBY_LIB_VERSION_STYLE $RUBY_LIB_VERSION_STYLE"
|
|
||||||
+echo '@%:@include "confdefs.h"'
|
|
||||||
+echo '#define STRINGIZE(x) x'
|
|
||||||
+test -f revision.h -o -f "${srcdir}/revision.h" || echo '#define RUBY_REVISION 0'
|
|
||||||
+echo '#include "version.h"'
|
|
||||||
+echo 'ruby_version=RUBY_LIB_VERSION'
|
|
||||||
+} > conftest.c
|
|
||||||
+ruby_version="`$CPP -I. -I"${srcdir}" -I"${srcdir}/include" conftest.c | sed '/^ruby_version=/!d;s/ //g'`"
|
|
||||||
+eval $ruby_version
|
|
||||||
+
|
|
||||||
+RUBY_LIB_VERSION="${ruby_version}"
|
|
||||||
+
|
|
||||||
AC_SUBST(RUBY_LIB_VERSION_STYLE)
|
|
||||||
AC_SUBST(RUBY_LIB_VERSION)
|
|
||||||
|
|
||||||
+AC_ARG_WITH(ruby-version,
|
|
||||||
+ AS_HELP_STRING([--with-ruby-version=STR], [ruby version string for version specific directories [[full]] (full|STR)]),
|
|
||||||
+ [ruby_version_dir_name=$withval],
|
|
||||||
+ [ruby_version_dir_name=full])
|
|
||||||
+AS_CASE(["$ruby_version_dir_name"],
|
|
||||||
+ [full], [ruby_version_dir_name='${ruby_version}'])
|
|
||||||
+
|
|
||||||
+ruby_version_dir=/'${ruby_version_dir_name}'
|
|
||||||
+
|
|
||||||
+if test -z "${ruby_version_dir_name}"; then
|
|
||||||
+ AC_MSG_ERROR([No ruby version, No place for bundled libraries])
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
+rubylibdir='${rubylibprefix}'${ruby_version_dir}
|
|
||||||
+rubyarchdir=${multiarch+'${rubyarchprefix}'${ruby_version_dir}}${multiarch-'${rubylibdir}/${arch}'}
|
|
||||||
+
|
|
||||||
AC_ARG_WITH(sitedir,
|
|
||||||
AS_HELP_STRING([--with-sitedir=DIR], [site libraries in DIR [[RUBY_LIB_PREFIX/site_ruby]], "no" to disable site directory]),
|
|
||||||
[sitedir=$withval],
|
|
||||||
[sitedir='${rubylibprefix}/site_ruby'])
|
|
||||||
-sitelibdir='${sitedir}/${ruby_version}'
|
|
||||||
+sitelibdir='${sitedir}'${ruby_version_dir}
|
|
||||||
|
|
||||||
AC_ARG_WITH(sitearchdir,
|
|
||||||
AS_HELP_STRING([--with-sitearchdir=DIR],
|
|
||||||
[architecture dependent site libraries in DIR [[SITEDIR/SITEARCH]], "no" to disable site directory]),
|
|
||||||
[sitearchdir=$withval],
|
|
||||||
- [sitearchdir=${multiarch+'${rubysitearchprefix}/site_ruby/${ruby_version}'}${multiarch-'${sitelibdir}/${sitearch}'}])
|
|
||||||
+ [sitearchdir=${multiarch+'${rubysitearchprefix}/site_ruby'${ruby_version_dir}}${multiarch-'${sitelibdir}/${sitearch}'}])
|
|
||||||
|
|
||||||
AC_ARG_WITH(vendordir,
|
|
||||||
AS_HELP_STRING([--with-vendordir=DIR], [vendor libraries in DIR [[RUBY_LIB_PREFIX/vendor_ruby]], "no" to disable vendor directory]),
|
|
||||||
[vendordir=$withval],
|
|
||||||
[vendordir='${rubylibprefix}/vendor_ruby'])
|
|
||||||
-vendorlibdir='${vendordir}/${ruby_version}'
|
|
||||||
+vendorlibdir='${vendordir}'${ruby_version_dir}
|
|
||||||
|
|
||||||
AC_ARG_WITH(vendorarchdir,
|
|
||||||
AS_HELP_STRING([--with-vendorarchdir=DIR],
|
|
||||||
[architecture dependent vendor libraries in DIR [[VENDORDIR/SITEARCH]], "no" to disable vendor directory]),
|
|
||||||
[vendorarchdir=$withval],
|
|
||||||
- [vendorarchdir=${multiarch+'${rubysitearchprefix}/vendor_ruby/${ruby_version}'}${multiarch-'${vendorlibdir}/${sitearch}'}])
|
|
||||||
+ [vendorarchdir=${multiarch+'${rubysitearchprefix}/vendor_ruby'${ruby_version_dir}}${multiarch-'${vendorlibdir}/${sitearch}'}])
|
|
||||||
|
|
||||||
AS_IF([test "${LOAD_RELATIVE+set}"], [
|
|
||||||
AC_DEFINE_UNQUOTED(LOAD_RELATIVE, $LOAD_RELATIVE)
|
|
||||||
@@ -4514,6 +4517,7 @@ AC_SUBST(sitearchincludedir)dnl
|
|
||||||
AC_SUBST(arch)dnl
|
|
||||||
AC_SUBST(sitearch)dnl
|
|
||||||
AC_SUBST(ruby_version)dnl
|
|
||||||
+AC_SUBST(ruby_version_dir_name)dnl
|
|
||||||
AC_SUBST(rubylibdir)dnl
|
|
||||||
AC_SUBST(rubyarchdir)dnl
|
|
||||||
AC_SUBST(sitedir)dnl
|
|
||||||
diff --git a/template/ruby.pc.in b/template/ruby.pc.in
|
|
||||||
index 6901ec2320..9b7b787208 100644
|
|
||||||
--- a/template/ruby.pc.in
|
|
||||||
+++ b/template/ruby.pc.in
|
|
||||||
@@ -2,6 +2,7 @@ MAJOR=@MAJOR@
|
|
||||||
MINOR=@MINOR@
|
|
||||||
TEENY=@TEENY@
|
|
||||||
ruby_version=@ruby_version@
|
|
||||||
+ruby_version_dir_name=@ruby_version_dir_name@
|
|
||||||
RUBY_API_VERSION=@RUBY_API_VERSION@
|
|
||||||
RUBY_PROGRAM_VERSION=@RUBY_PROGRAM_VERSION@
|
|
||||||
arch=@arch@
|
|
||||||
|
|
||||||
From baff562149499973123d2187620201be641c6538 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Tue, 31 Mar 2015 16:37:26 +0200
|
|
||||||
Subject: [PATCH 2/4] Add ruby_version_dir_name support for RDoc.
|
|
||||||
|
|
||||||
---
|
|
||||||
tool/rbinstall.rb | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/tool/rbinstall.rb b/tool/rbinstall.rb
|
|
||||||
index 874c3ef1d9..a9e6365b27 100755
|
|
||||||
--- a/tool/rbinstall.rb
|
|
||||||
+++ b/tool/rbinstall.rb
|
|
||||||
@@ -1053,7 +1053,7 @@ def (bins = []).add(name)
|
|
||||||
|
|
||||||
install?(:doc, :rdoc) do
|
|
||||||
if $rdocdir
|
|
||||||
- ridatadir = File.join(CONFIG['ridir'], CONFIG['ruby_version'], "system")
|
|
||||||
+ ridatadir = File.join(CONFIG['ridir'], CONFIG['ruby_version_dir_name'] || CONFIG['ruby_version'], "system")
|
|
||||||
prepare "rdoc", ridatadir
|
|
||||||
install_recursive($rdocdir, ridatadir, :no_install => rdoc_noinst, :mode => $data_mode)
|
|
||||||
end
|
|
||||||
|
|
||||||
From 7cf872a9a34f38d71cd2ca04ac114b4ea85cc56c Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Tue, 31 Mar 2015 16:37:44 +0200
|
|
||||||
Subject: [PATCH 3/4] Add ruby_version_dir_name support for RubyGems.
|
|
||||||
|
|
||||||
---
|
|
||||||
lib/rubygems/defaults.rb | 7 ++++---
|
|
||||||
test/rubygems/test_gem.rb | 5 +++--
|
|
||||||
2 files changed, 7 insertions(+), 5 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/lib/rubygems/defaults.rb b/lib/rubygems/defaults.rb
|
|
||||||
index 90f09fc191..f6b8a03b95 100644
|
|
||||||
--- a/lib/rubygems/defaults.rb
|
|
||||||
+++ b/lib/rubygems/defaults.rb
|
|
||||||
@@ -35,7 +35,7 @@ def self.default_spec_cache_dir
|
|
||||||
# specified in the environment
|
|
||||||
|
|
||||||
def self.default_dir
|
|
||||||
- @default_dir ||= File.join(RbConfig::CONFIG["rubylibprefix"], "gems", RbConfig::CONFIG["ruby_version"])
|
|
||||||
+ @default_dir ||= File.join(RbConfig::CONFIG["rubylibprefix"], "gems", RbConfig::CONFIG["ruby_version_dir_name"] || RbConfig::CONFIG["ruby_version"])
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
||||||
@@ -104,7 +104,8 @@ def self.user_dir
|
|
||||||
gem_dir = File.join(Gem.user_home, ".gem")
|
|
||||||
gem_dir = File.join(Gem.data_home, "gem") unless File.exist?(gem_dir)
|
|
||||||
parts = [gem_dir, ruby_engine]
|
|
||||||
- parts << RbConfig::CONFIG["ruby_version"] unless RbConfig::CONFIG["ruby_version"].empty?
|
|
||||||
+ ruby_version_dir_name = RbConfig::CONFIG["ruby_version_dir_name"] || RbConfig::CONFIG["ruby_version"]
|
|
||||||
+ parts << ruby_version_dir_name unless ruby_version_dir_name.empty?
|
|
||||||
File.join parts
|
|
||||||
end
|
|
||||||
|
|
||||||
@@ -265,7 +266,7 @@ def self.vendor_dir # :nodoc:
|
|
||||||
return nil unless RbConfig::CONFIG.key? "vendordir"
|
|
||||||
|
|
||||||
File.join RbConfig::CONFIG["vendordir"], "gems",
|
|
||||||
- RbConfig::CONFIG["ruby_version"]
|
|
||||||
+ RbConfig::CONFIG["ruby_version_dir_name"] || RbConfig::CONFIG["ruby_version"]
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
||||||
diff --git a/test/rubygems/test_gem.rb b/test/rubygems/test_gem.rb
|
|
||||||
index 74c8953904..1f3bd91d51 100644
|
|
||||||
--- a/test/rubygems/test_gem.rb
|
|
||||||
+++ b/test/rubygems/test_gem.rb
|
|
||||||
@@ -1339,7 +1339,8 @@ def test_self_use_paths
|
|
||||||
|
|
||||||
def test_self_user_dir
|
|
||||||
parts = [@userhome, ".gem", Gem.ruby_engine]
|
|
||||||
- parts << RbConfig::CONFIG["ruby_version"] unless RbConfig::CONFIG["ruby_version"].empty?
|
|
||||||
+ ruby_version_dir_name = RbConfig::CONFIG["ruby_version_dir_name"] || RbConfig::CONFIG["ruby_version"]
|
|
||||||
+ parts << ruby_version_dir_name unless ruby_version_dir_name.empty?
|
|
||||||
|
|
||||||
FileUtils.mkdir_p File.join(parts)
|
|
||||||
|
|
||||||
@@ -1415,7 +1416,7 @@ def test_self_vendor_dir
|
|
||||||
vendordir(File.join(@tempdir, "vendor")) do
|
|
||||||
expected =
|
|
||||||
File.join RbConfig::CONFIG["vendordir"], "gems",
|
|
||||||
- RbConfig::CONFIG["ruby_version"]
|
|
||||||
+ RbConfig::CONFIG["ruby_version_dir_name"] || RbConfig::CONFIG["ruby_version"]
|
|
||||||
|
|
||||||
assert_equal expected, Gem.vendor_dir
|
|
||||||
end
|
|
||||||
|
|
||||||
From 17cb98b7b78f8bfc511feffbe061747f676055b1 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Wed, 1 Apr 2015 14:55:37 +0200
|
|
||||||
Subject: [PATCH 4/4] Let headers directories follow the configured version
|
|
||||||
name.
|
|
||||||
|
|
||||||
---
|
|
||||||
configure.ac | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
|
||||||
index 9d8662369c..2bc5153141 100644
|
|
||||||
--- a/configure.ac
|
|
||||||
+++ b/configure.ac
|
|
||||||
@@ -151,7 +151,7 @@ RUBY_BASE_NAME=`echo ruby | sed "$program_transform_name"`
|
|
||||||
RUBYW_BASE_NAME=`echo rubyw | sed "$program_transform_name"`
|
|
||||||
AC_SUBST(RUBY_BASE_NAME)
|
|
||||||
AC_SUBST(RUBYW_BASE_NAME)
|
|
||||||
-AC_SUBST(RUBY_VERSION_NAME, '${RUBY_BASE_NAME}-${ruby_version}')
|
|
||||||
+AC_SUBST(RUBY_VERSION_NAME, '${RUBY_BASE_NAME}-${ruby_version_dir_name}')
|
|
||||||
|
|
||||||
dnl checks for alternative programs
|
|
||||||
AC_CANONICAL_BUILD
|
|
||||||
|
|
@ -1,86 +0,0 @@
|
||||||
From 03b44a86b574dc0b63fd57c5f9b52b56ad3ced37 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Mon, 6 Jan 2020 13:56:04 +0100
|
|
||||||
Subject: [PATCH] Initialize ABRT hook.
|
|
||||||
|
|
||||||
The ABRT hook used to be initialized by preludes via patches [[1], [2]].
|
|
||||||
Unfortunately, due to [[3]] and especially since [[4]], this would
|
|
||||||
require boostrapping [[5]].
|
|
||||||
|
|
||||||
To keep the things simple for now, load the ABRT hook via C.
|
|
||||||
|
|
||||||
[1]: https://bugs.ruby-lang.org/issues/8566
|
|
||||||
[2]: https://bugs.ruby-lang.org/issues/15306
|
|
||||||
[3]: https://bugs.ruby-lang.org/issues/16254
|
|
||||||
[4]: https://github.com/ruby/ruby/pull/2735
|
|
||||||
[5]: https://lists.fedoraproject.org/archives/list/ruby-sig@lists.fedoraproject.org/message/LH6L6YJOYQT4Y5ZNOO4SLIPTUWZ5V45Q/
|
|
||||||
---
|
|
||||||
abrt.c | 12 ++++++++++++
|
|
||||||
common.mk | 1 +
|
|
||||||
ruby.c | 4 ++++
|
|
||||||
spec/ruby/core/kernel/require_spec.rb | 2 ++
|
|
||||||
4 files changed, 19 insertions(+)
|
|
||||||
create mode 100644 abrt.c
|
|
||||||
|
|
||||||
diff --git a/abrt.c b/abrt.c
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000000..e99cb432e6
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/abrt.c
|
|
||||||
@@ -0,0 +1,12 @@
|
|
||||||
+#include "internal.h"
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+Init_abrt(void)
|
|
||||||
+{
|
|
||||||
+ rb_eval_string(
|
|
||||||
+ " begin\n"
|
|
||||||
+ " require 'abrt'\n"
|
|
||||||
+ " rescue LoadError\n"
|
|
||||||
+ " end\n"
|
|
||||||
+ );
|
|
||||||
+}
|
|
||||||
diff --git a/common.mk b/common.mk
|
|
||||||
index 08fee9119a..dae7d9dc00 100644
|
|
||||||
--- a/common.mk
|
|
||||||
+++ b/common.mk
|
|
||||||
@@ -116,6 +116,7 @@ PRISM_FILES = prism/api_node.$(OBJEXT) \
|
|
||||||
prism_init.$(OBJEXT)
|
|
||||||
|
|
||||||
COMMONOBJS = \
|
|
||||||
+ abrt.$(OBJEXT) \
|
|
||||||
array.$(OBJEXT) \
|
|
||||||
ast.$(OBJEXT) \
|
|
||||||
bignum.$(OBJEXT) \
|
|
||||||
diff --git a/ruby.c b/ruby.c
|
|
||||||
index b00fc1502d..32b88f7496 100644
|
|
||||||
--- a/ruby.c
|
|
||||||
+++ b/ruby.c
|
|
||||||
@@ -1773,10 +1773,14 @@ proc_options(long argc, char **argv, ruby_cmdline_options_t *opt, int envopt)
|
|
||||||
|
|
||||||
void Init_builtin_features(void);
|
|
||||||
|
|
||||||
+/* abrt.c */
|
|
||||||
+void Init_abrt(void);
|
|
||||||
+
|
|
||||||
static void
|
|
||||||
ruby_init_prelude(void)
|
|
||||||
{
|
|
||||||
Init_builtin_features();
|
|
||||||
+ Init_abrt();
|
|
||||||
}
|
|
||||||
|
|
||||||
void rb_call_builtin_inits(void);
|
|
||||||
diff --git a/spec/ruby/core/kernel/require_spec.rb b/spec/ruby/core/kernel/require_spec.rb
|
|
||||||
index 60d17242fe..a8f93b0db4 100644
|
|
||||||
--- a/spec/ruby/core/kernel/require_spec.rb
|
|
||||||
+++ b/spec/ruby/core/kernel/require_spec.rb
|
|
||||||
@@ -26,6 +26,8 @@
|
|
||||||
out = ruby_exe("puts $LOADED_FEATURES", options: '--disable-gems --disable-did-you-mean')
|
|
||||||
features = out.lines.map { |line| File.basename(line.chomp, '.*') }
|
|
||||||
|
|
||||||
+ # Ignore ABRT
|
|
||||||
+ features -= %w[abrt]
|
|
||||||
# Ignore CRuby internals
|
|
||||||
features -= %w[encdb transdb windows_1252 windows_31j]
|
|
||||||
features.reject! { |feature| feature.end_with?('-fake') }
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
||||||
From 9b7cb6a40d73bb86ee0de34360068e90e80f4e7e Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?V=C3=ADt=20Ondruch?= <vondruch@redhat.com>
|
|
||||||
Date: Thu, 7 Sep 2023 13:13:02 +0200
|
|
||||||
Subject: [PATCH] Disable syntax-suggest test case.
|
|
||||||
|
|
||||||
This requires internet connection.
|
|
||||||
---
|
|
||||||
common.mk | 2 --
|
|
||||||
1 file changed, 2 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/common.mk b/common.mk
|
|
||||||
index dae7d9dc00..111e859d1b 100644
|
|
||||||
--- a/common.mk
|
|
||||||
+++ b/common.mk
|
|
||||||
@@ -1619,8 +1619,6 @@ no-test-bundled-gems-spec:
|
|
||||||
|
|
||||||
test-syntax-suggest:
|
|
||||||
|
|
||||||
-check: $(DOT_WAIT) $(PREPARE_SYNTAX_SUGGEST) test-syntax-suggest
|
|
||||||
-
|
|
||||||
test-bundler-precheck: $(TEST_RUNNABLE)-test-bundler-precheck
|
|
||||||
no-test-bundler-precheck:
|
|
||||||
yes-test-bundler-precheck: main $(arch)-fake.rb
|
|
||||||
|
|
@ -1,117 +0,0 @@
|
||||||
From 1cfb11bc8d01e4fc1ff47807721e29b250f0f19f Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jarek Prokop <jprokop@redhat.com>
|
|
||||||
Date: Mon, 22 Dec 2025 10:13:34 +0100
|
|
||||||
Subject: [PATCH] Support customizable rustc_flags for rustc builds.
|
|
||||||
|
|
||||||
Add `rustc_flags` option for configure that appends to RUSTC_FLAGS
|
|
||||||
flags used when compiling with rustc for customizable build flags.
|
|
||||||
It appends to existing defaults in RUSTC_FLAGS.
|
|
||||||
|
|
||||||
Co-authored-by: Alan Wu <XrXr@users.noreply.github.com>
|
|
||||||
---
|
|
||||||
common.mk | 10 ++--------
|
|
||||||
configure.ac | 8 ++++++++
|
|
||||||
defs/jit.mk | 2 ++
|
|
||||||
template/Makefile.in | 1 +
|
|
||||||
4 files changed, 13 insertions(+), 8 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/common.mk b/common.mk
|
|
||||||
index 08fee9119a..9ac5ae919f 100644
|
|
||||||
--- a/common.mk
|
|
||||||
+++ b/common.mk
|
|
||||||
@@ -270,21 +270,15 @@ MAKE_LINK = $(MINIRUBY) -rfileutils -e "include FileUtils::Verbose" \
|
|
||||||
# For release builds
|
|
||||||
YJIT_RUSTC_ARGS = --crate-name=yjit \
|
|
||||||
$(JIT_RUST_FLAGS) \
|
|
||||||
+ $(RUSTC_FLAGS) \
|
|
||||||
--edition=2021 \
|
|
||||||
- -g \
|
|
||||||
- -C lto=thin \
|
|
||||||
- -C opt-level=3 \
|
|
||||||
- -C overflow-checks=on \
|
|
||||||
'--out-dir=$(CARGO_TARGET_DIR)/release/' \
|
|
||||||
'$(top_srcdir)/yjit/src/lib.rs'
|
|
||||||
|
|
||||||
ZJIT_RUSTC_ARGS = --crate-name=zjit \
|
|
||||||
$(JIT_RUST_FLAGS) \
|
|
||||||
+ $(RUSTC_FLAGS) \
|
|
||||||
--edition=2024 \
|
|
||||||
- -g \
|
|
||||||
- -C lto=thin \
|
|
||||||
- -C opt-level=3 \
|
|
||||||
- -C overflow-checks=on \
|
|
||||||
'--out-dir=$(CARGO_TARGET_DIR)/release/' \
|
|
||||||
'$(top_srcdir)/zjit/src/lib.rs'
|
|
||||||
|
|
||||||
diff --git a/configure.ac b/configure.ac
|
|
||||||
index 2bbce78fd0..a3aa6dc383 100644
|
|
||||||
--- a/configure.ac
|
|
||||||
+++ b/configure.ac
|
|
||||||
@@ -69,6 +69,7 @@ dnl 93(bright yellow) is copied from .github/workflows/mingw.yml
|
|
||||||
AC_ARG_VAR([cflags], [additional CFLAGS (ignored when CFLAGS is given)])dnl
|
|
||||||
AC_ARG_VAR([cppflags], [additional CPPFLAGS (ignored when CPPFLAGS is given)])dnl
|
|
||||||
AC_ARG_VAR([cxxflags], [additional CXXFLAGS (ignored when CXXFLAGS is given)])dnl
|
|
||||||
+AC_ARG_VAR([rustc_flags], [additional RUSTC_FLAGS])dnl
|
|
||||||
|
|
||||||
[begin]_group "environment section" && {
|
|
||||||
HAVE_BASERUBY=yes
|
|
||||||
@@ -4054,6 +4055,11 @@ AS_CASE(["${ZJIT_SUPPORT}"],
|
|
||||||
AC_DEFINE(USE_ZJIT, 0)
|
|
||||||
])
|
|
||||||
|
|
||||||
+RUSTC_FLAGS='-g -C lto=thin -C opt-level=3 -C overflow-checks=on'
|
|
||||||
+AS_IF([test -n "${rustc_flags}"], [
|
|
||||||
+ RUSTC_FLAGS="${RUSTC_FLAGS} ${rustc_flags}"
|
|
||||||
+])
|
|
||||||
+
|
|
||||||
JIT_RUST_FLAGS='--crate-type=staticlib --cfg feature=\"stats_allocator\"'
|
|
||||||
RLIB_DIR=
|
|
||||||
AS_CASE(["$JIT_CARGO_SUPPORT:$YJIT_SUPPORT:$ZJIT_SUPPORT"],
|
|
||||||
@@ -4111,6 +4117,7 @@ AS_IF([test -n "$RUST_LIB"], [
|
|
||||||
dnl These variables end up in ::RbConfig::CONFIG
|
|
||||||
AC_SUBST(RUSTC)dnl Rust compiler command
|
|
||||||
AC_SUBST(JIT_RUST_FLAGS)dnl the common rustc flags for JIT crates such as zjit
|
|
||||||
+AC_SUBST(RUSTC_FLAGS)dnl user-configurable rustc compiler flags
|
|
||||||
AC_SUBST(CARGO)dnl Cargo command for Rust builds
|
|
||||||
AC_SUBST(CARGO_BUILD_ARGS)dnl for selecting Rust build profiles
|
|
||||||
AC_SUBST(YJIT_SUPPORT)dnl what flavor of YJIT the Ruby build includes
|
|
||||||
@@ -4855,6 +4862,7 @@ config_summary "strip command" "$STRIP"
|
|
||||||
config_summary "install doc" "$DOCTARGETS"
|
|
||||||
config_summary "YJIT support" "$YJIT_SUPPORT"
|
|
||||||
config_summary "ZJIT support" "$ZJIT_SUPPORT"
|
|
||||||
+config_summary "RUSTC_FLAGS" "$RUSTC_FLAGS"
|
|
||||||
config_summary "man page type" "$MANTYPE"
|
|
||||||
config_summary "search path" "$search_path"
|
|
||||||
config_summary "static-linked-ext" ${EXTSTATIC:+"yes"}
|
|
||||||
diff --git a/defs/jit.mk b/defs/jit.mk
|
|
||||||
index 42b56c4cd9..27b14e7a07 100644
|
|
||||||
--- a/defs/jit.mk
|
|
||||||
+++ b/defs/jit.mk
|
|
||||||
@@ -40,6 +40,7 @@ else ifneq ($(strip $(RLIB_DIR)),) # combo build
|
|
||||||
$(RUST_LIB): $(srcdir)/ruby.rs
|
|
||||||
$(ECHO) 'building $(@F)'
|
|
||||||
$(gnumake_recursive)$(Q) $(RUSTC) --edition=2024 \
|
|
||||||
+ $(RUSTC_FLAGS) \
|
|
||||||
'-L$(@D)' \
|
|
||||||
--extern=yjit \
|
|
||||||
--extern=zjit \
|
|
||||||
@@ -58,6 +59,7 @@ $(JIT_RLIB):
|
|
||||||
$(gnumake_recursive)$(Q) $(RUSTC) --crate-name=jit \
|
|
||||||
--edition=2024 \
|
|
||||||
$(JIT_RUST_FLAGS) \
|
|
||||||
+ $(RUSTC_FLAGS) \
|
|
||||||
'--out-dir=$(@D)' \
|
|
||||||
'$(top_srcdir)/jit/src/lib.rs'
|
|
||||||
endif # ifneq ($(JIT_CARGO_SUPPORT),no)
|
|
||||||
diff --git a/template/Makefile.in b/template/Makefile.in
|
|
||||||
index 443c394cb4..0b7b50e3aa 100644
|
|
||||||
--- a/template/Makefile.in
|
|
||||||
+++ b/template/Makefile.in
|
|
||||||
@@ -115,6 +115,7 @@ CARGO_TARGET_DIR=@abs_top_builddir@/target
|
|
||||||
CARGO_BUILD_ARGS=@CARGO_BUILD_ARGS@
|
|
||||||
ZJIT_TEST_FEATURES=@ZJIT_TEST_FEATURES@
|
|
||||||
JIT_RUST_FLAGS=@JIT_RUST_FLAGS@
|
|
||||||
+RUSTC_FLAGS=@RUSTC_FLAGS@
|
|
||||||
RLIB_DIR=@RLIB_DIR@
|
|
||||||
RUST_LIB=@RUST_LIB@
|
|
||||||
RUST_LIBOBJ = $(RUST_LIB:.a=.@OBJEXT@)
|
|
||||||
|
|
@ -1,59 +0,0 @@
|
||||||
# Keep matching patterns enough not to hide unintended errors and warnings.
|
|
||||||
|
|
||||||
# There is no way to implement this with `%{SOURCE0}` without `%{_sourcedir}`.
|
|
||||||
# The order in the .spec file could be possibly different.
|
|
||||||
addFilter(r'ruby\.(spec|src):20: E: use-of-RPM_SOURCE_DIR$')
|
|
||||||
|
|
||||||
# The used version is not obvious.
|
|
||||||
addFilter(r'ruby\.(spec|src):\d+: W: unversioned-explicit-provides bundled\(ccan-build_assert\)$')
|
|
||||||
addFilter(r'ruby\.(spec|src):\d+: W: unversioned-explicit-provides bundled\(ccan-check_type\)$')
|
|
||||||
addFilter(r'ruby\.(spec|src):\d+: W: unversioned-explicit-provides bundled\(ccan-container_of\)$')
|
|
||||||
addFilter(r'ruby\.(spec|src):\d+: W: unversioned-explicit-provides bundled\(ccan-list\)$')
|
|
||||||
|
|
||||||
# The template files do not have to have executable bits.
|
|
||||||
addFilter(r'^rubygem-bundler\.noarch: E: non-executable-script /usr/share/gems/gems/bundler-[\d\.]+/lib/bundler/templates/[\w/\.]+ 644 /usr/bin/env ')
|
|
||||||
|
|
||||||
# Samples don't really need executable bits.
|
|
||||||
addFilter(r'^rubygem-bigdecimal\.x86_64: E: non-executable-script /usr/share/gems/gems/bigdecimal-[\d\.]+/sample/\w+.rb 644 /usr/local/bin/ruby$')
|
|
||||||
|
|
||||||
# The bundled gem files permissions are overridden as 644 by `make install`.
|
|
||||||
# https://bugs.ruby-lang.org/issues/17840
|
|
||||||
# https://github.com/rubygems/rubygems/issues/5255
|
|
||||||
addFilter(r'^.*: E: non-executable-script /usr/share/gems/gems/(abbrev|getoptlong|nkf|observer|resolv|resolv-replace|rinda|syslog)-[\d\.]+/bin/\w+ 644 ')
|
|
||||||
|
|
||||||
# Ruby provides API to set the cipher list.
|
|
||||||
addFilter(r'^ruby-libs\.\w+: W: crypto-policy-non-compliance-openssl /usr/lib(64)?/ruby/openssl.so SSL_CTX_set_cipher_list$')
|
|
||||||
|
|
||||||
# `gethostbyname` is part of deprecated Ruby API. There is also request to drop the API altogether:
|
|
||||||
# https://bugs.ruby-lang.org/issues/13097
|
|
||||||
# https://bugs.ruby-lang.org/issues/17944
|
|
||||||
addFilter(r'^ruby-libs\.\w+: W: binary-or-shlib-calls-gethostbyname /usr/lib(64)?/ruby/socket.so$')
|
|
||||||
|
|
||||||
# Rake ships some examples.
|
|
||||||
addFilter(r'^rubygem-rake.noarch: W: devel-file-in-non-devel-package /usr/share/gems/gems/rake-[\d\.]+/doc/example/\w+.c$')
|
|
||||||
|
|
||||||
# Some executables don't have their manual pages. Is it worth of use help2man?
|
|
||||||
addFilter(r'^.+: W: no-manual-page-for-binary (bundler|gem|racc|rbs|rdbg|rdoc|ruby-mri|syntax_suggest|typeprof)$')
|
|
||||||
|
|
||||||
# Default gems does not come with any documentation.
|
|
||||||
addFilter(r'^rubygem-(bigdecimal|io-console|json|psych)\.\w+: W: no-documentation$')
|
|
||||||
|
|
||||||
# rubygems-devel ships only RPM macros and generators. Their placement is given
|
|
||||||
# by RPM and can't be modified.
|
|
||||||
addFilter(r'rubygems-devel.noarch: W: only-non-binary-in-usr-lib$')
|
|
||||||
|
|
||||||
# Ignore some spelling false positives.
|
|
||||||
# Ignore spelling of technical terms
|
|
||||||
addFilter(r'^ruby-default-gems.noarch: E: spelling-error \(\'gemspec\'')
|
|
||||||
addFilter(r'^ruby-libs.x86_64: E: spelling-error \(\'libruby\'')
|
|
||||||
addFilter(r'^rubygem-test-unit.noarch: E: spelling-error \(\'xUnit\'')
|
|
||||||
addFilter(r'^rubygem-psych.x86_64: E: spelling-error \(\'libyaml\'')
|
|
||||||
addFilter(r'^rubygem-io-console.x86_64: E: spelling-error \(\'readline\'')
|
|
||||||
# `pyaml` is part of URL
|
|
||||||
addFilter(r'^rubygem-psych.x86_64: E: spelling-error \(\'pyyaml\'')
|
|
||||||
# `de-` is actually prefix
|
|
||||||
addFilter(r'^rubygem-psych.x86_64: E: spelling-error \(\'de\'')
|
|
||||||
|
|
||||||
# It does not seemt to be worth of changing rubygems to archful package due to
|
|
||||||
# single directory, unless it causes some real troubles.
|
|
||||||
addFilter(r'^rubygems.noarch: E: noarch-with-lib64$')
|
|
||||||
|
|
@ -1,6 +1,5 @@
|
||||||
%__rubygems_requires %{_rpmconfigdir}/rubygems.req
|
%__rubygems_requires %{_rpmconfigdir}/rubygems.req
|
||||||
%__rubygems_provides %{_rpmconfigdir}/rubygems.prov
|
%__rubygems_provides %{_rpmconfigdir}/rubygems.prov
|
||||||
%__rubygems_conflicts %{_rpmconfigdir}/rubygems.con
|
|
||||||
# In non-gem packages, the %%{gem_name} macro is not available and the macro
|
# In non-gem packages, the %%{gem_name} macro is not available and the macro
|
||||||
# stays unexpanded which leads to "invalid regex" error (rhbz#1154067).
|
# stays unexpanded which leads to "invalid regex" error (rhbz#1154067).
|
||||||
%__rubygems_path ^%{?gem_name:%{gem_spec}}%{!?gem_name:this_should_never_match_anything}$
|
%__rubygems_path ^%{?gem_name:%{gem_spec}}%{!?gem_name:this_should_never_match_anything}$
|
||||||
|
|
|
||||||
52
rubygems.con
52
rubygems.con
|
|
@ -1,52 +0,0 @@
|
||||||
#!/usr/bin/ruby
|
|
||||||
|
|
||||||
require 'rubygems/package'
|
|
||||||
|
|
||||||
module RubyGemsReq
|
|
||||||
module Helpers
|
|
||||||
# Keep only '!=' requirements.
|
|
||||||
def self.conflicts(requirements)
|
|
||||||
conflicts = requirements.select {|r| r.first == '!='}
|
|
||||||
end
|
|
||||||
|
|
||||||
# Converts Gem::Requirement into array of requirements strings compatible
|
|
||||||
# with RPM .spec file.
|
|
||||||
def self.requirement_versions_to_rpm(requirement)
|
|
||||||
self.conflicts(requirement.requirements).map do |op, version|
|
|
||||||
version == Gem::Version.new(0) ? "" : "= #{version}"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Report conflicting gem dependencies including their version.
|
|
||||||
def self.gem_dependencies(specification)
|
|
||||||
specification.runtime_dependencies.each do |dependency|
|
|
||||||
conflict_strings = Helpers::requirement_versions_to_rpm(dependency.requirement).map do |requirement|
|
|
||||||
requirement_string = "rubygem(#{dependency.name}) #{requirement}"
|
|
||||||
end
|
|
||||||
if conflict_strings.length > 0
|
|
||||||
conflict_string = conflict_strings.join(' with ')
|
|
||||||
conflict_string.prepend('(').concat(')') if conflict_strings.length > 1
|
|
||||||
puts conflict_string
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Reports all conflicts specified by all provided .gemspec files.
|
|
||||||
def self.conflicts
|
|
||||||
while filename = gets
|
|
||||||
filename.strip!
|
|
||||||
begin
|
|
||||||
specification = Gem::Specification.load filename
|
|
||||||
|
|
||||||
gem_dependencies(specification)
|
|
||||||
rescue => e
|
|
||||||
# Ignore all errors.
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if __FILE__ == $0
|
|
||||||
RubyGemsReq::conflicts
|
|
||||||
end
|
|
||||||
|
|
@ -9,9 +9,9 @@ module RubyGemsProv
|
||||||
def self.normalize_prerelease(version)
|
def self.normalize_prerelease(version)
|
||||||
if version.prerelease?
|
if version.prerelease?
|
||||||
prerelease = version.version.sub /^#{version.release}\./, ''
|
prerelease = version.version.sub /^#{version.release}\./, ''
|
||||||
"#{version.release}~#{prerelease}"
|
"#{version.release}-0.1.#{prerelease}"
|
||||||
else
|
else
|
||||||
version.release
|
"#{version.release}-1"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
||||||
49
rubygems.req
49
rubygems.req
|
|
@ -11,17 +11,11 @@ module RubyGemsReq
|
||||||
when '~>'
|
when '~>'
|
||||||
expand_pessimistic_requirement(r)
|
expand_pessimistic_requirement(r)
|
||||||
when '!='
|
when '!='
|
||||||
# If there is only the conflict requirement, we still need to depend
|
expand_not_equal_requirement(r)
|
||||||
# on the specified gem.
|
|
||||||
if requirements.size == 1
|
|
||||||
Gem::Requirement.default.requirements
|
|
||||||
else
|
|
||||||
[]
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
[r]
|
[r]
|
||||||
end
|
end
|
||||||
end.reject {|r| r.empty? }
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Expands the pessimistic version operator '~>' into equivalent '>=' and
|
# Expands the pessimistic version operator '~>' into equivalent '>=' and
|
||||||
|
|
@ -31,39 +25,38 @@ module RubyGemsReq
|
||||||
return ['>=', requirement.last], ['<', next_version]
|
return ['>=', requirement.last], ['<', next_version]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Expands the not equal version operator '!=' into equivalent '<' and
|
||||||
|
# '>' pair.
|
||||||
|
def self.expand_not_equal_requirement(requirement)
|
||||||
|
return ['<', requirement.last], ['>', requirement.last]
|
||||||
|
end
|
||||||
|
|
||||||
# Converts Gem::Requirement into array of requirements strings compatible
|
# Converts Gem::Requirement into array of requirements strings compatible
|
||||||
# with RPM .spec file.
|
# with RPM .spec file.
|
||||||
def self.requirement_versions_to_rpm(requirement)
|
def self.requirement_versions_to_rpm(requirement)
|
||||||
self.expand_requirement(requirement.requirements).map do |op, version|
|
self.expand_requirement(requirement.requirements).map do |op, version|
|
||||||
version == Gem::Version.new(0) ? "" : " #{op} #{version}"
|
version == Gem::Version.new(0) ? "" : "#{op} #{version}"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Compose dependency together with its requirements in RPM rich dependency
|
|
||||||
# string.
|
|
||||||
def self.compose_dependency_string(name, requirements)
|
|
||||||
dependency_strings = requirements.map { |requirement| name + requirement }
|
|
||||||
dependency_string = dependency_strings.join(' with ')
|
|
||||||
dependency_string.prepend('(').concat(')') if dependency_strings.length > 1
|
|
||||||
dependency_string
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Report RubyGems dependency, versioned if required.
|
# Report RubyGems dependency, versioned if required.
|
||||||
def self.rubygems_dependency(specification)
|
def self.rubygems_dependency(specification)
|
||||||
dependency_name = "ruby(rubygems)"
|
Helpers::requirement_versions_to_rpm(specification.required_rubygems_version).each do |requirement|
|
||||||
requirements = Helpers::requirement_versions_to_rpm(specification.required_rubygems_version)
|
dependency_string = "ruby(rubygems)"
|
||||||
|
dependency_string += " #{specification.required_rubygems_version}" if requirement && requirement.length > 0
|
||||||
puts Helpers::compose_dependency_string(dependency_name, requirements)
|
puts dependency_string
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# Report all gem dependencies including their version.
|
# Report all gem dependencies including their version.
|
||||||
def self.gem_dependencies(specification)
|
def self.gem_depenencies(specification)
|
||||||
specification.runtime_dependencies.each do |dependency|
|
specification.runtime_dependencies.each do |dependency|
|
||||||
dependency_name = "rubygem(#{dependency.name})"
|
Helpers::requirement_versions_to_rpm(dependency.requirement).each do |requirement|
|
||||||
requirements = Helpers::requirement_versions_to_rpm(dependency.requirement)
|
dependency_string = "rubygem(#{dependency.name})"
|
||||||
|
dependency_string += " #{requirement}" if requirement && requirement.length > 0
|
||||||
puts Helpers::compose_dependency_string(dependency_name, requirements)
|
puts dependency_string
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
@ -75,7 +68,7 @@ module RubyGemsReq
|
||||||
specification = Gem::Specification.load filename
|
specification = Gem::Specification.load filename
|
||||||
|
|
||||||
rubygems_dependency(specification)
|
rubygems_dependency(specification)
|
||||||
gem_dependencies(specification)
|
gem_depenencies(specification)
|
||||||
rescue => e
|
rescue => e
|
||||||
# Ignore all errors.
|
# Ignore all errors.
|
||||||
end
|
end
|
||||||
|
|
|
||||||
2
sources
2
sources
|
|
@ -1 +1 @@
|
||||||
SHA512 (ruby-4.0.1.tar.xz) = b67d9d1f97ba30200d103f8454e39dc2d0450819d51d91eb5451d44b0bafc56d2fa48bb1be6c5081babe5828f679984bad02b9bcee7441f6bd34c0a95b8f200b
|
4b9506c37e908b5b17215b66b2760438 ruby-2.2.5.tar.xz
|
||||||
|
|
|
||||||
|
|
@ -1,34 +0,0 @@
|
||||||
require 'openssl'
|
|
||||||
|
|
||||||
# Run openssl tests in OpenSSL FIPS. See the link below for how to test.
|
|
||||||
# https://github.com/ruby/openssl/blob/master/.github/workflows/test.yml
|
|
||||||
# - step name: test on fips module
|
|
||||||
|
|
||||||
# Listing the testing files by an array explicitly rather than the `Dir.glob`
|
|
||||||
# to prevent the test files from not loading unintentionally.
|
|
||||||
TEST_FILES = %w[
|
|
||||||
test/openssl/test_fips.rb
|
|
||||||
test/openssl/test_pkey.rb
|
|
||||||
].freeze
|
|
||||||
|
|
||||||
if ARGV.empty?
|
|
||||||
puts 'ERROR: Argument base_dir required.'
|
|
||||||
puts "Usage: #{__FILE__} base_dir [options]"
|
|
||||||
exit false
|
|
||||||
end
|
|
||||||
BASE_DIR = ARGV[0]
|
|
||||||
abs_test_files = TEST_FILES.map { |file| File.join(BASE_DIR, file) }
|
|
||||||
|
|
||||||
# Set Fedora/RHEL downstream OpenSSL downstream environment variable to enable
|
|
||||||
# FIPS module in non-FIPS OS environment. It is available in Fedora 38 or later
|
|
||||||
# versions.
|
|
||||||
# https://src.fedoraproject.org/rpms/openssl/blob/rawhide/f/0009-Add-Kernel-FIPS-mode-flag-support.patch
|
|
||||||
ENV['OPENSSL_FORCE_FIPS_MODE'] = '1'
|
|
||||||
# A flag to tell the tests the current environment is FIPS enabled.
|
|
||||||
# https://github.com/ruby/openssl/blob/master/test/openssl/test_fips.rb
|
|
||||||
ENV['TEST_RUBY_OPENSSL_FIPS_ENABLED'] = 'true'
|
|
||||||
|
|
||||||
abs_test_files.each do |file|
|
|
||||||
puts "INFO: Loading #{file}."
|
|
||||||
require file
|
|
||||||
end
|
|
||||||
|
|
@ -1,124 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'test/unit'
|
|
||||||
require 'rpm_test_helper'
|
|
||||||
|
|
||||||
class TestRubyGemsCon < Test::Unit::TestCase
|
|
||||||
include RPMTestHelper
|
|
||||||
|
|
||||||
def test_filter_out_regular_requirements
|
|
||||||
gem_i = GemInfo.new
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(0, lines.size)
|
|
||||||
|
|
||||||
deps = [ Dependency.new('bar') ]
|
|
||||||
gem_i.dependencies = deps
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(0, lines.size)
|
|
||||||
|
|
||||||
deps = [
|
|
||||||
Dependency.new('bar'),
|
|
||||||
Dependency.new('baq'),
|
|
||||||
Dependency.new('quz')
|
|
||||||
]
|
|
||||||
|
|
||||||
gem_i.dependencies = deps
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(0, lines.size)
|
|
||||||
|
|
||||||
deps = [
|
|
||||||
Dependency.new('bar', ['>= 4.1']),
|
|
||||||
Dependency.new('baz', ['~> 3.2']),
|
|
||||||
Dependency.new('quz', ['>= 5.6'])
|
|
||||||
]
|
|
||||||
|
|
||||||
gem_i.dependencies = deps
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(0, lines.size)
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_single_gem_single_version_conflict
|
|
||||||
con = Dependency.new('bar', ['!= 0.4.4'])
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [ con ])
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{con.to_rpm_str} = 0.4.4\n", lines.first)
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_multiple_gems_with_single_conflict
|
|
||||||
cons = [
|
|
||||||
Dependency.new('bar', ['!= 1.1']),
|
|
||||||
Dependency.new('baq', ['!= 1.2.2']),
|
|
||||||
Dependency.new('quz', ['!= 1.3'])
|
|
||||||
]
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: cons)
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(3, lines.size)
|
|
||||||
|
|
||||||
assert_equal("#{cons[0].to_rpm_str} = 1.1\n" , lines[0])
|
|
||||||
assert_equal("#{cons[1].to_rpm_str} = 1.2.2\n", lines[1])
|
|
||||||
assert_equal("#{cons[2].to_rpm_str} = 1.3\n" , lines[2])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_multiple_conflicts_on_single_gem
|
|
||||||
con = Dependency.new('bar', ['!= 2.3', '!= 2.4'])
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [con])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
rpm_name = con.to_rpm_str
|
|
||||||
left_rpm_constraint = "(#{rpm_name} = 2.3 with "
|
|
||||||
right_rpm_constraint = "#{rpm_name} = 2.4)\n"
|
|
||||||
assert_equal((left_rpm_constraint + right_rpm_constraint), lines[0])
|
|
||||||
|
|
||||||
con = Dependency.new('bar', ['!= 2.3', '!= 2.4', '!= 4.5'])
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [ con ])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
|
|
||||||
rpm_name = con.to_rpm_str
|
|
||||||
left_rpm_constraint = "(#{rpm_name} = 2.3 with "
|
|
||||||
middle_rpm_constraint = "#{rpm_name} = 2.4 with "
|
|
||||||
right_rpm_constraint = "#{rpm_name} = 4.5)\n"
|
|
||||||
|
|
||||||
assert_equal((left_rpm_constraint + middle_rpm_constraint + right_rpm_constraint), lines[0])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_generates_conflicts_while_ignoring_regular_requirements
|
|
||||||
deps = [
|
|
||||||
Dependency.new('bar', ['>= 2.3', '!= 2.4.2']),
|
|
||||||
Dependency.new('quz', ['~> 3.0', '!= 3.2'])
|
|
||||||
]
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: deps)
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
|
|
||||||
rpm_name = deps[0].to_rpm_str
|
|
||||||
rpm_constraint = "#{rpm_name} = 2.4.2\n"
|
|
||||||
assert_equal(rpm_constraint, lines[0])
|
|
||||||
|
|
||||||
rpm_name = deps[1].to_rpm_str
|
|
||||||
rpm_constraint = "#{rpm_name} = 3.2\n"
|
|
||||||
assert_equal(rpm_constraint, lines[1])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
@ -1,52 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'test/unit'
|
|
||||||
require 'rpm_test_helper'
|
|
||||||
|
|
||||||
class TestRubyGemsProv < Test::Unit::TestCase
|
|
||||||
include RPMTestHelper
|
|
||||||
|
|
||||||
def test_provides_the_gem_version
|
|
||||||
gem_i = GemInfo.new(version: '1.2')
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{gem_i.to_rpm_str} = #{gem_i.version}\n", lines.first)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(name: 'somegem_foo', version: '4.5.6')
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{gem_i.to_rpm_str} = #{gem_i.version}\n", lines.first)
|
|
||||||
|
|
||||||
deps = [
|
|
||||||
Dependency.new('bar'),
|
|
||||||
Dependency.new('baq', [">= 1.2"]),
|
|
||||||
Dependency.new('quz', ["!= 3.2"])
|
|
||||||
]
|
|
||||||
gem_i = GemInfo.new(dependencies: deps)
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{gem_i.to_rpm_str} = #{gem_i.version}\n", lines.first)
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_translates_prelease_version_provides_from_rubygems_to_rpm
|
|
||||||
gem_i = GemInfo.new(version: '1.2.3.dev')
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{gem_i.to_rpm_str} = 1.2.3~dev\n", lines.first)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(name: 'foo2', version: '1.2.3.dev.2')
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{gem_i.to_rpm_str} = 1.2.3~dev.2\n", lines.first)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
@ -1,205 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'test/unit'
|
|
||||||
require 'rpm_test_helper'
|
|
||||||
|
|
||||||
class TestRubyGemsReq < Test::Unit::TestCase
|
|
||||||
include RPMTestHelper
|
|
||||||
|
|
||||||
def test_depends_on_rubygems
|
|
||||||
gem_i = GemInfo.new
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(1, lines.size)
|
|
||||||
assert_equal("#{helper_rubygems_dependency}\n", lines.first)
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_requires_rubygems_and_dependency
|
|
||||||
dep = Dependency.new('bar')
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{helper_rubygems_dependency}\n", lines.first)
|
|
||||||
assert_equal("#{dep.to_rpm_str}\n", lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_requires_multiple_dependencies_with_constraint
|
|
||||||
constraints = [
|
|
||||||
'>= 3.0',
|
|
||||||
'>= 3.0.0',
|
|
||||||
'>= 3',
|
|
||||||
'= 1.0.2',
|
|
||||||
'= 3.0',
|
|
||||||
'< 3.2',
|
|
||||||
'<= 3.4'
|
|
||||||
]
|
|
||||||
|
|
||||||
dependencies = []
|
|
||||||
constraints.each_with_index do |constraint, idx|
|
|
||||||
dependencies << Dependency.new("bar#{idx}", [constraint])
|
|
||||||
end
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: dependencies)
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
# + 1 for the rubygems dependency
|
|
||||||
assert_equal(constraints.size + 1, lines.size)
|
|
||||||
dependencies.each_with_index do |dep, idx|
|
|
||||||
rpm_dep_name = dep.to_rpm_str
|
|
||||||
# Start indexing lines at 1, to jump over rubygems dependency
|
|
||||||
assert_equal("#{rpm_dep_name} #{constraints[idx]}\n", lines[idx + 1])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_expands_pessimistic_constraint_for_rpm
|
|
||||||
dep = Dependency.new('bar', ['~> 1.2'])
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
|
|
||||||
rpm_dep_name = dep.to_rpm_str
|
|
||||||
left_constraint = "#{rpm_dep_name} >= 1.2"
|
|
||||||
right_constraint = "#{rpm_dep_name} < 2"
|
|
||||||
expected_constraint = "(#{left_constraint} with #{right_constraint})\n"
|
|
||||||
assert_equal(expected_constraint, lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_multiple_pessimistically_constrained_dependencies
|
|
||||||
dependencies = []
|
|
||||||
dep_map = [
|
|
||||||
{
|
|
||||||
constraint: '~> 1.2.3',
|
|
||||||
expanded_left: '>= 1.2.3',
|
|
||||||
expanded_rigth: '< 1.3',
|
|
||||||
gem_name: 'bar1'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
constraint: '~> 1.2',
|
|
||||||
expanded_left: '>= 1.2',
|
|
||||||
expanded_rigth: '< 2',
|
|
||||||
gem_name: 'bar2'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
constraint: '~> 3',
|
|
||||||
expanded_left: '>= 3',
|
|
||||||
expanded_rigth: '< 4',
|
|
||||||
gem_name: 'bar3'
|
|
||||||
}
|
|
||||||
].each do |deps|
|
|
||||||
dependencies << Dependency.new(deps[:gem_name], [deps[:constraint]])
|
|
||||||
end
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: dependencies)
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(dep_map.size + 1, lines.size)
|
|
||||||
|
|
||||||
dep_map.each_with_index do |hash, idx|
|
|
||||||
rpm_dep_name = dependencies[idx].to_rpm_str
|
|
||||||
left_constraint = rpm_dep_name + ' ' + hash[:expanded_left]
|
|
||||||
right_constraint = rpm_dep_name + ' ' + hash[:expanded_rigth]
|
|
||||||
expected_constraint = "(#{left_constraint} with #{right_constraint})\n"
|
|
||||||
assert_equal(expected_constraint, lines[idx + 1])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_multiple_constraints_on_one_dependency_composes_constraints_for_RPM
|
|
||||||
# The quoting here depends on how the constraint is expanded in the helpers.
|
|
||||||
# right now the form is `["#{constraint}"]`, therefore we have to not specify
|
|
||||||
# left and right quotes.
|
|
||||||
constraints = ['>= 0.2.3', '<= 0.2.5']
|
|
||||||
dep = Dependency.new('baz', constraints)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
rpm_dep_name = dep.to_rpm_str
|
|
||||||
assert_equal("(#{rpm_dep_name} >= 0.2.3 with #{rpm_dep_name} <= 0.2.5)\n", lines[1])
|
|
||||||
|
|
||||||
# Not sure who would compose a dependency like this, but it's possible
|
|
||||||
# to do with the current generator
|
|
||||||
constraints = ['> 0.4.5', '< 0.6.4', '>= 2.3', '<= 2.5.3']
|
|
||||||
dep = Dependency.new('qux', constraints)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
rpm_dep = dep.to_rpm_str
|
|
||||||
expected_str = "(#{rpm_dep} > 0.4.5 with #{rpm_dep} < 0.6.4 with " \
|
|
||||||
"#{rpm_dep} >= 2.3 with #{rpm_dep} <= 2.5.3)\n"
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal(expected_str, lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
# https://bugzilla.redhat.com/show_bug.cgi?id=1561487
|
|
||||||
def test_depends_on_gem_with_version_conflict
|
|
||||||
dep = Dependency.new('baz', ['!= 0.4'])
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{dep.to_rpm_str}\n", lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_filters_conflict_from_regular_version_constraints
|
|
||||||
constraint = ['> 1.2.4', '!= 1.2.7']
|
|
||||||
dep = Dependency.new('baq', constraint)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{dep.to_rpm_str} > 1.2.4\n", lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_filtering_conflicts_is_not_depending_on_contraint_ordering
|
|
||||||
constraints = ['!= 1.2.7', '> 1.2.4']
|
|
||||||
dep = Dependency.new('baq', constraints)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{dep.to_rpm_str} > 1.2.4\n", lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_filters_multiple_conflicts_from_dependency
|
|
||||||
omit "Case not yet supported."
|
|
||||||
constraints = ['!= 1.2.4', '!= 1.2.5', '!= 2.3', '!= 4.8']
|
|
||||||
dep = Dependency.new('baf', constraints)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{dep.to_rpm_str}\n", lines[1])
|
|
||||||
end
|
|
||||||
|
|
||||||
def test_filters_multiple_conflicts_from_dependency_but_keeps_regular_constraint
|
|
||||||
constraints = ['!= 1.2.4', '!= 1.2.5', '!= 2.3', '<= 4.8']
|
|
||||||
dep = Dependency.new('bam', constraints)
|
|
||||||
|
|
||||||
gem_i = GemInfo.new(dependencies: [dep])
|
|
||||||
|
|
||||||
lines = run_generator_single_file(gem_i)
|
|
||||||
|
|
||||||
assert_equal(2, lines.size)
|
|
||||||
assert_equal("#{dep.to_rpm_str} <= 4.8\n", lines[1])
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
@ -1,65 +1,9 @@
|
||||||
require 'set'
|
require 'rbconfig'
|
||||||
|
|
||||||
LIBRUBY_SO = 'libruby.so'
|
if RbConfig::CONFIG.select {|k, v| v =~ /dtrace/}.size == 1
|
||||||
PROBES_D = 'probes.d'
|
exit true
|
||||||
|
else
|
||||||
# These probes are excluded by VM_COLLECT_USAGE_DETAILS ifdef.
|
puts 'ERROR: SystemTap (dtrace) support was not detected.'
|
||||||
EXCLUDE_PROBES = Set.new %w(insn insn__operand)
|
|
||||||
|
|
||||||
## Detect SystemTap section headers presence
|
|
||||||
|
|
||||||
stap_headers = [
|
|
||||||
'\.stapsdt\.base',
|
|
||||||
'\.note\.stapsdt'
|
|
||||||
]
|
|
||||||
|
|
||||||
header_regexp = %r{ (#{stap_headers.join('|')}) }
|
|
||||||
|
|
||||||
section_headers = `readelf -S "#{LIBRUBY_SO}"`
|
|
||||||
detected_stap_headers = section_headers.scan(header_regexp).flatten
|
|
||||||
|
|
||||||
# Assume there are both headers until this is proven wrong ;)
|
|
||||||
unless detected_stap_headers.size == 2
|
|
||||||
puts 'ERROR: SystemTap (DTrace) headers were not detected in resulting library.'
|
|
||||||
exit false
|
|
||||||
end
|
|
||||||
|
|
||||||
## Find if every declared probe is propagated to resulting library
|
|
||||||
|
|
||||||
# Colect probes specified in probes.d file.
|
|
||||||
probes_declared = []
|
|
||||||
|
|
||||||
File.open(PROBES_D) do |file|
|
|
||||||
file.each_line do |line|
|
|
||||||
if probe = line[/probe (\S+)\(.*\);/, 1]
|
|
||||||
probes_declared << probe
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
probes_declared = Set.new probes_declared
|
|
||||||
|
|
||||||
unless EXCLUDE_PROBES.subset? probes_declared
|
|
||||||
puts 'ERROR: Change in SystemTap (DTrace) probes definition file detected.'
|
|
||||||
exit false
|
|
||||||
end
|
|
||||||
|
|
||||||
probes_declared -= EXCLUDE_PROBES
|
|
||||||
|
|
||||||
# Detect probes in resulting library.
|
|
||||||
get_probes_detected = %r{
|
|
||||||
^\s*Provider:\s+ruby,\s+Name:\s+(\S+),\s+.*$
|
|
||||||
}
|
|
||||||
|
|
||||||
probes_detected = `eu-readelf -n "#{LIBRUBY_SO}"`
|
|
||||||
|
|
||||||
probes_detected = Set.new probes_detected.scan(get_probes_detected).flatten
|
|
||||||
|
|
||||||
# Both sets must be equal, otherwise something is wrong.
|
|
||||||
unless probes_declared == probes_detected
|
|
||||||
puts 'ERROR: SystemTap (DTrace) probes were not correctly propagated into resulting library.'
|
|
||||||
puts " Undetected probes: #{(probes_declared - probes_detected).sort.join(', ')}\n",
|
|
||||||
" Additional detected probes: #{(probes_detected - probes_declared).sort.join(', ')}"
|
|
||||||
|
|
||||||
exit false
|
exit false
|
||||||
end
|
end
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue