Class: YARD::Handlers::Ruby::Legacy::MixinHandler
| Relationships & Source Files | |
| Extension / Inclusion / Inheritance Descendants | |
|
Subclasses:
|
|
| Super Chains via Extension / Inclusion / Inheritance | |
|
Class Chain:
self,
Base,
::YARD::Handlers::Base
|
|
|
Instance Chain:
|
|
| Inherits: |
YARD::Handlers::Ruby::Legacy::Base
|
| Defined in: | lib/yard/handlers/ruby/legacy/mixin_handler.rb |
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
::YARD::Parser::Ruby::Legacy::RubyToken - Included
EXPR_ARG, EXPR_BEG, EXPR_CLASS, EXPR_DOT, EXPR_END, EXPR_FNAME, EXPR_MID, NEWLINE_TOKEN, TkReading2Token, TkSymbol2Token, TokenDefinitions
Class Attribute Summary
::YARD::Handlers::Base - Inherited
| .namespace_only | Declares that the handler should only be called when inside a |
| .namespace_only? | |
Class Method Summary
Base - Inherited
::YARD::Handlers::Base - Inherited
| .clear_subclasses | Clear all registered subclasses. |
| .handlers, | |
| .handles | Declares the statement type which will be processed by this handler. |
| .handles? | This class is implemented by |
| .in_file | Declares that a handler should only be called when inside a filename by its basename or a regex match for the full path. |
| .inherited, .matches_file?, .new, | |
| .process | Generates a #process method, equivalent to +def process; ... |
| .subclasses | Returns all registered handler subclasses. |
Instance Attribute Summary
::YARD::Handlers::Base - Inherited
| #extra_state | Share state across different handlers inside of a file. |
| #globals |
|
| #namespace, #namespace=, #owner, #owner=, #parser, #scope, #scope=, #statement, #visibility, #visibility= | |
Instance Method Summary
-
#process ⇒ void
Main processing callback.
- #process_mixin(mixin) private
Base - Inherited
| #call_params, #caller_method, | |
| #parse_block | Parses a statement's block with a set of state values. |
| #extract_method_details | Extracts method information for macro expansion only. |
| #tokval | The string value of a token. |
| #tokval_list | Returns a list of symbols or string values from a statement. |
::YARD::Parser::Ruby::Legacy::RubyToken - Included
::YARD::Handlers::Base - Inherited
| #abort! | Aborts a handler by raising |
| #call_params, #caller_method, | |
| #ensure_loaded! | Ensures that a specific |
| #parse_block | Parses the semantic "block" contained in the statement node. |
| #process | The main handler method called by the parser on a statement that matches the |
| #push_state | Executes a given block with specific state values for |
| #register | Do some post processing on a list of code objects. |
| #register_docstring | Registers any docstring found for the object and expands macros. |
| #register_dynamic | Registers the object as dynamic if the object is defined inside a method or block (owner != namespace). |
| #register_ensure_loaded | Ensures that the object's namespace is loaded before attaching it to the namespace. |
| #register_file_info | Registers the file/line of the declaration with the object. |
| #register_group | Registers the object as being inside a specific group. |
| #register_module_function | Registers the same method information on the module function, if the object was defined as a module function. |
| #register_source, | |
| #register_transitive_tags | Registers any transitive tags from the namespace on the object. |
| #register_visibility | Registers visibility on a method object. |
Constructor Details
This class inherits a constructor from YARD::Handlers::Base
Instance Method Details
#process ⇒ void
This method returns an undefined value.
Main processing callback
# File 'lib/yard/handlers/ruby/legacy/mixin_handler.rb', line 7
process do errors = [] statement.tokens[1..-1].to_s.split(/\s*,\s*/).reverse.each do |mixin| mixin = mixin.strip begin process_mixin(mixin) rescue YARD::Parser::UndocumentableError => err errors << err. end end unless errors.empty? msg = errors.size == 1 ? ": #{errors[0]}" : "s: #{errors.join(", ")}" raise YARD::Parser::UndocumentableError, "mixin#{msg} for class #{namespace.path}" end end
#process_mixin(mixin) (private)
# File 'lib/yard/handlers/ruby/legacy/mixin_handler.rb', line 26
def process_mixin(mixin) mixmatch = mixin[/\A(#{NAMESPACEMATCH})/, 1] raise YARD::Parser::UndocumentableError unless mixmatch case obj = Proxy.new(namespace, mixmatch) when ConstantObject # If a constant is included, use its value as the real object obj = Proxy.new(namespace, obj.value, :module) else obj = Proxy.new(namespace, mixmatch, :module) end namespace.mixins(scope).unshift(obj) unless namespace.mixins(scope).include?(obj) end