Module: YARD::Handlers::Ruby::StructHandlerMethods Deprecated
Relationships & Source Files | |
Extension / Inclusion / Inheritance Descendants | |
Included In:
| |
Super Chains via Extension / Inclusion / Inheritance | |
Instance Chain:
self,
::YARD::CodeObjects
|
|
Defined in: | lib/yard/handlers/ruby/struct_handler_methods.rb |
Overview
The use of @attr
tags are deprecated since 0.8.0 in favour of
the @!attribute
directive. This module should not be relied on.
Helper methods to parse @attr_* tags on a class.
Constant Summary
::YARD::CodeObjects
- Included
BUILTIN_ALL, BUILTIN_CLASSES, BUILTIN_EXCEPTIONS, BUILTIN_EXCEPTIONS_HASH, BUILTIN_MODULES, CONSTANTMATCH, CONSTANTSTART, CSEP, CSEPQ, ISEP, ISEPQ, METHODMATCH, METHODNAMEMATCH, NAMESPACEMATCH, NSEP, NSEPQ, PROXY_MATCH
Instance Method Summary
-
#add_reader_tags(klass, new_method, member) ⇒ String
Creates the auto-generated docstring for the getter method of a struct's member.
-
#add_writer_tags(klass, new_method, member) ⇒ String
Creates the auto-generated docstring for the setter method of a struct's member.
-
#create_attributes(klass, members)
Creates the given member methods and attaches them to the given ClassObject.
-
#create_class(classname, superclass) ⇒ ClassObject
Creates and registers a class object with the given name and superclass name.
-
#create_member_method?(klass, member, type = :read) ⇒ Boolean
Determines whether to create an attribute method based on the class's tags.
-
#create_reader(klass, member)
Creates the getter (reader) method and attaches it to the class as an attribute.
-
#create_writer(klass, member)
Creates the setter (writer) method and attaches it to the class as an attribute.
-
#member_tag_for_member(klass, member, type = :read) ⇒ Tags::Tag?
Extracts the user's defined @member tag for a given class and its member.
-
#members_from_tags(klass) ⇒ Array<String>
Retrieves all members defined in @attr* tags.
-
#return_type_from_tag(member_tag) ⇒ String
Gets the return type for the member in a nicely formatted string.
Instance Method Details
#add_reader_tags(klass, new_method, member) ⇒ String
Creates the auto-generated docstring for the getter method of a struct's member. This is used so the generated documentation will look just like that of an attribute defined using attr_accessor.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 62
def (klass, new_method, member) member_tag = member_tag_for_member(klass, member, :read) return_type = return_type_from_tag(member_tag) getter_doc_text = member_tag ? member_tag.text : "Returns the value of attribute #{member}" new_method.docstring.replace(getter_doc_text) new_method.add_tag YARD::Tags::Tag.new(:return, "the current value of #{member}", return_type) end
#add_writer_tags(klass, new_method, member) ⇒ String
Creates the auto-generated docstring for the setter method of a struct's member. This is used so the generated documentation will look just like that of an attribute defined using attr_accessor.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 77
def (klass, new_method, member) member_tag = member_tag_for_member(klass, member, :write) return_type = return_type_from_tag(member_tag) setter_doc_text = member_tag ? member_tag.text : "Sets the attribute #{member}" new_method.docstring.replace(setter_doc_text) new_method.add_tag YARD::Tags::Tag.new(:param, "the value to set the attribute #{member} to.", return_type, "value") new_method.add_tag YARD::Tags::Tag.new(:return, "the newly set value", return_type) end
#create_attributes(klass, members)
Creates the given member methods and attaches them to the given ClassObject.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 134
def create_attributes(klass, members) # For each parameter, add reader and writers members.each do |member| next if klass.attributes[:instance][member] klass.attributes[:instance][member] = SymbolHash[:read => nil, :write => nil] create_writer klass, member if create_member_method?(klass, member, :write) create_reader klass, member if create_member_method?(klass, member, :read) end end
#create_class(classname, superclass) ⇒ ClassObject
Creates and registers a class object with the given name and superclass name. Returns it for further use.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 92
def create_class(classname, superclass) register ClassObject.new(namespace, classname) do |o| o.superclass = superclass if superclass o.superclass.type = :class if o.superclass.is_a?(Proxy) end end
#create_member_method?(klass, member, type = :read) ⇒ Boolean
Determines whether to create an attribute method based on the class's tags.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 38
def create_member_method?(klass, member, type = :read) return true if (klass. (:attr) + klass. (:attr_reader) + klass. (:attr_writer)).empty? return true if member_tag_for_member(klass, member, type) return !member_tag_for_member(klass, member, :write) if type == :read !member_tag_for_member(klass, member, :read) end
#create_reader(klass, member)
Creates the getter (reader) method and attaches it to the class as an attribute. Also sets up the docstring to prettify the documentation output.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 121
def create_reader(klass, member) new_meth = register MethodObject.new(klass, member, :instance) do |o| o.signature ||= "def #{member}" o.source ||= "#{o.signature}\n @#{member}\nend" end (klass, new_meth, member) klass.attributes[:instance][member][:read] = new_meth end
#create_writer(klass, member)
Creates the setter (writer) method and attaches it to the class as an attribute. Also sets up the docstring to prettify the documentation output.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 104
def create_writer(klass, member) # We want to convert these members into attributes just like # as if they were declared using attr_accessor. new_meth = register MethodObject.new(klass, "#{member}=", :instance) do |o| o.parameters = [['value', nil]] o.signature ||= "def #{member}=(value)" o.source ||= "#{o.signature}\n @#{member} = value\nend" end (klass, new_meth, member) klass.attributes[:instance][member][:write] = new_meth end
#member_tag_for_member(klass, member, type = :read) ⇒ Tags::Tag?
Extracts the user's defined @member tag for a given class and its member. Returns nil if the user did not define a @member tag for this struct entry.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 17
def member_tag_for_member(klass, member, type = :read) specific_tag = type == :read ? :attr_reader : :attr_writer (klass. (specific_tag) + klass. (:attr)).find {|tag| tag.name == member } end
#members_from_tags(klass) ⇒ Array<String>
Retrieves all members defined in @attr* tags
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 26
def (klass) = klass. (:attr) + klass. (:attr_reader) + klass. (:attr_writer) .map(&:name).uniq end
#return_type_from_tag(member_tag) ⇒ String
Gets the return type for the member in a nicely formatted string. Used to be injected into auto-generated docstrings.
# File 'lib/yard/handlers/ruby/struct_handler_methods.rb', line 51
def return_type_from_tag(member_tag) member_tag && member_tag.types ? member_tag.types : "Object" end