From 7814eeaf3c0a0468e931791a6966f676a8ea8f31 Mon Sep 17 00:00:00 2001 From: Ian Kronquist Date: Wed, 16 Sep 2015 15:14:03 -0700 Subject: [PATCH] (PDOC-54) Providers & Types w/same name conflict If a provider and a type with the same name conflict strings will overwrite the documentation of one of them with the other. That is if both a provider and a type are named apt_key, strings will write the type to doc/apt_key.html and the provider to doc/apt_key.html. The fix is to write the provider to doc/apt_key_provider.html and the type to doc/apt_key_type.html. --- .../puppetlabs/strings/yard/handlers/provider_handler.rb | 3 ++- .../puppetlabs/strings/yard/handlers/type_handler.rb | 3 ++- .../strings/yard/templates/default/fulldoc/html/setup.rb | 8 +++++++- .../strings/yard/templates/default/provider/setup.rb | 6 ++++++ .../strings/yard/templates/default/type/setup.rb | 6 ++++++ .../puppet_x/puppetlabs/strings/yard/type_handler_spec.rb | 2 +- 6 files changed, 24 insertions(+), 4 deletions(-) diff --git a/lib/puppet_x/puppetlabs/strings/yard/handlers/provider_handler.rb b/lib/puppet_x/puppetlabs/strings/yard/handlers/provider_handler.rb index f4654a6..bd2cc22 100644 --- a/lib/puppet_x/puppetlabs/strings/yard/handlers/provider_handler.rb +++ b/lib/puppet_x/puppetlabs/strings/yard/handlers/provider_handler.rb @@ -26,7 +26,7 @@ class PuppetX::PuppetLabs::Strings::YARD::Handlers::PuppetProviderHandler < YARD provider_name = statement[i+1].jump(:ident).source type_name = statement.jump(:symbol).first.source - obj = ProviderObject.new(:root, provider_name) + obj = ProviderObject.new(:root, "#{provider_name}_provider") docstring = nil features = [] @@ -83,6 +83,7 @@ class PuppetX::PuppetLabs::Strings::YARD::Handlers::PuppetProviderHandler < YARD obj.confines = confines obj.defaults = defaults obj.type_name = type_name + obj.header_name = provider_name register_docstring(obj, docstring, nil) register obj diff --git a/lib/puppet_x/puppetlabs/strings/yard/handlers/type_handler.rb b/lib/puppet_x/puppetlabs/strings/yard/handlers/type_handler.rb index 06c7d34..ffc1409 100644 --- a/lib/puppet_x/puppetlabs/strings/yard/handlers/type_handler.rb +++ b/lib/puppet_x/puppetlabs/strings/yard/handlers/type_handler.rb @@ -78,7 +78,7 @@ class PuppetX::PuppetLabs::Strings::YARD::Handlers::PuppetTypeHandler < YARD::Ha parameter_details = [] property_details = [] features = [] - obj = TypeObject.new(:root, name) do |o| + obj = TypeObject.new(:root, "#{name}_type") do |o| # FIXME: This block gets yielded twice for whatever reason parameter_details = [] property_details = [] @@ -137,6 +137,7 @@ class PuppetX::PuppetLabs::Strings::YARD::Handlers::PuppetTypeHandler < YARD::Ha obj.parameter_details = parameter_details obj.property_details = property_details obj.features = features + obj.header_name = name register obj # Register docstring after the object. If the object already has a diff --git a/lib/puppet_x/puppetlabs/strings/yard/templates/default/fulldoc/html/setup.rb b/lib/puppet_x/puppetlabs/strings/yard/templates/default/fulldoc/html/setup.rb index 2788460..7ab0dfe 100644 --- a/lib/puppet_x/puppetlabs/strings/yard/templates/default/fulldoc/html/setup.rb +++ b/lib/puppet_x/puppetlabs/strings/yard/templates/default/fulldoc/html/setup.rb @@ -59,7 +59,13 @@ def namespace_list(opts = {}) end children.reject {|c| c.nil? }.sort_by {|child| child.path }.map do |child| if namespace_types.include? child.type - name = child.namespace.is_a?(CodeObjects::Proxy) ? child.path : child.name + if child.namespace.is_a?(CodeObjects::Proxy) + name = child.path + elsif child.is_a?(PuppetX::PuppetLabs::Strings::YARD::CodeObjects::TypeObject) || child.is_a?(PuppetX::PuppetLabs::Strings::YARD::CodeObjects::ProviderObject) + name = child.header_name + else + name = child.name + end has_children = child.respond_to?(:children) && run_verifier(child.children).any? {|o| o.is_a?(CodeObjects::NamespaceObject) } out << "
  • " out << " " if has_children diff --git a/lib/puppet_x/puppetlabs/strings/yard/templates/default/provider/setup.rb b/lib/puppet_x/puppetlabs/strings/yard/templates/default/provider/setup.rb index f9cf10c..8acd72d 100644 --- a/lib/puppet_x/puppetlabs/strings/yard/templates/default/provider/setup.rb +++ b/lib/puppet_x/puppetlabs/strings/yard/templates/default/provider/setup.rb @@ -10,6 +10,12 @@ def init @html_helper = HTMLHelper.new end +def header + @header_text = object.header_name + + erb(:header) +end + def command_details @command_details = object.commands erb(:command_details) diff --git a/lib/puppet_x/puppetlabs/strings/yard/templates/default/type/setup.rb b/lib/puppet_x/puppetlabs/strings/yard/templates/default/type/setup.rb index f9736b5..016e269 100644 --- a/lib/puppet_x/puppetlabs/strings/yard/templates/default/type/setup.rb +++ b/lib/puppet_x/puppetlabs/strings/yard/templates/default/type/setup.rb @@ -10,6 +10,12 @@ def init @html_helper = HTMLHelper.new end +def header + @header_text = object.header_name + + erb(:header) +end + def provider_details type_name = object.name.to_s @providers = YARD::Registry.all(:provider).select { |t| t.type_name == type_name } diff --git a/spec/unit/puppet_x/puppetlabs/strings/yard/type_handler_spec.rb b/spec/unit/puppet_x/puppetlabs/strings/yard/type_handler_spec.rb index 338ce5c..7c12f54 100644 --- a/spec/unit/puppet_x/puppetlabs/strings/yard/type_handler_spec.rb +++ b/spec/unit/puppet_x/puppetlabs/strings/yard/type_handler_spec.rb @@ -7,7 +7,7 @@ describe PuppetX::PuppetLabs::Strings::YARD::Handlers::PuppetTypeHandler do include StringsSpec::Parsing def the_type() - YARD::Registry.at("file") + YARD::Registry.at("file_type") end it "should have the proper docstring" do