distil 0.11.6 → 0.11.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (168) hide show
  1. data/VERSION +1 -1
  2. data/assets/distil.js +2 -1
  3. data/bin/distil +2 -0
  4. data/distil.gemspec +152 -2
  5. data/lib/distil/configurable.rb +3 -1
  6. data/lib/distil/error-reporter.rb +2 -0
  7. data/lib/distil/product/concatenated.rb +1 -3
  8. data/lib/distil/product/debug.rb +1 -3
  9. data/lib/distil/product/javascript-product.rb +2 -8
  10. data/lib/distil/product.rb +5 -5
  11. data/lib/distil/project/distil-project.rb +18 -1
  12. data/lib/distil/project/external-project.rb +1 -1
  13. data/lib/distil/project/remote-project.rb +39 -0
  14. data/lib/distil/project.rb +18 -9
  15. data/lib/distil/target.rb +13 -12
  16. data/lib/distil/task/css-dependency-task.rb +1 -1
  17. data/lib/distil/task/validate-js-task.rb +6 -1
  18. data/lib/distil.rb +1 -0
  19. data/vendor/pdoc/LICENSE +16 -0
  20. data/vendor/pdoc/PDoc.tmbundle/Commands/Continue PDoc Comment.tmCommand +39 -0
  21. data/vendor/pdoc/PDoc.tmbundle/Macros/Collapse PDoc Blocks.tmMacro +4084 -0
  22. data/vendor/pdoc/PDoc.tmbundle/Macros/Expand PDoc Blocks.tmMacro +1388 -0
  23. data/vendor/pdoc/PDoc.tmbundle/Preferences/PDoc.tmPreferences +50 -0
  24. data/vendor/pdoc/PDoc.tmbundle/Snippets/class.tmSnippet +24 -0
  25. data/vendor/pdoc/PDoc.tmbundle/Snippets/constant.tmSnippet +22 -0
  26. data/vendor/pdoc/PDoc.tmbundle/Snippets/event.tmSnippet +16 -0
  27. data/vendor/pdoc/PDoc.tmbundle/Snippets/method.tmSnippet +22 -0
  28. data/vendor/pdoc/PDoc.tmbundle/Snippets/mixin.tmSnippet +23 -0
  29. data/vendor/pdoc/PDoc.tmbundle/Snippets/namespace.tmSnippet +24 -0
  30. data/vendor/pdoc/PDoc.tmbundle/Snippets/param.tmSnippet +16 -0
  31. data/vendor/pdoc/PDoc.tmbundle/Snippets/property.tmSnippet +22 -0
  32. data/vendor/pdoc/PDoc.tmbundle/Snippets/section.tmSnippet +23 -0
  33. data/vendor/pdoc/PDoc.tmbundle/Syntaxes/PDoc.tmLanguage +33 -0
  34. data/vendor/pdoc/PDoc.tmbundle/info.plist +22 -0
  35. data/vendor/pdoc/README.markdown +34 -0
  36. data/vendor/pdoc/Rakefile +46 -0
  37. data/vendor/pdoc/bin/pdoc +58 -0
  38. data/vendor/pdoc/lib/pdoc/error.rb +4 -0
  39. data/vendor/pdoc/lib/pdoc/generators/abstract_generator.rb +16 -0
  40. data/vendor/pdoc/lib/pdoc/generators/html/helpers.rb +256 -0
  41. data/vendor/pdoc/lib/pdoc/generators/html/page.rb +71 -0
  42. data/vendor/pdoc/lib/pdoc/generators/html/syntax_highlighter.rb +41 -0
  43. data/vendor/pdoc/lib/pdoc/generators/html/template.rb +37 -0
  44. data/vendor/pdoc/lib/pdoc/generators/html/website.rb +194 -0
  45. data/vendor/pdoc/lib/pdoc/generators/html.rb +8 -0
  46. data/vendor/pdoc/lib/pdoc/generators/json.rb +15 -0
  47. data/vendor/pdoc/lib/pdoc/generators/pythonesque.rb +105 -0
  48. data/vendor/pdoc/lib/pdoc/generators.rb +6 -0
  49. data/vendor/pdoc/lib/pdoc/models/argument.rb +37 -0
  50. data/vendor/pdoc/lib/pdoc/models/base.rb +107 -0
  51. data/vendor/pdoc/lib/pdoc/models/callable.rb +19 -0
  52. data/vendor/pdoc/lib/pdoc/models/class.rb +28 -0
  53. data/vendor/pdoc/lib/pdoc/models/class_method.rb +18 -0
  54. data/vendor/pdoc/lib/pdoc/models/class_property.rb +9 -0
  55. data/vendor/pdoc/lib/pdoc/models/constant.rb +9 -0
  56. data/vendor/pdoc/lib/pdoc/models/constructor.rb +14 -0
  57. data/vendor/pdoc/lib/pdoc/models/container.rb +114 -0
  58. data/vendor/pdoc/lib/pdoc/models/entity.rb +54 -0
  59. data/vendor/pdoc/lib/pdoc/models/instance_method.rb +18 -0
  60. data/vendor/pdoc/lib/pdoc/models/instance_property.rb +9 -0
  61. data/vendor/pdoc/lib/pdoc/models/mixin.rb +10 -0
  62. data/vendor/pdoc/lib/pdoc/models/namespace.rb +10 -0
  63. data/vendor/pdoc/lib/pdoc/models/root.rb +27 -0
  64. data/vendor/pdoc/lib/pdoc/models/section.rb +19 -0
  65. data/vendor/pdoc/lib/pdoc/models/signature.rb +27 -0
  66. data/vendor/pdoc/lib/pdoc/models/utility.rb +11 -0
  67. data/vendor/pdoc/lib/pdoc/models.rb +47 -0
  68. data/vendor/pdoc/lib/pdoc/parser/argument_description_nodes.rb +21 -0
  69. data/vendor/pdoc/lib/pdoc/parser/basic_nodes.rb +31 -0
  70. data/vendor/pdoc/lib/pdoc/parser/description_nodes.rb +42 -0
  71. data/vendor/pdoc/lib/pdoc/parser/documentation_nodes.rb +483 -0
  72. data/vendor/pdoc/lib/pdoc/parser/ebnf_arguments_nodes.rb +58 -0
  73. data/vendor/pdoc/lib/pdoc/parser/ebnf_expression_nodes.rb +227 -0
  74. data/vendor/pdoc/lib/pdoc/parser/fragment.rb +55 -0
  75. data/vendor/pdoc/lib/pdoc/parser/section_content_nodes.rb +19 -0
  76. data/vendor/pdoc/lib/pdoc/parser/tags_nodes.rb +14 -0
  77. data/vendor/pdoc/lib/pdoc/parser/treetop_files/argument_description.treetop +31 -0
  78. data/vendor/pdoc/lib/pdoc/parser/treetop_files/basic.treetop +41 -0
  79. data/vendor/pdoc/lib/pdoc/parser/treetop_files/description.treetop +7 -0
  80. data/vendor/pdoc/lib/pdoc/parser/treetop_files/documentation.treetop +75 -0
  81. data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_arguments.treetop +33 -0
  82. data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_expression.treetop +70 -0
  83. data/vendor/pdoc/lib/pdoc/parser/treetop_files/ebnf_javascript.treetop +54 -0
  84. data/vendor/pdoc/lib/pdoc/parser/treetop_files/events.treetop +17 -0
  85. data/vendor/pdoc/lib/pdoc/parser/treetop_files/section_content.treetop +8 -0
  86. data/vendor/pdoc/lib/pdoc/parser/treetop_files/tags.treetop +31 -0
  87. data/vendor/pdoc/lib/pdoc/parser.rb +109 -0
  88. data/vendor/pdoc/lib/pdoc/runner.rb +110 -0
  89. data/vendor/pdoc/lib/pdoc/treemaker.rb +94 -0
  90. data/vendor/pdoc/lib/pdoc.rb +32 -0
  91. data/vendor/pdoc/pdoc-0.2.0.gem +0 -0
  92. data/vendor/pdoc/pdoc.gemspec +31 -0
  93. data/vendor/pdoc/templates/html/assets/images/pdoc/alias.png +0 -0
  94. data/vendor/pdoc/templates/html/assets/images/pdoc/class.png +0 -0
  95. data/vendor/pdoc/templates/html/assets/images/pdoc/class_deprecated.png +0 -0
  96. data/vendor/pdoc/templates/html/assets/images/pdoc/class_method.png +0 -0
  97. data/vendor/pdoc/templates/html/assets/images/pdoc/class_property.png +0 -0
  98. data/vendor/pdoc/templates/html/assets/images/pdoc/constant.png +0 -0
  99. data/vendor/pdoc/templates/html/assets/images/pdoc/constructor.png +0 -0
  100. data/vendor/pdoc/templates/html/assets/images/pdoc/deprecated.png +0 -0
  101. data/vendor/pdoc/templates/html/assets/images/pdoc/description.png +0 -0
  102. data/vendor/pdoc/templates/html/assets/images/pdoc/information.png +0 -0
  103. data/vendor/pdoc/templates/html/assets/images/pdoc/instance_method.png +0 -0
  104. data/vendor/pdoc/templates/html/assets/images/pdoc/instance_property.png +0 -0
  105. data/vendor/pdoc/templates/html/assets/images/pdoc/method.png +0 -0
  106. data/vendor/pdoc/templates/html/assets/images/pdoc/method_deprecated.png +0 -0
  107. data/vendor/pdoc/templates/html/assets/images/pdoc/mixin.png +0 -0
  108. data/vendor/pdoc/templates/html/assets/images/pdoc/namespace.png +0 -0
  109. data/vendor/pdoc/templates/html/assets/images/pdoc/property.png +0 -0
  110. data/vendor/pdoc/templates/html/assets/images/pdoc/related_to.png +0 -0
  111. data/vendor/pdoc/templates/html/assets/images/pdoc/search-background.png +0 -0
  112. data/vendor/pdoc/templates/html/assets/images/pdoc/section-background.png +0 -0
  113. data/vendor/pdoc/templates/html/assets/images/pdoc/section.png +0 -0
  114. data/vendor/pdoc/templates/html/assets/images/pdoc/selected-section-background.png +0 -0
  115. data/vendor/pdoc/templates/html/assets/images/pdoc/subclass.png +0 -0
  116. data/vendor/pdoc/templates/html/assets/images/pdoc/superclass.png +0 -0
  117. data/vendor/pdoc/templates/html/assets/images/pdoc/utility.png +0 -0
  118. data/vendor/pdoc/templates/html/assets/javascripts/pdoc/application.js +478 -0
  119. data/vendor/pdoc/templates/html/assets/javascripts/pdoc/prototype.js +4874 -0
  120. data/vendor/pdoc/templates/html/assets/javascripts/pdoc/tabs.js +506 -0
  121. data/vendor/pdoc/templates/html/assets/stylesheets/pdoc/api.css +677 -0
  122. data/vendor/pdoc/templates/html/assets/stylesheets/pdoc/pygments.css +62 -0
  123. data/vendor/pdoc/templates/html/helpers.rb +35 -0
  124. data/vendor/pdoc/templates/html/index.erb +18 -0
  125. data/vendor/pdoc/templates/html/item_index.js.erb +6 -0
  126. data/vendor/pdoc/templates/html/layout.erb +67 -0
  127. data/vendor/pdoc/templates/html/leaf.erb +22 -0
  128. data/vendor/pdoc/templates/html/node.erb +30 -0
  129. data/vendor/pdoc/templates/html/partials/class_relationships.erb +19 -0
  130. data/vendor/pdoc/templates/html/partials/classes.erb +7 -0
  131. data/vendor/pdoc/templates/html/partials/constructor.erb +5 -0
  132. data/vendor/pdoc/templates/html/partials/description.erb +5 -0
  133. data/vendor/pdoc/templates/html/partials/link_list.erb +1 -0
  134. data/vendor/pdoc/templates/html/partials/method_signatures.erb +14 -0
  135. data/vendor/pdoc/templates/html/partials/methodized_note.erb +9 -0
  136. data/vendor/pdoc/templates/html/partials/mixins.erb +7 -0
  137. data/vendor/pdoc/templates/html/partials/namespaces.erb +7 -0
  138. data/vendor/pdoc/templates/html/partials/related_utilities.erb +5 -0
  139. data/vendor/pdoc/templates/html/partials/relationships.erb +11 -0
  140. data/vendor/pdoc/templates/html/partials/short_description_list.erb +7 -0
  141. data/vendor/pdoc/templates/html/partials/title.erb +22 -0
  142. data/vendor/pdoc/templates/html/section.erb +18 -0
  143. data/vendor/pdoc/test/fixtures/ajax.js +809 -0
  144. data/vendor/pdoc/test/fixtures/prototype.js +5789 -0
  145. data/vendor/pdoc/test/fixtures/test.txt +1 -0
  146. data/vendor/pdoc/test/fixtures/text.txt +13 -0
  147. data/vendor/pdoc/test/unit/parser/argument_description_test.rb +40 -0
  148. data/vendor/pdoc/test/unit/parser/basic_test.rb +55 -0
  149. data/vendor/pdoc/test/unit/parser/description_test.rb +34 -0
  150. data/vendor/pdoc/test/unit/parser/documentation_test.rb +520 -0
  151. data/vendor/pdoc/test/unit/parser/ebnf_arguments_test.rb +81 -0
  152. data/vendor/pdoc/test/unit/parser/ebnf_expression_test.rb +382 -0
  153. data/vendor/pdoc/test/unit/parser/ebnf_javascript_test.rb +37 -0
  154. data/vendor/pdoc/test/unit/parser/events_test.rb +27 -0
  155. data/vendor/pdoc/test/unit/parser/section_content_test.rb +44 -0
  156. data/vendor/pdoc/test/unit/parser/tags_test.rb +39 -0
  157. data/vendor/pdoc/test/unit/parser/test_fragment.rb +80 -0
  158. data/vendor/pdoc/test/unit/parser_test_helper.rb +62 -0
  159. data/vendor/pdoc/test/unit/runner/basic_test.rb +14 -0
  160. data/vendor/pdoc/test/unit/templates/html_helpers_test.rb +25 -0
  161. data/vendor/pdoc/vendor/albino.rb +122 -0
  162. data/vendor/pdoc/website/html/documentation.html +280 -0
  163. data/vendor/pdoc/website/html/images/pdoc.jpg +0 -0
  164. data/vendor/pdoc/website/html/index.html +84 -0
  165. data/vendor/pdoc/website/html/stylesheets/main.css +73 -0
  166. data/vendor/pdoc/website/html/stylesheets/reset.css +18 -0
  167. data/vendor/pdoc/website/markdown/syntax.markdown +226 -0
  168. 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
+