Class: Schron::LoggedRepository
- Inherits:
-
Object
- Object
- Schron::LoggedRepository
- Defined in:
- lib/schron/logged_repository.rb
Instance Method Summary collapse
-
#initialize(repo, logger: nil, log_level: :info, exclude_regexp: nil, include_regexp: nil) ⇒ LoggedRepository
constructor
A new instance of LoggedRepository.
- #method_missing(method_name, *args, &block) ⇒ Object
- #respond_to_missing?(method_name, include_private = false) ⇒ Boolean
Constructor Details
#initialize(repo, logger: nil, log_level: :info, exclude_regexp: nil, include_regexp: nil) ⇒ LoggedRepository
Returns a new instance of LoggedRepository.
8 9 10 11 12 13 14 15 16 17 18 |
# File 'lib/schron/logged_repository.rb', line 8 def initialize(repo, logger: nil, log_level: :info, exclude_regexp: nil, include_regexp: nil) @repo = repo @logger = logger || Logger.new(STDOUT) @log_level = log_level @exclude = exclude_regexp @include = include_regexp end |
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
20 21 22 23 24 25 26 27 28 |
# File 'lib/schron/logged_repository.rb', line 20 def method_missing(method_name, *args, &block) if @repo.respond_to?(method_name) log(method_name, *args) do @repo.__send__(method_name, *args, &block) end else super end end |
Instance Method Details
#respond_to_missing?(method_name, include_private = false) ⇒ Boolean
30 31 32 |
# File 'lib/schron/logged_repository.rb', line 30 def respond_to_missing?(method_name, include_private=false) @repo.respond_to?(method_name, include_private) end |