Sha256: 7b56ca41e3b48b82c03e1d3d165bd269f275b82928613474e11003d4262db7b4
Contents?: true
Size: 1.89 KB
Versions: 1
Compression:
Stored size: 1.89 KB
Contents
# encoding: utf-8 module Yardstick # Base class of every rule # # @abstract class Rule extend Forwardable class << self # Description of the rule # # This is shown when a rule is invalid # # @return [String] # # @api private attr_accessor :description private :description= end # Register rule in Document # # @param [Class] subclass # class that is inheriting from this class # # @return [undefined] # # @api private def self.inherited(subclass) Document.register_rule(subclass) end private_class_method :inherited # Makes a new instance of rule using given config # # @param [Yardstick::Document] document # document that will be measured # @param [Yardstick::Config] config # a configuration # # @return [Yardstick::Rule] # # @api private def self.coerce(document, config) new(document, config.for_rule(self)) end # Return document that current rule is using # # @return [Document] # # @api private attr_reader :document # Initializes a rule # # @param [Yardstick::Document] document # @param [Yardstick::RuleConfig] config # rule configuration # # @return [Yardstick::Rule] # # @api private def initialize(document, config = RuleConfig.new) @document = document @config = config end def_delegators :@document, :has_tag?, :api?, :tag_types, :tag_text, :summary_text, :visibility # Checks if rule is enabled in current context # # @return [Boolean] # true if enabled # # @api private def enabled? @config.enabled_for_path?(@document.path) end # Checks if the rule is validatable for given document # # @return [Boolean] # # @api private def validatable? true end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
yardstick-0.9.7 | lib/yardstick/rule.rb |