Class: YARD::Server::LibraryVersion
- Inherits:
-
Object
- Object
- YARD::Server::LibraryVersion
- Defined in:
- lib/yard/server/library_version.rb
Overview
A library version encapsulates a library’s documentation at a specific version. Although the version is optional, this allows for creating multiple documentation points for a specific library, each representing a unique version. The term “library” used in other parts of the YARD::Server documentation refers to objects of this class unless otherwise noted.
A library points to a location where a #yardoc_file is located so that its documentation may be loaded and served. Optionally, a #source_path is given to point to a location where any extra files (and .yardopts) should be loaded from. Both of these methods may not be known immediately, since the yardoc file may not be built until later. Resolving the yardoc file and source path are dependent on the specific library “source type” used. Source types (known as “library source”) are discussed in detail below.
Using with Adapters
A list of libraries need to be passed into adapters upon creation. In most cases, you will never do this manually, but if you use a RackMiddleware, you will need to pass in this list yourself. To build this list of libraries, you should create a hash of library names mapped to an Array of LibraryVersion objects. For example:
{'mylib' => [LibraryVersion.new('mylib', '1.0', ...),
LibraryVersion.new('mylib', '2.0', ...)]}
Note that you can also use Adapter#add_library for convenience.
The “array” part is required, even for just one library version.
Library Sources
The #source method represents the library source type, ie. where the library “comes from”. It might come from “disk”, or it might come from a “gem” (technically the disk, but a separate type nonetheless). In these two cases, the yardoc file sits somewhere on your filesystem, though it may also be built dynamically if it does not yet exist. This behaviour is controlled through the #prepare! method, which prepares the yardoc file given a specific library source. We will see how this works in detail in the following section.
Implementing a Custom Library Source
YARD can be extended to support custom library sources in order to build or retrieve a yardoc file at runtime from many different locations.
To implement this behaviour, 3 methods can be added to the LibraryVersion
class, #load_yardoc_from_SOURCE
, #yardoc_file_for_SOURCE
, and #source_path_for_SOURCE
. In all cases, “SOURCE” represents the source type used in #source when creating the library object. The #yardoc_file_for_SOURCE
and #source_path_for_SOURCE
methods are called upon creation and should return the location where the source code for the library lives. The load method is called from #prepare! if there is no yardoc file and should set #yardoc_file. Below is a full example for implementing a custom library source, :http
, which reads packaged .yardoc databases from zipped archives off of an HTTP server.
Note that only #load_yardoc_from_SOURCE
is required. The other two methods are optional and can be set manually (via #source_path= and #yardoc_file=) on the object at any time.
Constant Summary collapse
- @@chdir_mutex =
Mutex.new
Instance Attribute Summary collapse
-
#name ⇒ String
The name of the library.
-
#source ⇒ Symbol
The source type representing where the yardoc should be loaded from.
- #source_path ⇒ String?
-
#version ⇒ String
The version of the specific library.
- #yardoc_file ⇒ String?
Instance Method Summary collapse
-
#eql?(other) ⇒ Boolean
(also: #==, #equal?)
Whether another LibraryVersion is equal to this one.
- #gemspec ⇒ Gem::Specification?
-
#hash ⇒ Fixnum
Used for Hash mapping.
-
#initialize(name, version = nil, yardoc = nil, source = :disk) ⇒ LibraryVersion
constructor
A new instance of LibraryVersion.
-
#load_yardoc_from_disk ⇒ Object
protected
Called when a library of source type “disk” is to be prepared.
-
#load_yardoc_from_gem ⇒ Object
protected
Called when a library of source type “gem” is to be prepared.
-
#prepare! ⇒ Object
Prepares a library to be displayed by the server.
-
#ready? ⇒ Boolean
Whether the library has been completely processed and is ready to be served.
-
#source_path_for_disk ⇒ String
protected
The source path for a disk source.
-
#source_path_for_gem ⇒ String
protected
The source path for a gem source.
-
#to_s(url_format = true) ⇒ String
The string representation of the library.
-
#yardoc_file_for_gem ⇒ String
protected
The yardoc file for a gem source.
Constructor Details
#initialize(name, version = nil, yardoc = nil, source = :disk) ⇒ LibraryVersion
Returns a new instance of LibraryVersion.
134 135 136 137 138 139 |
# File 'lib/yard/server/library_version.rb', line 134 def initialize(name, version = nil, yardoc = nil, source = :disk) self.name = name self.yardoc_file = yardoc self.version = version self.source = source end |
Instance Attribute Details
#name ⇒ String
Returns the name of the library.
96 97 98 |
# File 'lib/yard/server/library_version.rb', line 96 def name @name end |
#source ⇒ Symbol
Returns the source type representing where the yardoc should be loaded from. Defaults are :disk
and :gem
, though custom sources may be implemented. This value is used to inform #prepare! about how to load the necessary data in order to display documentation for an object.
116 117 118 |
# File 'lib/yard/server/library_version.rb', line 116 def source @source end |
#source_path ⇒ String?
122 123 124 |
# File 'lib/yard/server/library_version.rb', line 122 def source_path @source_path ||= load_source_path end |
#version ⇒ String
Returns the version of the specific library.
99 100 101 |
# File 'lib/yard/server/library_version.rb', line 99 def version @version end |
#yardoc_file ⇒ String?
To implement a custom yardoc file getter, implement
106 107 108 |
# File 'lib/yard/server/library_version.rb', line 106 def yardoc_file @yardoc_file ||= load_yardoc_file end |
Instance Method Details
#eql?(other) ⇒ Boolean Also known as: ==, equal?
Returns whether another LibraryVersion is equal to this one.
153 154 155 156 |
# File 'lib/yard/server/library_version.rb', line 153 def eql?(other) other.is_a?(LibraryVersion) && other.name == name && other.version == version && other.yardoc_file == yardoc_file end |
#gemspec ⇒ Gem::Specification?
191 192 193 194 |
# File 'lib/yard/server/library_version.rb', line 191 def gemspec ver = version ? "= #{version}" : ">= 0" YARD::GemIndex.find_all_by_name(name, ver).last end |
#hash ⇒ Fixnum
Returns used for Hash mapping.
150 |
# File 'lib/yard/server/library_version.rb', line 150 def hash; to_s.hash end |
#load_yardoc_from_disk ⇒ Object (protected)
Called when a library of source type “disk” is to be prepared. In this case, the #yardoc_file should already be set, but the library may not be prepared. Run preparation if not done.
206 207 208 209 210 211 212 213 214 215 216 217 218 |
# File 'lib/yard/server/library_version.rb', line 206 def load_yardoc_from_disk return if ready? @@chdir_mutex.synchronize do Dir.chdir(source_path_for_disk) do Thread.new do CLI::Yardoc.run('--no-stats', '-n', '-b', yardoc_file) end end end raise LibraryNotPreparedError end |
#load_yardoc_from_gem ⇒ Object (protected)
Called when a library of source type “gem” is to be prepared. In this case, the #yardoc_file needs to point to the correct location for the installed gem. The yardoc file is built if it has not been done.
226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 |
# File 'lib/yard/server/library_version.rb', line 226 def load_yardoc_from_gem return if ready? ver = version ? "= #{version}" : ">= 0" @@chdir_mutex.synchronize do Thread.new do # Build gem docs on demand log.debug "Building gem docs for #{to_s(false)}" CLI::Gems.run(name, ver) log.debug "Done building gem docs for #{to_s(false)}" end end raise LibraryNotPreparedError end |
#prepare! ⇒ Object
You should not directly override this method. Instead, implement load_yardoc_from_SOURCENAME
when implementing loading for a specific source type. See the YARD::Server::LibraryVersion documentation for “Implementing a Custom Library Source”
Prepares a library to be displayed by the server. This callback is performed before each request on a library to ensure that it is loaded and ready to be viewed. If any steps need to be performed prior to loading, they are performed through this method (though they should be implemented through the load_yardoc_from_SOURCE
method).
182 183 184 185 186 |
# File 'lib/yard/server/library_version.rb', line 182 def prepare! return if ready? meth = "load_yardoc_from_#{source}" send(meth) if respond_to?(meth, true) end |
#ready? ⇒ Boolean
Returns whether the library has been completely processed and is ready to be served.
162 163 164 165 |
# File 'lib/yard/server/library_version.rb', line 162 def ready? return false if yardoc_file.nil? serializer.complete? end |
#source_path_for_disk ⇒ String (protected)
Returns the source path for a disk source.
243 244 245 |
# File 'lib/yard/server/library_version.rb', line 243 def source_path_for_disk File.dirname(yardoc_file) if yardoc_file end |
#source_path_for_gem ⇒ String (protected)
Returns the source path for a gem source.
248 249 250 |
# File 'lib/yard/server/library_version.rb', line 248 def source_path_for_gem gemspec.full_gem_path if gemspec end |
#to_s(url_format = true) ⇒ String
Returns the string representation of the library.
145 146 147 |
# File 'lib/yard/server/library_version.rb', line 145 def to_s(url_format = true) version ? "#{name}#{url_format ? '/' : '-'}#{version}" : name.to_s end |
#yardoc_file_for_gem ⇒ String (protected)
Returns the yardoc file for a gem source.
253 254 255 256 257 |
# File 'lib/yard/server/library_version.rb', line 253 def yardoc_file_for_gem require 'rubygems' ver = version ? "= #{version}" : ">= 0" Registry.yardoc_file_for_gem(name, ver) end |