libdatadog 6.0.0.1.0-aarch64-linux → 6.0.0.2.0-aarch64-linux

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 04d2e4dc428ca9caac821533262e9739cfda14722ee6153e4ad719ddb94b80ab
4
- data.tar.gz: 391ea5cc716642528242034e5dee0edf9442ddc272f553ee24cb2063c6b5ca07
3
+ metadata.gz: 9bb5d8eb96095010b0a119da538d13a04e6292c98b4da5aaf5d317bda8cbde40
4
+ data.tar.gz: aa7393b410cc17492b1b2c70857345e6891405dc76d6e4ab6acfbcf87411e070
5
5
  SHA512:
6
- metadata.gz: fdaa10eb5d53245dc1302343290672578c3d600fdd6dfc6e48bfc8afbc82a5d231ac091a22033e612b7dc9835ea0348b1d465690b0ec3822523446135a4b7e16
7
- data.tar.gz: 146613891ce562c83692f2c9dde2bc6698e50b92693895ed56719babbc4a9ce983054530655f28511b61bd9296500527c480e3627ed84738d5482c6704648d73
6
+ metadata.gz: 800dbe84ce259c657c66a107241fa6e32f035334acb00ef24ee23139f27746ab7493aa9cea0aa6cbcb80a2a4c0b8656532a4c4002415b2570879fa08999c66be
7
+ data.tar.gz: 6ae87e41654aa73e896f4833c14fc37dab779d88c3e199ab099b1d6ec6610e7793c542f7ab9e0ada6903e44fad288469c0288fbad6e933eec2fb29734e30e2cd
@@ -4,7 +4,7 @@ module Libdatadog
4
4
  # Current libdatadog version
5
5
  LIB_VERSION = "6.0.0"
6
6
 
7
- GEM_MAJOR_VERSION = "1"
7
+ GEM_MAJOR_VERSION = "2"
8
8
  GEM_MINOR_VERSION = "0"
9
9
  GEM_PRERELEASE_VERSION = "" # remember to include dot prefix, if needed!
10
10
  private_constant :GEM_MAJOR_VERSION, :GEM_MINOR_VERSION, :GEM_PRERELEASE_VERSION
data/lib/libdatadog.rb CHANGED
@@ -9,24 +9,7 @@ module Libdatadog
9
9
  end
10
10
 
11
11
  def self.pkgconfig_folder(pkgconfig_file_name = "datadog_profiling_with_rpath.pc")
12
- current_platform = Gem::Platform.local.to_s
13
-
14
- if RbConfig::CONFIG["arch"].include?("-musl") && !current_platform.include?("-musl")
15
- # Fix/workaround for https://github.com/DataDog/dd-trace-rb/issues/2222
16
- #
17
- # Old versions of rubygems (for instance 3.0.3) don't properly detect alternative libc implementations on Linux;
18
- # in particular for our case, they don't detect musl. (For reference, Rubies older than 2.7 may have shipped with
19
- # an affected version of rubygems).
20
- # In such cases, we fall back to use RbConfig::CONFIG['arch'] instead.
21
- #
22
- # Why not use RbConfig::CONFIG['arch'] always? Because Gem::Platform.local.to_s does some normalization we want
23
- # in other situations -- for instance, it turns `x86_64-linux-gnu` to `x86_64-linux`. So for now we only add this
24
- # workaround in a specific situation where we actually know it is wrong.
25
- #
26
- # See also https://github.com/rubygems/rubygems/pull/2922 and https://github.com/rubygems/rubygems/pull/4082
27
-
28
- current_platform = RbConfig::CONFIG["arch"]
29
- end
12
+ current_platform = self.current_platform
30
13
 
31
14
  return unless available_binaries.include?(current_platform)
32
15
 
@@ -40,4 +23,37 @@ module Libdatadog
40
23
  private_class_method def self.vendor_directory
41
24
  ENV["LIBDATADOG_VENDOR_OVERRIDE"] || "#{__dir__}/../vendor/libdatadog-#{Libdatadog::LIB_VERSION}/"
42
25
  end
26
+
27
+ def self.current_platform
28
+ platform = Gem::Platform.local.to_s
29
+
30
+ if platform.end_with?("-gnu")
31
+ # In some cases on Linux with glibc the platform includes a -gnu suffix. We normalize it to not have the suffix.
32
+ #
33
+ # Note: This should be platform = platform.delete_suffix("-gnu") but it doesn't work on legacy Rubies; once
34
+ # dd-trace-rb 2.0 is out we can simplify this.
35
+ #
36
+ platform = platform[0..-5]
37
+ end
38
+
39
+ if RbConfig::CONFIG["arch"].include?("-musl") && !platform.include?("-musl")
40
+ # Fix/workaround for https://github.com/datadog/dd-trace-rb/issues/2222
41
+ #
42
+ # Old versions of rubygems (for instance 3.0.3) don't properly detect alternative libc implementations on Linux;
43
+ # in particular for our case, they don't detect musl. (For reference, Rubies older than 2.7 may have shipped with
44
+ # an affected version of rubygems).
45
+ # In such cases, we fall back to use RbConfig::CONFIG['arch'] instead.
46
+ #
47
+ # Why not use RbConfig::CONFIG['arch'] always? Because Gem::Platform.local.to_s does some normalization that seemed
48
+ # useful in the past, although part of it got removed in https://github.com/rubygems/rubygems/pull/5852.
49
+ # For now we only add this workaround in a specific situation where we actually know it is wrong, but in the
50
+ # future it may be worth re-evaluating if we should move away from `Gem::Platform` altogether.
51
+ #
52
+ # See also https://github.com/rubygems/rubygems/pull/2922 and https://github.com/rubygems/rubygems/pull/4082
53
+
54
+ RbConfig::CONFIG["arch"]
55
+ else
56
+ platform
57
+ end
58
+ end
43
59
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: libdatadog
3
3
  version: !ruby/object:Gem::Version
4
- version: 6.0.0.1.0
4
+ version: 6.0.0.2.0
5
5
  platform: aarch64-linux
6
6
  authors:
7
7
  - Datadog, Inc.
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-02-12 00:00:00.000000000 Z
11
+ date: 2024-03-04 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: libdatadog is a Rust-based utility library for Datadog's ddtrace gem.
14
14
  email: