Class: Qonfig::Commands::Definition::LoadFromJSON Private

Inherits:
Base
  • Object
show all
Defined in:
lib/qonfig/commands/definition/load_from_json.rb

Overview

This class is part of a private API. You should avoid using this class if possible, as it may be removed or be changed in the future.

Since:

  • 0.5.0

Version:

  • 0.29.0

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods inherited from Base

inheritable=, inheritable?, #inheritable?, inherited

Constructor Details

#initialize(file_path, strict: true, replace_on_merge: false) ⇒ LoadFromJSON

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of LoadFromJSON.

Parameters:

  • file_path (String, Pathname)
  • strict (Hash) (defaults to: true)

    a customizable set of options

  • replace_on_merge (Hash) (defaults to: false)

    a customizable set of options

Options Hash (strict:):

  • (Boolean)

Options Hash (replace_on_merge:):

  • (Boolean)

Since:

  • 0.5.0

Version:

  • 0.29.0



35
36
37
38
39
# File 'lib/qonfig/commands/definition/load_from_json.rb', line 35

def initialize(file_path, strict: true, replace_on_merge: false)
  @file_path = file_path
  @strict = strict
  @replace_on_merge = replace_on_merge
end

Instance Attribute Details

#file_pathString, Pathname (readonly)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (String, Pathname)

Since:

  • 0.5.0



14
15
16
# File 'lib/qonfig/commands/definition/load_from_json.rb', line 14

def file_path
  @file_path
end

#replace_on_mergeBoolean (readonly)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Boolean)

Since:

  • 0.29.0



26
27
28
# File 'lib/qonfig/commands/definition/load_from_json.rb', line 26

def replace_on_merge
  @replace_on_merge
end

#strictBoolean (readonly)

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns:

  • (Boolean)

Since:

  • 0.5.0



20
21
22
# File 'lib/qonfig/commands/definition/load_from_json.rb', line 20

def strict
  @strict
end

Instance Method Details

#call(data_set, settings) ⇒ void

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

This method returns an undefined value.

Parameters:

Raises:

Since:

  • 0.5.0

Version:

  • 0.29.0



48
49
50
51
52
53
54
55
56
57
58
# File 'lib/qonfig/commands/definition/load_from_json.rb', line 48

def call(data_set, settings)
  json_data = Qonfig::Loaders::JSON.load_file(file_path, fail_on_unexist: strict)

  raise(
    Qonfig::IncompatibleJSONStructureError,
    'JSON object must be a hash-like structure'
  ) unless json_data.is_a?(Hash)

  json_based_settings = build_data_set_klass(json_data).new.settings
  settings.__append_settings__(json_based_settings, with_redefinition: replace_on_merge)
end