Module: YARD::Templates::Template::ClassMethods
- Included in:
- YARD::Templates::Template
- Defined in:
- lib/yard/templates/template.rb
Instance Attribute Summary collapse
-
#full_path ⇒ Object
Returns the value of attribute full_path.
-
#path ⇒ Object
Returns the value of attribute path.
Instance Method Summary collapse
-
#find_file(basename) ⇒ String
Searches for a file identified by
basename
in the template’s path as well as any mixed in template paths. -
#find_nth_file(basename, index = 1) ⇒ String
Searches for the nth file (where n =
index
) identified by basename in the template’s path and any mixed in template paths. -
#full_paths ⇒ Array<String>
A list of full paths.
- #initialize(path, full_paths) ⇒ Object
- #is_a?(klass) ⇒ Boolean
-
#new(*args) ⇒ Object
Creates a new template object to be rendered with #run.
-
#reset_full_paths ⇒ Object
Resets cache for #full_paths.
- #run(*args) ⇒ Object
-
#S(*args) ⇒ Object
Alias for creating a Section with arguments.
- #T(*path) ⇒ Object
Instance Attribute Details
#full_path ⇒ Object
Returns the value of attribute full_path.
59 60 61 |
# File 'lib/yard/templates/template.rb', line 59 def full_path @full_path end |
#path ⇒ Object
Returns the value of attribute path.
59 60 61 |
# File 'lib/yard/templates/template.rb', line 59 def path @path end |
Instance Method Details
#find_file(basename) ⇒ String
Searches for a file identified by basename
in the template’s path as well as any mixed in template paths. Equivalent to calling #find_nth_file with index of 1.
97 98 99 |
# File 'lib/yard/templates/template.rb', line 97 def find_file(basename) find_nth_file(basename) end |
#find_nth_file(basename, index = 1) ⇒ String
Searches for the nth file (where n = index
) identified by basename in the template’s path and any mixed in template paths.
108 109 110 111 112 113 114 115 116 117 118 119 |
# File 'lib/yard/templates/template.rb', line 108 def find_nth_file(basename, index = 1) n = 1 full_paths.each do |path| file = File.join(path, basename) if File.file?(file) return file if index == n n += 1 end end nil end |
#full_paths ⇒ Array<String>
This method caches path results. Paths should not be modified after this method is called; call #reset_full_paths to reset cache.
Returns a list of full paths.
64 65 66 67 68 69 70 71 72 73 |
# File 'lib/yard/templates/template.rb', line 64 def full_paths reset_full_paths unless defined? @cached_included_modules return @full_paths if included_modules == @cached_included_modules @cached_included_modules = included_modules @full_paths = included_modules.inject([full_path]) do |paths, mod| paths |= mod.full_paths if mod.respond_to?(:full_paths) paths end end |
#initialize(path, full_paths) ⇒ Object
80 81 82 83 84 85 86 87 |
# File 'lib/yard/templates/template.rb', line 80 def initialize(path, full_paths) full_path = full_paths.shift self.path = path self.full_path = full_path include_inherited(full_paths) include_parent load_setup_rb end |
#is_a?(klass) ⇒ Boolean
121 122 123 124 |
# File 'lib/yard/templates/template.rb', line 121 def is_a?(klass) return true if klass == Template super(klass) end |
#new(*args) ⇒ Object
Creates a new template object to be rendered with YARD::Templates::Template#run
127 128 129 130 131 132 |
# File 'lib/yard/templates/template.rb', line 127 def new(*args) obj = Object.new.extend(self) obj.class = self obj.send(:initialize, *args) obj end |
#reset_full_paths ⇒ Object
Resets cache for #full_paths
76 77 78 |
# File 'lib/yard/templates/template.rb', line 76 def reset_full_paths @cached_included_modules = nil end |
#run(*args) ⇒ Object
134 135 136 |
# File 'lib/yard/templates/template.rb', line 134 def run(*args) new(*args).run end |