BinData objects are instantiated with parameters to determine their behaviour. These parameters must be sanitized to ensure their values are valid. When instantiating many objects with identical parameters, such as an array of records, there is much duplicated sanitizing.
The purpose of the sanitizing code is to eliminate the duplicated validation.
SanitizedParameters is a hash-like collection of parameters. Its purpose is to recursively sanitize the parameters of an entire BinData object chain at a single time.
Memoized constants
# File lib/bindata/sanitize.rb, line 197 def initialize(parameters, the_class, hints) parameters.each_pair { |key, value| self[key.to_sym] = value } @the_class = the_class if hints[:endian] self[:endian] ||= hints[:endian] end if hints[:search_prefix] && !hints[:search_prefix].empty? self[:search_prefix] = Array(self[:search_prefix]).concat(Array(hints[:search_prefix])) end sanitize! end
# File lib/bindata/sanitize.rb, line 188 def sanitize(parameters, the_class) if SanitizedParameters === parameters parameters else SanitizedParameters.new(parameters, the_class, {}) end end
# File lib/bindata/sanitize.rb, line 287 def create_sanitized_params(params, the_class) SanitizedParameters.new(params, the_class, hints) end
# File lib/bindata/sanitize.rb, line 215 def has_at_least_one_of?(*keys) keys.each do |key| return true if has_parameter?(key) end false end
# File lib/bindata/sanitize.rb, line 291 def hints { endian: self[:endian], search_prefix: self[:search_prefix] } end
def warn_renamed_parameter(old_key, new_key)
val = delete(old_key)
if val
self[new_key] = val
Kernel.warn ":#{old_key} has been renamed to :#{new_key} in #{@the_class}. " \
"Using :#{old_key} is now deprecated and will be removed in the future"
end
end
# File lib/bindata/sanitize.rb, line 239 def must_be_integer(*keys) keys.each do |key| if has_parameter?(key) parameter = self[key] unless Symbol === parameter || parameter.respond_to?(:arity) || parameter.respond_to?(:to_int) raise ArgumentError, "parameter '#{key}' in #{@the_class} must " "evaluate to an integer, got #{parameter.class}" end end end end
# File lib/bindata/sanitize.rb, line 253 def rename_parameter(old_key, new_key) if has_parameter?(old_key) self[new_key] = delete(old_key) end end
# File lib/bindata/sanitize.rb, line 281 def sanitize(key, &block) if needs_sanitizing?(key) self[key] = yield(self[key]) end end
# File lib/bindata/sanitize.rb, line 271 def sanitize_choices(key, &block) sanitize(key) do |obj| create_sanitized_choices(yield(obj)) end end
# File lib/bindata/sanitize.rb, line 277 def sanitize_endian(key) sanitize(key) { |endian| create_sanitized_endian(endian) } end
# File lib/bindata/sanitize.rb, line 263 def sanitize_fields(key, &block) sanitize(key) do |fields| sanitized_fields = create_sanitized_fields yield(fields, sanitized_fields) sanitized_fields end end
# File lib/bindata/sanitize.rb, line 259 def sanitize_object_prototype(key) sanitize(key) { |obj_type, obj_params| create_sanitized_object_prototype(obj_type, obj_params) } end
# File lib/bindata/sanitize.rb, line 223 def warn_replacement_parameter(bad_key, suggested_key) if has_parameter?(bad_key) Kernel.warn ":#{bad_key} is not used with #{@the_class}. " "You probably want to change this to :#{suggested_key}" end end