class Geocoder::Logger

def current_logger

def current_logger
  logger = Geocoder.config[:logger]
  if logger == :kernel
    logger = Geocoder::KernelLogger.instance
  end
  logger
end

def log(level, message)

def log(level, message)
  unless valid_level?(level)
    raise StandardError, "Geocoder tried to log a message with an invalid log level."
  end
  if current_logger.respond_to? :add
    current_logger.add(SEVERITY[level], message)
  else
    raise Geocoder::ConfigurationError, "Please specify valid logger for Geocoder. " +
    "Logger specified must be :kernel or must respond to `add(level, message)`."
  end
  nil
end

def valid_level?(level)

def valid_level?(level)
  SEVERITY.keys.include?(level)
end