Skip to content

Commit

Permalink
(PA-5430) Patch augeas C extension
Browse files Browse the repository at this point in the history
This issue is very similar to PA-4844 (puppetlabs#620) except it affects augeas instead of selinux

When puppet is run with Ruby 3.2, this warning is generated:
`/opt/puppetlabs/puppet/lib/ruby/vendor_ruby/augeas.rb:48: warning: undefining the allocator of T_DATA class Augeas`

This commit patches the autogenerated augeas C extension so there is no warning for augeas
  • Loading branch information
AriaXLi committed May 15, 2023
1 parent 5d99782 commit b23e114
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 0 deletions.
5 changes: 5 additions & 0 deletions configs/components/_base-ruby-augeas.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
# load it with instance_eval. See ruby-x.y-augeas.rb configs.
#

pkg.add_source("file://resources/patches/augeas/ruby-augeas-0.5.0-patch_c_extension.patch")

# These can be overridden by the including component.
ruby_version ||= settings[:ruby_version]
host_ruby ||= settings[:host_ruby]
Expand Down Expand Up @@ -74,6 +76,9 @@
build_commands = []
build_commands << "#{ruby} ext/augeas/extconf.rb"
build_commands << "#{platform[:make]} -e -j$(shell expr $(shell #{platform[:num_cores]}) + 1)"
if ruby_version =~ /^3/
build_commands << "#{platform.patch} --strip=2 --fuzz=0 --ignore-whitespace --no-backup-if-mismatch < ../ruby-augeas-0.5.0-patch_c_extension.patch"
end

build_commands
end
Expand Down
12 changes: 12 additions & 0 deletions resources/patches/augeas/ruby-augeas-0.5.0-patch_c_extension.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
diff --git a/ruby-augeas-0.5.0/ext/augeas/_augeas.c b/ruby-augeas-0.5.0/ext/augeas/_augeas.c
index 95d9e05024..7aac0eb96d 100644
--- a/ruby-augeas-0.5.0/ext/augeas/_augeas.c
+++ b/ruby-augeas-0.5.0/ext/augeas/_augeas.c
@@ -489,6 +489,7 @@ void Init__augeas() {

/* Define the ruby class */
c_augeas = rb_define_class("Augeas", rb_cObject) ;
+ rb_undef_alloc_func(c_augeas);

/* Constants for enum aug_flags */
#define DEF_AUG_FLAG(name) \

0 comments on commit b23e114

Please sign in to comment.