Module: Datadog::Tracing::Distributed::Helpers
- Defined in:
- lib/datadog/tracing/distributed/helpers.rb
Overview
Helpers module provides common helper functions for distributed tracing data
Class Method Summary collapse
-
.clamp_sampling_priority(sampling_priority) ⇒ Object
Base provides common methods for distributed helper classes.
- .parse_decimal_id(value) ⇒ Object
- .parse_hex_id(value) ⇒ Object
Class Method Details
.clamp_sampling_priority(sampling_priority) ⇒ Object
Base provides common methods for distributed helper classes
12 13 14 15 16 17 18 19 20 21 |
# File 'lib/datadog/tracing/distributed/helpers.rb', line 12 def self.clamp_sampling_priority(sampling_priority) # B3 doesn't have our -1 (USER_REJECT) and 2 (USER_KEEP) priorities so convert to acceptable 0/1 if sampling_priority < 0 sampling_priority = Sampling::Ext::Priority::AUTO_REJECT elsif sampling_priority > 1 sampling_priority = Sampling::Ext::Priority::AUTO_KEEP end sampling_priority end |
.parse_decimal_id(value) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/datadog/tracing/distributed/helpers.rb', line 23 def self.parse_decimal_id(value) return unless value value = value.to_s num = value.to_i # Ensure the parsed number is the same as the original string value # e.g. We want to make sure to throw away `'nan'.to_i == 0` return unless num.to_s(10) == value num end |
.parse_hex_id(value) ⇒ Object
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
# File 'lib/datadog/tracing/distributed/helpers.rb', line 37 def self.parse_hex_id(value) return unless value # Lowercase if we want to parse base16 e.g. 3E8 => 3e8 # DEV: Ruby will parse `3E8` just fine, but to test # `num.to_s(base) == value` we need to lowercase value = value.to_s.downcase # Remove any leading zeros # DEV: When we call `num.to_s(16)` later Ruby will not add leading zeros # for us so we want to make sure the comparision will work as expected # DEV: regex, remove all leading zeros up until we find the last 0 in the string # or we find the first non-zero, this allows `'0000' -> '0'` and `'00001' -> '1'` value = value.sub(/^0*(?=(0$)|[^0])/, '') # Convert value to an integer # DEV: Ruby `.to_i` will return `0` if a number could not be parsed num = value.to_i(16) # Ensure the parsed number is the same as the original string value # e.g. We want to make sure to throw away `'nan'.to_i == 0` return unless num.to_s(16) == value num end |