distil 0.11.6 → 0.11.8
Sign up to get free protection for your applications and to get access to all the features.
- data/VERSION +1 -1
- data/assets/distil.js +2 -1
- data/bin/distil +2 -0
- data/distil.gemspec +152 -2
- data/lib/distil/configurable.rb +3 -1
- data/lib/distil/error-reporter.rb +2 -0
- data/lib/distil/product/concatenated.rb +1 -3
- data/lib/distil/product/debug.rb +1 -3
- data/lib/distil/product/javascript-product.rb +2 -8
- data/lib/distil/product.rb +5 -5
- data/lib/distil/project/distil-project.rb +18 -1
- data/lib/distil/project/external-project.rb +1 -1
- data/lib/distil/project/remote-project.rb +39 -0
- data/lib/distil/project.rb +18 -9
- data/lib/distil/target.rb +13 -12
- data/lib/distil/task/css-dependency-task.rb +1 -1
- data/lib/distil/task/validate-js-task.rb +6 -1
- data/lib/distil.rb +1 -0
- data/vendor/pdoc/LICENSE +16 -0
- data/vendor/pdoc/PDoc.tmbundle/Commands/Continue PDoc Comment.tmCommand +39 -0
- data/vendor/pdoc/PDoc.tmbundle/Macros/Collapse PDoc Blocks.tmMacro +4084 -0
- data/vendor/pdoc/PDoc.tmbundle/Macros/Expand PDoc Blocks.tmMacro +1388 -0
- data/vendor/pdoc/PDoc.tmbundle/Preferences/PDoc.tmPreferences +50 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/class.tmSnippet +24 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/constant.tmSnippet +22 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/event.tmSnippet +16 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/method.tmSnippet +22 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/mixin.tmSnippet +23 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/namespace.tmSnippet +24 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/param.tmSnippet +16 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/property.tmSnippet +22 -0
- data/vendor/pdoc/PDoc.tmbundle/Snippets/section.tmSnippet +23 -0
- data/vendor/pdoc/PDoc.tmbundle/Syntaxes/PDoc.tmLanguage +33 -0
- data/vendor/pdoc/PDoc.tmbundle/info.plist +22 -0
- data/vendor/pdoc/README.markdown +34 -0
- data/vendor/pdoc/Rakefile +46 -0
- data/vendor/pdoc/bin/pdoc +58 -0
- data/vendor/pdoc/lib/pdoc/error.rb +4 -0
- data/vendor/pdoc/lib/pdoc/generators/abstract_generator.rb +16 -0
- data/vendor/pdoc/lib/pdoc/generators/html/helpers.rb +256 -0
- data/vendor/pdoc/lib/pdoc/generators/html/page.rb +71 -0
- data/vendor/pdoc/lib/pdoc/generators/html/syntax_highlighter.rb +41 -0
- data/vendor/pdoc/lib/pdoc/generators/html/template.rb +37 -0
- data/vendor/pdoc/lib/pdoc/generators/html/website.rb +194 -0
- data/vendor/pdoc/lib/pdoc/generators/html.rb +8 -0
- data/vendor/pdoc/lib/pdoc/generators/json.rb +15 -0
- data/vendor/pdoc/lib/pdoc/generators/pythonesque.rb +105 -0
- data/vendor/pdoc/lib/pdoc/generators.rb +6 -0
- data/vendor/pdoc/lib/pdoc/models/argument.rb +37 -0
- data/vendor/pdoc/lib/pdoc/models/base.rb +107 -0
- data/vendor/pdoc/lib/pdoc/models/callable.rb +19 -0
- data/vendor/pdoc/lib/pdoc/models/class.rb +28 -0
- data/vendor/pdoc/lib/pdoc/models/class_method.rb +18 -0
- data/vendor/pdoc/lib/pdoc/models/class_property.rb +9 -0
- data/vendor/pdoc/lib/pdoc/models/constant.rb +9 -0
- data/vendor/pdoc/lib/pdoc/models/constructor.rb +14 -0
- data/vendor/pdoc/lib/pdoc/models/container.rb +114 -0
- data/vendor/pdoc/lib/pdoc/models/entity.rb +54 -0
- data/vendor/pdoc/lib/pdoc/models/instance_method.rb +18 -0
- data/vendor/pdoc/lib/pdoc/models/instance_property.rb +9 -0
- data/vendor/pdoc/lib/pdoc/models/mixin.rb +10 -0
- data/vendor/pdoc/lib/pdoc/models/namespace.rb +10 -0
- data/vendor/pdoc/lib/pdoc/models/root.rb +27 -0
- data/vendor/pdoc/lib/pdoc/models/section.rb +19 -0
- data/vendor/pdoc/lib/pdoc/models/signature.rb +27 -0
- data/vendor/pdoc/lib/pdoc/models/utility.rb +11 -0
- data/vendor/pdoc/lib/pdoc/models.rb +47 -0
- data/vendor/pdoc/lib/pdoc/parser/argument_description_nodes.rb +21 -0
- data/vendor/pdoc/lib/pdoc/parser/basic_nodes.rb +31 -0
- data/vendor/pdoc/lib/pdoc/parser/description_nodes.rb +42 -0
- data/vendor/pdoc/lib/pdoc/parser/documentation_nodes.rb +483 -0
- data/vendor/pdoc/lib/pdoc/parser/ebnf_arguments_nodes.rb +58 -0
- data/vendor/pdoc/lib/pdoc/parser/ebnf_expression_nodes.rb +227 -0
- data/vendor/pdoc/lib/pdoc/parser/fragment.rb +55 -0
- data/vendor/pdoc/lib/pdoc/parser/section_content_nodes.rb +19 -0
- data/vendor/pdoc/lib/pdoc/parser/tags_nodes.rb +14 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/argument_description.treetop +31 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/basic.treetop +41 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/description.treetop +7 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/documentation.treetop +75 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_arguments.treetop +33 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_expression.treetop +70 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_javascript.treetop +54 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/events.treetop +17 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/section_content.treetop +8 -0
- data/vendor/pdoc/lib/pdoc/parser/treetop_files/tags.treetop +31 -0
- data/vendor/pdoc/lib/pdoc/parser.rb +109 -0
- data/vendor/pdoc/lib/pdoc/runner.rb +110 -0
- data/vendor/pdoc/lib/pdoc/treemaker.rb +94 -0
- data/vendor/pdoc/lib/pdoc.rb +32 -0
- data/vendor/pdoc/pdoc-0.2.0.gem +0 -0
- data/vendor/pdoc/pdoc.gemspec +31 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/alias.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/class.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/class_deprecated.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/class_method.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/class_property.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/constant.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/constructor.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/deprecated.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/description.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/information.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/instance_method.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/instance_property.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/method.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/method_deprecated.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/mixin.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/namespace.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/property.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/related_to.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/search-background.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/section-background.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/section.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/selected-section-background.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/subclass.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/superclass.png +0 -0
- data/vendor/pdoc/templates/html/assets/images/pdoc/utility.png +0 -0
- data/vendor/pdoc/templates/html/assets/javascripts/pdoc/application.js +478 -0
- data/vendor/pdoc/templates/html/assets/javascripts/pdoc/prototype.js +4874 -0
- data/vendor/pdoc/templates/html/assets/javascripts/pdoc/tabs.js +506 -0
- data/vendor/pdoc/templates/html/assets/stylesheets/pdoc/api.css +677 -0
- data/vendor/pdoc/templates/html/assets/stylesheets/pdoc/pygments.css +62 -0
- data/vendor/pdoc/templates/html/helpers.rb +35 -0
- data/vendor/pdoc/templates/html/index.erb +18 -0
- data/vendor/pdoc/templates/html/item_index.js.erb +6 -0
- data/vendor/pdoc/templates/html/layout.erb +67 -0
- data/vendor/pdoc/templates/html/leaf.erb +22 -0
- data/vendor/pdoc/templates/html/node.erb +30 -0
- data/vendor/pdoc/templates/html/partials/class_relationships.erb +19 -0
- data/vendor/pdoc/templates/html/partials/classes.erb +7 -0
- data/vendor/pdoc/templates/html/partials/constructor.erb +5 -0
- data/vendor/pdoc/templates/html/partials/description.erb +5 -0
- data/vendor/pdoc/templates/html/partials/link_list.erb +1 -0
- data/vendor/pdoc/templates/html/partials/method_signatures.erb +14 -0
- data/vendor/pdoc/templates/html/partials/methodized_note.erb +9 -0
- data/vendor/pdoc/templates/html/partials/mixins.erb +7 -0
- data/vendor/pdoc/templates/html/partials/namespaces.erb +7 -0
- data/vendor/pdoc/templates/html/partials/related_utilities.erb +5 -0
- data/vendor/pdoc/templates/html/partials/relationships.erb +11 -0
- data/vendor/pdoc/templates/html/partials/short_description_list.erb +7 -0
- data/vendor/pdoc/templates/html/partials/title.erb +22 -0
- data/vendor/pdoc/templates/html/section.erb +18 -0
- data/vendor/pdoc/test/fixtures/ajax.js +809 -0
- data/vendor/pdoc/test/fixtures/prototype.js +5789 -0
- data/vendor/pdoc/test/fixtures/test.txt +1 -0
- data/vendor/pdoc/test/fixtures/text.txt +13 -0
- data/vendor/pdoc/test/unit/parser/argument_description_test.rb +40 -0
- data/vendor/pdoc/test/unit/parser/basic_test.rb +55 -0
- data/vendor/pdoc/test/unit/parser/description_test.rb +34 -0
- data/vendor/pdoc/test/unit/parser/documentation_test.rb +520 -0
- data/vendor/pdoc/test/unit/parser/ebnf_arguments_test.rb +81 -0
- data/vendor/pdoc/test/unit/parser/ebnf_expression_test.rb +382 -0
- data/vendor/pdoc/test/unit/parser/ebnf_javascript_test.rb +37 -0
- data/vendor/pdoc/test/unit/parser/events_test.rb +27 -0
- data/vendor/pdoc/test/unit/parser/section_content_test.rb +44 -0
- data/vendor/pdoc/test/unit/parser/tags_test.rb +39 -0
- data/vendor/pdoc/test/unit/parser/test_fragment.rb +80 -0
- data/vendor/pdoc/test/unit/parser_test_helper.rb +62 -0
- data/vendor/pdoc/test/unit/runner/basic_test.rb +14 -0
- data/vendor/pdoc/test/unit/templates/html_helpers_test.rb +25 -0
- data/vendor/pdoc/vendor/albino.rb +122 -0
- data/vendor/pdoc/website/html/documentation.html +280 -0
- data/vendor/pdoc/website/html/images/pdoc.jpg +0 -0
- data/vendor/pdoc/website/html/index.html +84 -0
- data/vendor/pdoc/website/html/stylesheets/main.css +73 -0
- data/vendor/pdoc/website/html/stylesheets/reset.css +18 -0
- data/vendor/pdoc/website/markdown/syntax.markdown +226 -0
- metadata +153 -3
@@ -0,0 +1,109 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
require 'treetop'
|
3
|
+
|
4
|
+
FILE_NAMES = %w[basic tags argument_description description ebnf_arguments ebnf_expression section_content documentation]
|
5
|
+
|
6
|
+
FILE_NAMES.each { |file_name| require "#{file_name}_nodes" }
|
7
|
+
|
8
|
+
%w[ebnf_javascript events].concat(FILE_NAMES).each do |file_name|
|
9
|
+
Treetop.load File.expand_path(File.join(PARSER_DIR, "treetop_files", file_name))
|
10
|
+
end
|
11
|
+
|
12
|
+
module PDoc
|
13
|
+
class Parser
|
14
|
+
def initialize(string)
|
15
|
+
@string = string
|
16
|
+
@parser = DocumentationParser.new
|
17
|
+
@percentage = 0
|
18
|
+
end
|
19
|
+
|
20
|
+
# Parses the preprocessed string. Returns an instance
|
21
|
+
# of Documentation::Doc
|
22
|
+
def parse
|
23
|
+
@finished = false
|
24
|
+
result = @parser.parse(pre_process)
|
25
|
+
@finished = true
|
26
|
+
raise ParseError, @parser unless result
|
27
|
+
result
|
28
|
+
end
|
29
|
+
|
30
|
+
# Preprocess the string before parsing.
|
31
|
+
# Converts "\r\n" to "\n" and avoids edge case
|
32
|
+
# by wrapping the string in line breaks.
|
33
|
+
def pre_process
|
34
|
+
string = @string.gsub(/\r\n/, "\n")
|
35
|
+
string = string.split("\n").map do |line|
|
36
|
+
line.gsub(/\s+$/, '')
|
37
|
+
end.join("\n")
|
38
|
+
"\n#{string}\n"
|
39
|
+
end
|
40
|
+
|
41
|
+
def completion_percentage
|
42
|
+
if @parser.index
|
43
|
+
ratio = @parser.index.to_f / @parser.input.size.to_f
|
44
|
+
percentage = (ratio * 100).floor
|
45
|
+
@percentage = percentage if percentage > @percentage
|
46
|
+
end
|
47
|
+
"#{@percentage}%"
|
48
|
+
end
|
49
|
+
|
50
|
+
def finished?
|
51
|
+
@finished
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
# Thrown by PDoc::Parser if the documentation is malformed.
|
56
|
+
class ParseError < StandardError
|
57
|
+
def initialize(parser)
|
58
|
+
@parser = parser
|
59
|
+
@lines = @parser.input.split("\n").unshift("")
|
60
|
+
end
|
61
|
+
|
62
|
+
def message
|
63
|
+
<<-EOS
|
64
|
+
|
65
|
+
ParseError: Expected #{expected_string} at line #{line}, column #{column} (byte #{index + 1}) after #{@parser.input[@parser.index...index].inspect}.
|
66
|
+
|
67
|
+
#{source_code}
|
68
|
+
|
69
|
+
EOS
|
70
|
+
end
|
71
|
+
|
72
|
+
def line
|
73
|
+
@parser.failure_line
|
74
|
+
end
|
75
|
+
|
76
|
+
def column
|
77
|
+
@parser.failure_column
|
78
|
+
end
|
79
|
+
|
80
|
+
def failures
|
81
|
+
@parser.terminal_failures
|
82
|
+
end
|
83
|
+
|
84
|
+
def index
|
85
|
+
@parser.failure_index
|
86
|
+
end
|
87
|
+
|
88
|
+
def source_code
|
89
|
+
((line-2)..(line+2)).map do |index|
|
90
|
+
result = index == line ? "-->" : " "
|
91
|
+
"#{result} #{index.to_s.rjust(5)} #{@lines[index]}"
|
92
|
+
end.join("\n")
|
93
|
+
end
|
94
|
+
|
95
|
+
def failure_reason
|
96
|
+
""
|
97
|
+
end
|
98
|
+
|
99
|
+
def expected_string
|
100
|
+
if failures.size == 1
|
101
|
+
failures.first.expected_string.inspect
|
102
|
+
else
|
103
|
+
expected = failures.map { |f| f.expected_string.inspect }.uniq
|
104
|
+
last = expected.pop
|
105
|
+
"one of #{expected.join(', ')} or #{last}"
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
@@ -0,0 +1,110 @@
|
|
1
|
+
module PDoc
|
2
|
+
require 'yaml'
|
3
|
+
|
4
|
+
class Runner
|
5
|
+
def initialize(*source_files)
|
6
|
+
options = source_files.last.is_a?(Hash) ? source_files.pop : {}
|
7
|
+
@source_files = source_files.empty? ? options[:source_files] : source_files
|
8
|
+
@output_directory = File.expand_path(options.delete(:destination) || OUTPUT_DIR)
|
9
|
+
@generator = options.delete(:generator) || Generators::Html::Website
|
10
|
+
@parser = Parser
|
11
|
+
@serializer = Serializer
|
12
|
+
@bust_cache = options.delete(:bust_cache) || false
|
13
|
+
Models.src_code_href = options.delete(:src_code_href)
|
14
|
+
Models.doc_href = options.delete(:doc_href)
|
15
|
+
@generator_options = options
|
16
|
+
end
|
17
|
+
|
18
|
+
def serialize(files)
|
19
|
+
files.each do |path|
|
20
|
+
File.open(pdoc_file(path), "w+") do |f|
|
21
|
+
f << serialize_file(path)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
def deserialize(files)
|
27
|
+
results = []
|
28
|
+
files.each do |file|
|
29
|
+
file = pdoc_file(file)
|
30
|
+
File.open(file) do |y|
|
31
|
+
YAML.load_documents(y) { |doc| results << doc }
|
32
|
+
end
|
33
|
+
end
|
34
|
+
results
|
35
|
+
end
|
36
|
+
|
37
|
+
def new_files
|
38
|
+
@source_files.select do |path|
|
39
|
+
pdoc = pdoc_file(path)
|
40
|
+
!File.exist?(pdoc) || File.mtime(path) > File.mtime(pdoc)
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
def run
|
45
|
+
opts = @generator_options
|
46
|
+
puts
|
47
|
+
puts " Markdown parser: #{opts[:markdown_parser]}" if opts[:markdown_parser]
|
48
|
+
puts " Syntax highlighter: #{opts[:syntax_highlighter]}" if opts[:syntax_highlighter]
|
49
|
+
puts " Pretty urls: #{opts[:pretty_urls]}" if opts[:pretty_urls]
|
50
|
+
puts " Index page: #{opts[:index_page]}" if opts[:index_page]
|
51
|
+
puts " Output directory: #{@output_directory}\n\n"
|
52
|
+
|
53
|
+
files = @bust_cache ? @source_files : new_files
|
54
|
+
if files.empty?
|
55
|
+
puts " Restoring serialized documentation from cache.\n\n"
|
56
|
+
else
|
57
|
+
puts " Parsing JS files for PDoc comments:"
|
58
|
+
start_time = Time.new
|
59
|
+
serialize(files)
|
60
|
+
puts " Finished parsing files in #{Time.new - start_time} seconds.\n\n"
|
61
|
+
end
|
62
|
+
|
63
|
+
|
64
|
+
start_time = Time.new
|
65
|
+
data = deserialize(@source_files)
|
66
|
+
root = Treemaker.new(data).root
|
67
|
+
puts " Building documentation tree. Finished in #{Time.new - start_time} seconds.\n\n"
|
68
|
+
|
69
|
+
start_time = Time.new
|
70
|
+
puts " Generating documentation:"
|
71
|
+
@generator.new(root, @generator_options).render(@output_directory)
|
72
|
+
puts "\n Finished generating documentation in #{Time.new - start_time} seconds.\n\n"
|
73
|
+
end
|
74
|
+
|
75
|
+
private
|
76
|
+
def serialize_file(path)
|
77
|
+
serializer = @serializer.new
|
78
|
+
serializer.path = path
|
79
|
+
puts " Parsing #{path}..."
|
80
|
+
File.open(path) do |file|
|
81
|
+
@parser.new(file.read).parse.each do |fragment|
|
82
|
+
fragment.serialize(serializer)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
serializer
|
86
|
+
end
|
87
|
+
|
88
|
+
def pdoc_file(path)
|
89
|
+
name = '.' << File.basename(path, '.js') << '.pdoc.yaml'
|
90
|
+
File.expand_path(File.join(File.dirname(path), name))
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
class Serializer
|
95
|
+
attr_accessor :path
|
96
|
+
def initialize
|
97
|
+
@doc_fragments = []
|
98
|
+
end
|
99
|
+
|
100
|
+
def <<(fragment)
|
101
|
+
fragment = "---\n#{fragment}"
|
102
|
+
fragment << "\nfile: #{path}"
|
103
|
+
@doc_fragments << fragment
|
104
|
+
end
|
105
|
+
|
106
|
+
def to_s
|
107
|
+
@doc_fragments.join("\n\n")
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
@@ -0,0 +1,94 @@
|
|
1
|
+
module PDoc
|
2
|
+
class Treemaker
|
3
|
+
include Models
|
4
|
+
|
5
|
+
def initialize(doc_fragments = [])
|
6
|
+
methodized = []
|
7
|
+
doc_fragments.each do |attributes|
|
8
|
+
if attributes['methodized']
|
9
|
+
dups = attributes.dup
|
10
|
+
dups['id'] = methodize_id(dups['id'])
|
11
|
+
dups['type'] = 'instance method'
|
12
|
+
if dups['signatures']
|
13
|
+
dups['signatures'] = dups['signatures'].map do |s|
|
14
|
+
{
|
15
|
+
'signature' => methodize_signature(s['signature']),
|
16
|
+
'return_value' => s['return_value']
|
17
|
+
}
|
18
|
+
end
|
19
|
+
end
|
20
|
+
if dups['alias_of']
|
21
|
+
dups['alias_of'] = methodize_id(dups['alias_of'])
|
22
|
+
end
|
23
|
+
methodized << dups
|
24
|
+
i = instantiate_from(dups)
|
25
|
+
c = instantiate_from(attributes)
|
26
|
+
i.functionalized_self = c
|
27
|
+
c.methodized_self = i
|
28
|
+
else
|
29
|
+
instantiate_from(attributes)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
doc_fragments.concat(methodized).each do |attributes|
|
34
|
+
if parent_id = attributes['parent_id']
|
35
|
+
parent = root.find(parent_id)
|
36
|
+
raise "Undocumented object: #{parent_id}." unless parent
|
37
|
+
else
|
38
|
+
parent = root
|
39
|
+
end
|
40
|
+
object = root.find(attributes['id'])
|
41
|
+
object.parent = parent
|
42
|
+
object.attach_to_parent(parent)
|
43
|
+
|
44
|
+
if superclass_id = attributes['superclass_id']
|
45
|
+
superclass = root.find(superclass_id)
|
46
|
+
raise "Undocumented object: #{superclass_id}." unless superclass
|
47
|
+
object.superclass = superclass
|
48
|
+
superclass.subclasses << object
|
49
|
+
end
|
50
|
+
|
51
|
+
if included = attributes['included']
|
52
|
+
included.each do |id|
|
53
|
+
mixin = root.find(id)
|
54
|
+
raise "Undocumented object: #{id}." unless mixin
|
55
|
+
object.included_mixins << mixin
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
if alias_of_id = attributes['alias_of']
|
60
|
+
alias_of = root.find(alias_of_id)
|
61
|
+
raise "Undocumented object: #{alias_of_id}." unless alias_of
|
62
|
+
object.alias = alias_of
|
63
|
+
alias_of.aliases << object
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
def instantiate_from(attributes)
|
69
|
+
arguments = attributes.delete('arguments')
|
70
|
+
signatures = attributes.delete('signatures')
|
71
|
+
object = Base.instantiate(attributes)
|
72
|
+
arguments.each { |a| Argument.new(a).attach_to_parent(object) } if arguments
|
73
|
+
signatures.each { |s| Signature.new(s).attach_to_parent(object) } if signatures
|
74
|
+
object.register_on(root.registry)
|
75
|
+
end
|
76
|
+
|
77
|
+
def methodize_signature(sig)
|
78
|
+
sig.sub(/\.([\w\d\$]+)\((.*?)(,\s*|\))/) do
|
79
|
+
first_arg = $2.to_s.strip
|
80
|
+
prefix = first_arg[-1, 1] == '[' ? '([' : '('
|
81
|
+
rest = $3 == ')' ? $3 : ''
|
82
|
+
"##{$1}#{prefix}#{rest}"
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
def methodize_id(id)
|
87
|
+
id.sub(/\.([^\.]+)$/) { "##{$1}" }
|
88
|
+
end
|
89
|
+
|
90
|
+
def root
|
91
|
+
@root ||= Root.new
|
92
|
+
end
|
93
|
+
end
|
94
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
DIR = File.expand_path(File.dirname(__FILE__))
|
2
|
+
OUTPUT_DIR = File.join(DIR, '..', 'output')
|
3
|
+
TEMPLATES_DIR = File.join(DIR, '..', 'templates')
|
4
|
+
VENDOR_DIR = File.join(DIR, '..', 'vendor')
|
5
|
+
PARSER_DIR = File.join(DIR, 'pdoc', 'parser')
|
6
|
+
|
7
|
+
[DIR, VENDOR_DIR, PARSER_DIR, OUTPUT_DIR, TEMPLATES_DIR].each do |c|
|
8
|
+
$:.unshift(c)
|
9
|
+
end
|
10
|
+
|
11
|
+
require 'rubygems'
|
12
|
+
require 'erb'
|
13
|
+
require 'fileutils'
|
14
|
+
|
15
|
+
require 'pdoc/error'
|
16
|
+
require 'pdoc/runner'
|
17
|
+
require 'pdoc/generators'
|
18
|
+
require 'pdoc/parser'
|
19
|
+
require 'pdoc/models'
|
20
|
+
require 'pdoc/treemaker'
|
21
|
+
|
22
|
+
module PDoc
|
23
|
+
def self.run(options = {})
|
24
|
+
Runner.new(options.dup).run
|
25
|
+
end
|
26
|
+
|
27
|
+
def self.copy_templates(template_type, destination)
|
28
|
+
dir = File.expand_path(destination)
|
29
|
+
raise "File already exists: #{destination}" if File.exist?(dir)
|
30
|
+
FileUtils.cp_r("#{TEMPLATES_DIR}/#{template_type}", dir)
|
31
|
+
end
|
32
|
+
end
|
Binary file
|
@@ -0,0 +1,31 @@
|
|
1
|
+
Gem::Specification.new do |s|
|
2
|
+
s.name = "pdoc"
|
3
|
+
s.version = "0.2.0"
|
4
|
+
s.date = "2008-11-17"
|
5
|
+
s.summary = "Inline comment parser and JavaScript documentation generator"
|
6
|
+
s.email = "tobie.langel@gmail.com"
|
7
|
+
s.homepage = "http://pdoc.org/"
|
8
|
+
s.description = "PDoc is an inline comment parser and JavaScript documentation generator written in Ruby. It is designed for documenting Prototype and Prototype-based libraries."
|
9
|
+
s.has_rdoc = true
|
10
|
+
s.authors = ["Tobie Langel"]
|
11
|
+
s.files = [
|
12
|
+
"README.markdown",
|
13
|
+
"Rakefile",
|
14
|
+
"pdoc.gemspec"] +
|
15
|
+
Dir['lib/**/*'] +
|
16
|
+
Dir['templates/**/*']
|
17
|
+
|
18
|
+
s.autorequire = "lib/pdoc.rb"
|
19
|
+
|
20
|
+
s.bindir = "bin"
|
21
|
+
s.executables = ["pdoc"]
|
22
|
+
s.default_executable = "pdoc"
|
23
|
+
|
24
|
+
s.test_files = Dir['test/**/*.rb']
|
25
|
+
s.rdoc_options = ["--main", "README.markdown"]
|
26
|
+
s.extra_rdoc_files = ["README.markdown"]
|
27
|
+
s.add_dependency("BlueCloth", ["> 0.0.0"])
|
28
|
+
s.add_dependency("treetop", ["> 0.0.0"])
|
29
|
+
s.add_dependency("oyster", ["> 0.0.0"])
|
30
|
+
end
|
31
|
+
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|