Sha256: 90630b1431b2a23d6fa1fdaaa6ebe5a78de77fa3fd152fec34bf2986bdfff6a2

Contents?: true

Size: 1.8 KB

Versions: 2

Compression:

Stored size: 1.8 KB

Contents

module Lookbook
  class ParamTag < YardTag
    VALUE_TYPE_MATCHER = /^(\[\s?([A-Z]{1}\w+)\s?\])/
    DESCRIPTION_MATCHER = /(?<=\s|^)"(.*?[^\\])"(?:\s|$)/

    supports_options

    attr_reader :tag_args

    def initialize(text)
      @name, text_without_name = extract_name(text)
      @tag_args = parse_tag_body(text_without_name)
      super("param", tag_args[:rest], nil, @name)
    end

    def input
      tag_args[:input]&.downcase&.tr("_", "-")
    end

    def description
      tag_args[:description]
    end

    def value_type
      tag_args[:value_type]&.downcase
    end

    def value_default
      default_value_parts = object.parameters.find { |parts| parts[0].chomp(":") == name }
      if default_value_parts
        host_class_instance.instance_eval(default_value_parts[1])
      else
        raise ParserError.new "Unknown method parameter '#{name}'"
      end
    end

    protected

    def extract_name(text)
      parts = text.to_s.split(" ")
      [parts.shift, parts.join(" ")]
    end

    def parse_tag_body(text)
      value_type = nil
      description = nil

      # Parse out YARD-style value type definition - i.e. [Boolean]
      text.match(VALUE_TYPE_MATCHER) do |match_data|
        value_type = match_data[2]
        text.gsub!(VALUE_TYPE_MATCHER, "").strip!
      end

      # Parse and remove any options from string
      text_with_options = text
      _, text = parse_options(text)
      options_str = text_with_options.sub(text, "")

      # Parse description, if provided
      text.match(DESCRIPTION_MATCHER) do |match_data|
        description = match_data[1]
        text.sub!(DESCRIPTION_MATCHER, "").strip!
      end

      input, rest = text.split(" ", 2)

      {input: input, value_type: value_type, description: description, rest: [rest, options_str].compact.join(" ")}
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
lookbook-2.0.2 lib/lookbook/tags/param_tag.rb
lookbook-2.0.1 lib/lookbook/tags/param_tag.rb