Class: CFA::BaseModel
- Inherits:
-
Object
- Object
- CFA::BaseModel
- Defined in:
- lib/cfa/base_model.rb
Overview
A base class for models. Represents a configuration file as an object with domain-specific attributes/methods. For persistent storage, use load and save, Non-responsibilities: actual storage and parsing (both delegated). There is no caching involved.
Instance Method Summary collapse
-
#generic_get(key) ⇒ Object
powerfull method that gets unformatted any value in config.
-
#generic_set(key, value) ⇒ Object
powerfull method that sets any value in config.
-
#initialize(parser, file_path, file_handler: File) ⇒ BaseModel
constructor
A new instance of BaseModel.
- #load ⇒ Object
-
#loaded? ⇒ Boolean
rubocop:disable Style/TrivialAccessors Returns if configuration was already loaded.
- #save(changes_only: false) ⇒ Object
Constructor Details
#initialize(parser, file_path, file_handler: File) ⇒ BaseModel
Returns a new instance of BaseModel.
16 17 18 19 20 21 22 |
# File 'lib/cfa/base_model.rb', line 16 def initialize(parser, file_path, file_handler: File) @file_handler = file_handler @parser = parser @file_path = file_path @loaded = false self.data = parser.empty end |
Instance Method Details
#generic_get(key) ⇒ Object
prefer to use specialized methods of children
powerfull method that gets unformatted any value in config.
44 45 46 |
# File 'lib/cfa/base_model.rb', line 44 def generic_get(key) data[key] end |
#generic_set(key, value) ⇒ Object
prefer to use specialized methods of children
powerfull method that sets any value in config. It try to be smart to at first modify existing value, then replace commented out code and if even that doesn’t work, then append it at the end
38 39 40 |
# File 'lib/cfa/base_model.rb', line 38 def generic_set(key, value) modify(key, value) || uncomment(key, value) || add_new(key, value) end |
#load ⇒ Object
29 30 31 32 |
# File 'lib/cfa/base_model.rb', line 29 def load self.data = @parser.parse(@file_handler.read(@file_path)) @loaded = true end |
#loaded? ⇒ Boolean
rubocop:disable Style/TrivialAccessors Returns if configuration was already loaded
50 51 52 |
# File 'lib/cfa/base_model.rb', line 50 def loaded? @loaded end |
#save(changes_only: false) ⇒ Object
24 25 26 27 |
# File 'lib/cfa/base_model.rb', line 24 def save(changes_only: false) merge_changes if changes_only @file_handler.write(@file_path, @parser.serialize(data)) end |