Sha256: 42fad99cfad28014a42dac0face70498da802b3886f9f1e439dfb6ed3f5e589d

Contents?: true

Size: 1.07 KB

Versions: 4

Compression:

Stored size: 1.07 KB

Contents

require 'puppet-strings/yard/handlers/helpers'
require 'puppet-strings/yard/handlers/puppet/base'
require 'puppet-strings/yard/parsers'
require 'puppet-strings/yard/code_objects'

# Implements the handler for Puppet Data Type Alias.
class PuppetStrings::Yard::Handlers::Puppet::DataTypeAliasHandler < PuppetStrings::Yard::Handlers::Puppet::Base
  handles PuppetStrings::Yard::Parsers::Puppet::DataTypeAliasStatement

  process do
    # Register the object
    object = PuppetStrings::Yard::CodeObjects::DataTypeAlias.new(statement)
    register object

    # Log a warning if missing documentation
    log.warn "Missing documentation for Puppet type alias '#{object.name}' at #{statement.file}:#{statement.line}." if object.docstring.empty? && object.tags.empty?

    # Mark the class as public if it doesn't already have an api tag
    object.add_tag YARD::Tags::Tag.new(:api, 'public') unless object.has_tag? :api

    # Warn if a summary longer than 140 characters was provided
    PuppetStrings::Yard::Handlers::Helpers.validate_summary_tag(object) if object.has_tag? :summary
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
puppet-strings-2.5.0 lib/puppet-strings/yard/handlers/puppet/data_type_alias_handler.rb
puppet-strings-2.4.0 lib/puppet-strings/yard/handlers/puppet/data_type_alias_handler.rb
puppet-strings-2.3.1 lib/puppet-strings/yard/handlers/puppet/data_type_alias_handler.rb
puppet-strings-2.3.0 lib/puppet-strings/yard/handlers/puppet/data_type_alias_handler.rb