bean-kramdown 0.13.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (60) hide show
  1. data/AUTHORS +1 -0
  2. data/CONTRIBUTERS +11 -0
  3. data/COPYING +24 -0
  4. data/ChangeLog +6683 -0
  5. data/GPL +674 -0
  6. data/README +43 -0
  7. data/VERSION +1 -0
  8. data/bin/kramdown +78 -0
  9. data/lib/kramdown.rb +23 -0
  10. data/lib/kramdown/compatibility.rb +49 -0
  11. data/lib/kramdown/converter.rb +41 -0
  12. data/lib/kramdown/converter/base.rb +169 -0
  13. data/lib/kramdown/converter/bean_html.rb +71 -0
  14. data/lib/kramdown/converter/html.rb +411 -0
  15. data/lib/kramdown/converter/kramdown.rb +428 -0
  16. data/lib/kramdown/converter/latex.rb +607 -0
  17. data/lib/kramdown/converter/toc.rb +82 -0
  18. data/lib/kramdown/document.rb +119 -0
  19. data/lib/kramdown/element.rb +524 -0
  20. data/lib/kramdown/error.rb +30 -0
  21. data/lib/kramdown/options.rb +373 -0
  22. data/lib/kramdown/parser.rb +39 -0
  23. data/lib/kramdown/parser/base.rb +136 -0
  24. data/lib/kramdown/parser/bean_kramdown.rb +25 -0
  25. data/lib/kramdown/parser/bean_kramdown/info_box.rb +52 -0
  26. data/lib/kramdown/parser/bean_kramdown/oembed.rb +230 -0
  27. data/lib/kramdown/parser/html.rb +570 -0
  28. data/lib/kramdown/parser/kramdown.rb +339 -0
  29. data/lib/kramdown/parser/kramdown/abbreviation.rb +71 -0
  30. data/lib/kramdown/parser/kramdown/autolink.rb +53 -0
  31. data/lib/kramdown/parser/kramdown/blank_line.rb +43 -0
  32. data/lib/kramdown/parser/kramdown/block_boundary.rb +46 -0
  33. data/lib/kramdown/parser/kramdown/blockquote.rb +51 -0
  34. data/lib/kramdown/parser/kramdown/codeblock.rb +63 -0
  35. data/lib/kramdown/parser/kramdown/codespan.rb +56 -0
  36. data/lib/kramdown/parser/kramdown/emphasis.rb +70 -0
  37. data/lib/kramdown/parser/kramdown/eob.rb +39 -0
  38. data/lib/kramdown/parser/kramdown/escaped_chars.rb +38 -0
  39. data/lib/kramdown/parser/kramdown/extensions.rb +204 -0
  40. data/lib/kramdown/parser/kramdown/footnote.rb +74 -0
  41. data/lib/kramdown/parser/kramdown/header.rb +68 -0
  42. data/lib/kramdown/parser/kramdown/horizontal_rule.rb +39 -0
  43. data/lib/kramdown/parser/kramdown/html.rb +169 -0
  44. data/lib/kramdown/parser/kramdown/html_entity.rb +44 -0
  45. data/lib/kramdown/parser/kramdown/image.rb +157 -0
  46. data/lib/kramdown/parser/kramdown/line_break.rb +38 -0
  47. data/lib/kramdown/parser/kramdown/link.rb +154 -0
  48. data/lib/kramdown/parser/kramdown/list.rb +240 -0
  49. data/lib/kramdown/parser/kramdown/math.rb +65 -0
  50. data/lib/kramdown/parser/kramdown/paragraph.rb +63 -0
  51. data/lib/kramdown/parser/kramdown/smart_quotes.rb +214 -0
  52. data/lib/kramdown/parser/kramdown/table.rb +178 -0
  53. data/lib/kramdown/parser/kramdown/typographic_symbol.rb +52 -0
  54. data/lib/kramdown/parser/markdown.rb +69 -0
  55. data/lib/kramdown/utils.rb +42 -0
  56. data/lib/kramdown/utils/entities.rb +348 -0
  57. data/lib/kramdown/utils/html.rb +85 -0
  58. data/lib/kramdown/utils/ordered_hash.rb +100 -0
  59. data/lib/kramdown/version.rb +28 -0
  60. metadata +140 -0
@@ -0,0 +1,82 @@
1
+ # -*- coding: utf-8 -*-
2
+ #
3
+ #--
4
+ # Copyright (C) 2009-2012 Thomas Leitner <t_leitner@gmx.at>
5
+ #
6
+ # This file is part of kramdown.
7
+ #
8
+ # kramdown is free software: you can redistribute it and/or modify
9
+ # it under the terms of the GNU General Public License as published by
10
+ # the Free Software Foundation, either version 3 of the License, or
11
+ # (at your option) any later version.
12
+ #
13
+ # This program is distributed in the hope that it will be useful,
14
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
+ # GNU General Public License for more details.
17
+ #
18
+ # You should have received a copy of the GNU General Public License
19
+ # along with this program. If not, see <http://www.gnu.org/licenses/>.
20
+ #++
21
+ #
22
+
23
+ require 'rexml/parsers/baseparser'
24
+
25
+ module Kramdown
26
+
27
+ module Converter
28
+
29
+ # Converts a Kramdown::Document to an element tree that represents the table of contents.
30
+ #
31
+ # The returned tree consists of Element objects of type :toc where the root element is just used
32
+ # as container object. Each :toc element contains as value the wrapped :header element and under
33
+ # the attribute key :id the header ID that should be used (note that this ID may not exist in
34
+ # the wrapped element).
35
+ #
36
+ # Since the TOC tree consists of special :toc elements, one cannot directly feed this tree to
37
+ # other converters!
38
+ class Toc < Base
39
+
40
+ def initialize(root, options)
41
+ super
42
+ @toc = Element.new(:toc)
43
+ @stack = []
44
+ @options[:template] = ''
45
+ end
46
+
47
+ def convert(el)
48
+ if el.type == :header && in_toc?(el)
49
+ attr = el.attr.dup
50
+ attr['id'] = generate_id(el.options[:raw_text]) if @options[:auto_ids] && !attr['id']
51
+ add_to_toc(el, attr['id'], @toc) if attr['id']
52
+ else
53
+ el.children.each {|child| convert(child)}
54
+ end
55
+ @toc
56
+ end
57
+
58
+ private
59
+
60
+ def add_to_toc(el, id, toc)
61
+ toc_element = Element.new(:toc, el, :id => id)
62
+
63
+ success = false
64
+ while !success
65
+ if @stack.empty?
66
+ @toc.children << toc_element
67
+ @stack << toc_element
68
+ success = true
69
+ elsif @stack.last.value.options[:level] < el.options[:level]
70
+ @stack.last.children << toc_element
71
+ @stack << toc_element
72
+ success = true
73
+ else
74
+ @stack.pop
75
+ end
76
+ end
77
+ end
78
+
79
+ end
80
+
81
+ end
82
+ end
@@ -0,0 +1,119 @@
1
+ # -*- coding: utf-8 -*-
2
+ #
3
+ #--
4
+ # Copyright (C) 2009-2012 Thomas Leitner <t_leitner@gmx.at>
5
+ #
6
+ # This file is part of kramdown.
7
+ #
8
+ # kramdown is free software: you can redistribute it and/or modify
9
+ # it under the terms of the GNU General Public License as published by
10
+ # the Free Software Foundation, either version 3 of the License, or
11
+ # (at your option) any later version.
12
+ #
13
+ # This program is distributed in the hope that it will be useful,
14
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
+ # GNU General Public License for more details.
17
+ #
18
+ # You should have received a copy of the GNU General Public License
19
+ # along with this program. If not, see <http://www.gnu.org/licenses/>.
20
+ #++
21
+ #
22
+
23
+ require 'kramdown/compatibility'
24
+
25
+ require 'kramdown/version'
26
+ require 'kramdown/element'
27
+ require 'kramdown/error'
28
+ require 'kramdown/parser'
29
+ require 'kramdown/converter'
30
+ require 'kramdown/options'
31
+ require 'kramdown/utils'
32
+ require 'kramdown/converter/bean_html'
33
+ require 'kramdown/parser/bean_kramdown'
34
+
35
+ module Kramdown
36
+
37
+ # Return the data directory for kramdown.
38
+ def self.data_dir
39
+ unless defined?(@@data_dir)
40
+ require 'rbconfig'
41
+ @@data_dir = File.expand_path(File.join(File.dirname(__FILE__), '..', '..', 'data', 'kramdown'))
42
+ @@data_dir = File.expand_path(File.join(Config::CONFIG["datadir"], "kramdown")) if !File.exists?(@@data_dir)
43
+ raise "kramdown data directory not found! This is a bug, please report it!" unless File.directory?(@@data_dir)
44
+ end
45
+ @@data_dir
46
+ end
47
+
48
+
49
+ # The main interface to kramdown.
50
+ #
51
+ # This class provides a one-stop-shop for using kramdown to convert text into various output
52
+ # formats. Use it like this:
53
+ #
54
+ # require 'kramdown'
55
+ # doc = Kramdown::Document.new('This *is* some kramdown text')
56
+ # puts doc.to_html
57
+ #
58
+ # The #to_html method is a shortcut for using the Converter::Html class. See #method_missing for
59
+ # more information.
60
+ #
61
+ # The second argument to the ::new method is an options hash for customizing the behaviour of the
62
+ # used parser and the converter. See ::new for more information!
63
+ class Document
64
+
65
+ # The root Element of the element tree. It is immediately available after the ::new method has
66
+ # been called.
67
+ attr_accessor :root
68
+
69
+ # The options hash which holds the options for parsing/converting the Kramdown document.
70
+ attr_reader :options
71
+
72
+ # An array of warning messages. It is filled with warnings during the parsing phase (i.e. in
73
+ # ::new) and the conversion phase.
74
+ attr_reader :warnings
75
+
76
+
77
+ # Create a new Kramdown document from the string +source+ and use the provided +options+. The
78
+ # options that can be used are defined in the Options module.
79
+ #
80
+ # The special options key :input can be used to select the parser that should parse the
81
+ # +source+. It has to be the name of a class in the Kramdown::Parser module. For example, to
82
+ # select the kramdown parser, one would set the :input key to +Kramdown+. If this key is not
83
+ # set, it defaults to +Kramdown+.
84
+ #
85
+ # The +source+ is immediately parsed by the selected parser so that the root element is
86
+ # immediately available and the output can be generated.
87
+ def initialize(source, options = {})
88
+ @options = Options.merge(options).freeze
89
+ parser = (options[:input] || 'kramdown').to_s
90
+ parser = parser[0..0].upcase + parser[1..-1]
91
+ if Parser.const_defined?(parser)
92
+ @root, @warnings = Parser.const_get(parser).parse(source, @options)
93
+ else
94
+ raise Kramdown::Error.new("kramdown has no parser to handle the specified input format: #{options[:input]}")
95
+ end
96
+ end
97
+
98
+ # Check if a method is invoked that begins with +to_+ and if so, try to instantiate a converter
99
+ # class (i.e. a class in the Kramdown::Converter module) and use it for converting the document.
100
+ #
101
+ # For example, +to_html+ would instantiate the Kramdown::Converter::Html class.
102
+ def method_missing(id, *attr, &block)
103
+ if id.to_s =~ /^to_(\w+)$/ && (name = Utils.camelize($1)) && Converter.const_defined?(name)
104
+ output, warnings = Converter.const_get(name).convert(@root, @options)
105
+ @warnings.concat(warnings)
106
+ output
107
+ else
108
+ super
109
+ end
110
+ end
111
+
112
+ def inspect #:nodoc:
113
+ "<KD:Document: options=#{@options.inspect} root=#{@root.inspect} warnings=#{@warnings.inspect}>"
114
+ end
115
+
116
+ end
117
+
118
+ end
119
+
@@ -0,0 +1,524 @@
1
+ # -*- coding: utf-8 -*-
2
+ #
3
+ #--
4
+ # Copyright (C) 2009-2012 Thomas Leitner <t_leitner@gmx.at>
5
+ #
6
+ # This file is part of kramdown.
7
+ #
8
+ # kramdown is free software: you can redistribute it and/or modify
9
+ # it under the terms of the GNU General Public License as published by
10
+ # the Free Software Foundation, either version 3 of the License, or
11
+ # (at your option) any later version.
12
+ #
13
+ # This program is distributed in the hope that it will be useful,
14
+ # but WITHOUT ANY WARRANTY; without even the implied warranty of
15
+ # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
+ # GNU General Public License for more details.
17
+ #
18
+ # You should have received a copy of the GNU General Public License
19
+ # along with this program. If not, see <http://www.gnu.org/licenses/>.
20
+ #++
21
+ #
22
+
23
+ module Kramdown
24
+
25
+ # Represents all elements in the element tree.
26
+ #
27
+ # kramdown only uses this one class for representing all available elements in an element tree
28
+ # (paragraphs, headers, emphasis, ...). The type of element can be set via the #type accessor.
29
+ #
30
+ # Following is a description of all supported element types.
31
+ #
32
+ # == Structural Elements
33
+ #
34
+ # === :root
35
+ #
36
+ # [Category] None
37
+ # [Usage context] As the root element of a document
38
+ # [Content model] Block-level elements
39
+ #
40
+ # Represents the root of a kramdown document.
41
+ #
42
+ # The root element contains the following option keys:
43
+ #
44
+ # :encoding:: When running on Ruby 1.9 this key has to be set to the encoding used for the text
45
+ # parts of the kramdown document.
46
+ #
47
+ # :abbrev_defs:: This key may be used to store the mapping of abbreviation to abbreviation
48
+ # definition.
49
+ #
50
+ # :options:: This key may be used to store options that were set during parsing of the document.
51
+ #
52
+ #
53
+ # === :blank
54
+ #
55
+ # [Category] Block-level element
56
+ # [Usage context] Where block-level elements are expected
57
+ # [Content model] Empty
58
+ #
59
+ # Represents one or more blank lines. It is not allowed to have two or more consecutive blank
60
+ # elements.
61
+ #
62
+ # The +value+ field may contain the original content of the blank lines.
63
+ #
64
+ #
65
+ # === :p
66
+ #
67
+ # [Category] Block-level element
68
+ # [Usage context] Where block-level elements are expected
69
+ # [Content model] Span-level elements
70
+ #
71
+ # Represents a paragraph.
72
+ #
73
+ # If the option :transparent is +true+, this element just represents a block of text. I.e. this
74
+ # element just functions as a container for span-level elements.
75
+ #
76
+ #
77
+ # === :header
78
+ #
79
+ # [Category] Block-level element
80
+ # [Usage context] Where block-level elements are expected
81
+ # [Content model] Span-level elements
82
+ #
83
+ # Represents a header.
84
+ #
85
+ # The option :level specifies the header level and has to contain a number between 1 and \6. The
86
+ # option :raw_text has to contain the raw header text.
87
+ #
88
+ #
89
+ # === :blockquote
90
+ #
91
+ # [Category] Block-level element
92
+ # [Usage context] Where block-level elements are expected
93
+ # [Content model] Block-level elements
94
+ #
95
+ # Represents a blockquote.
96
+ #
97
+ #
98
+ # === :codeblock
99
+ #
100
+ # [Category] Block-level element
101
+ # [Usage context] Where block-level elements are expected
102
+ # [Content model] Empty
103
+ #
104
+ # Represents a code block, i.e. a block of text that should be used as-is.
105
+ #
106
+ # The +value+ field has to contain the content of the code block.
107
+ #
108
+ #
109
+ # === :ul
110
+ #
111
+ # [Category] Block-level element
112
+ # [Usage context] Where block-level elements are expected
113
+ # [Content model] One or more :li elements
114
+ #
115
+ # Represents an unordered list.
116
+ #
117
+ #
118
+ # === :ol
119
+ #
120
+ # [Category] Block-level element
121
+ # [Usage context] Where block-level elements are expected
122
+ # [Content model] One or more :li elements
123
+ #
124
+ # Represents an ordered list.
125
+ #
126
+ #
127
+ # === :li
128
+ #
129
+ # [Category] None
130
+ # [Usage context] Inside :ol and :ul elements
131
+ # [Content model] Block-level elements
132
+ #
133
+ # Represents a list item of an ordered or unordered list.
134
+ #
135
+ # Note that the first child of a list item must not be a :blank element!
136
+ #
137
+ #
138
+ # === :dl
139
+ #
140
+ # [Category] Block-level element
141
+ # [Usage context] Where block-level elements are expected
142
+ # [Content model] One or more groups each consisting of one or more :dt elements followed by one
143
+ # or more :dd elements.
144
+ #
145
+ # Represents a definition list which contains groups consisting of terms and definitions for them.
146
+ #
147
+ #
148
+ # === :dt
149
+ #
150
+ # [Category] None
151
+ # [Usage context] Before :dt or :dd elements inside a :dl elment
152
+ # [Content model] Span-level elements
153
+ #
154
+ # Represents the term part of a term-definition group in a definition list.
155
+ #
156
+ #
157
+ # === :dd
158
+ #
159
+ # [Category] None
160
+ # [Usage context] After :dt or :dd elements inside a :dl elment
161
+ # [Content model] Block-level elements
162
+ #
163
+ # Represents the definition part of a term-definition group in a definition list.
164
+ #
165
+ #
166
+ # === :hr
167
+ #
168
+ # [Category] Block-level element
169
+ # [Usage context] Where block-level elements are expected
170
+ # [Content model] None
171
+ #
172
+ # Represents a horizontal line.
173
+ #
174
+ #
175
+ # === :table
176
+ #
177
+ # [Category] Block-level element
178
+ # [Usage context] Where block-level elements are expected
179
+ # [Content model] Zero or one :thead elements, one or more :tbody elements, zero or one :tfoot
180
+ # elements
181
+ #
182
+ # Represents a table. Each table row (i.e. :tr element) of the table has to contain the same
183
+ # number of :td elements.
184
+ #
185
+ # The option :alignment has to be an array containing the alignment values, exactly one for each
186
+ # column of the table. The possible alignment values are :left, :center, :right and :default.
187
+ #
188
+ #
189
+ # === :thead
190
+ #
191
+ # [Category] None
192
+ # [Usage context] As first element inside a :table element
193
+ # [Content model] One or more :tr elements
194
+ #
195
+ # Represents the table header.
196
+ #
197
+ #
198
+ # === :tbody
199
+ #
200
+ # [Category] None
201
+ # [Usage context] After a :thead element but before a :tfoot element inside a :table element
202
+ # [Content model] One or more :tr elements
203
+ #
204
+ # Represents a table body.
205
+ #
206
+ #
207
+ # === :tfoot
208
+ #
209
+ # [Category] None
210
+ # [Usage context] As last element inside a :table element
211
+ # [Content model] One or more :tr elements
212
+ #
213
+ # Represents the table footer.
214
+ #
215
+ #
216
+ # === :tr
217
+ #
218
+ # [Category] None
219
+ # [Usage context] Inside :thead, :tbody and :tfoot elements
220
+ # [Content model] One or more :td elements
221
+ #
222
+ # Represents a table row.
223
+ #
224
+ #
225
+ # === :td
226
+ #
227
+ # [Category] None
228
+ # [Usage context] Inside :tr elements
229
+ # [Content model] As child of :thead/:tr span-level elements, as child of :tbody/:tr and
230
+ # :tfoot/:tr block-level elements
231
+ #
232
+ # Represents a table cell.
233
+ #
234
+ #
235
+ # === :math
236
+ #
237
+ # [Category] Block/span-level element
238
+ # [Usage context] Where block/span-level elements are expected
239
+ # [Content model] None
240
+ #
241
+ # Represents mathematical text that is written in LaTeX.
242
+ #
243
+ # The +value+ field has to contain the actual mathematical text.
244
+ #
245
+ # The option :category has to be set to either :span or :block depending on the context where the
246
+ # element is used.
247
+ #
248
+ #
249
+ # == Text Markup Elements
250
+ #
251
+ # === :text
252
+ #
253
+ # [Category] Span-level element
254
+ # [Usage context] Where span-level elements are expected
255
+ # [Content model] None
256
+ #
257
+ # Represents text.
258
+ #
259
+ # The +value+ field has to contain the text itself.
260
+ #
261
+ #
262
+ # === :br
263
+ #
264
+ # [Category] Span-level element
265
+ # [Usage context] Where span-level elements are expected
266
+ # [Content model] None
267
+ #
268
+ # Represents a hard line break.
269
+ #
270
+ #
271
+ # === :a
272
+ #
273
+ # [Category] Span-level element
274
+ # [Usage context] Where span-level elements are expected
275
+ # [Content model] Span-level elements
276
+ #
277
+ # Represents a link to an URL.
278
+ #
279
+ # The attribute +href+ has to be set to the URL to which the link points. The attribute +title+
280
+ # optionally contains the title of the link.
281
+ #
282
+ #
283
+ # === :img
284
+ #
285
+ # [Category] Span-level element
286
+ # [Usage context] Where span-level elements are expected
287
+ # [Content model] None
288
+ #
289
+ # Represents an image.
290
+ #
291
+ # The attribute +src+ has to be set to the URL of the image. The attribute +alt+ has to contain a
292
+ # text description of the image. The attribute +title+ optionally contains the title of the image.
293
+ #
294
+ #
295
+ # === :codespan
296
+ #
297
+ # [Category] Span-level element
298
+ # [Usage context] Where span-level elements are expected
299
+ # [Content model] None
300
+ #
301
+ # Represents verbatim text.
302
+ #
303
+ # The +value+ field has to contain the content of the code span.
304
+ #
305
+ #
306
+ # === :footnote
307
+ #
308
+ # [Category] Span-level element
309
+ # [Usage context] Where span-level elements are expected
310
+ # [Content model] None
311
+ #
312
+ # Represents a footnote marker.
313
+ #
314
+ # The +value+ field has to contain an element whose children are the content of the footnote. The
315
+ # option :name has to contain a valid and unique footnote name. A valid footnote name consists of
316
+ # a word character or a digit and then optionally followed by other word characters, digits or
317
+ # dashes.
318
+ #
319
+ #
320
+ # === :em
321
+ #
322
+ # [Category] Span-level element
323
+ # [Usage context] Where span-level elements are expected
324
+ # [Content model] Span-level elements
325
+ #
326
+ # Represents emphasis of its contents.
327
+ #
328
+ #
329
+ # === :strong
330
+ #
331
+ # [Category] Span-level element
332
+ # [Usage context] Where span-level elements are expected
333
+ # [Content model] Span-level elements
334
+ #
335
+ # Represents strong importance for its contents.
336
+ #
337
+ #
338
+ # === :entity
339
+ #
340
+ # [Category] Span-level element
341
+ # [Usage context] Where span-level elements are expected
342
+ # [Content model] None
343
+ #
344
+ # Represents an HTML entity.
345
+ #
346
+ # The +value+ field has to contain an instance of Kramdown::Utils::Entities::Entity. The option
347
+ # :original can be used to store the original representation of the entity.
348
+ #
349
+ #
350
+ # === :typographic_sym
351
+ #
352
+ # [Category] Span-level element
353
+ # [Usage context] Where span-level elements are expected
354
+ # [Content model] None
355
+ #
356
+ # Represents a typographic symbol.
357
+ #
358
+ # The +value+ field needs to contain a Symbol representing the specific typographic symbol from
359
+ # the following list:
360
+ #
361
+ # :mdash:: An mdash character (---)
362
+ # :ndash:: An ndash character (--)
363
+ # :hellip:: An ellipsis (...)
364
+ # :laquo:: A left guillemet (<<)
365
+ # :raquo:: A right guillemet (>>)
366
+ # :laquo_space:: A left guillemet with a space (<< )
367
+ # :raquo_space:: A right guillemet with a space ( >>)
368
+ #
369
+ #
370
+ # === :smart_quote
371
+ #
372
+ # [Category] Span-level element
373
+ # [Usage context] Where span-level elements are expected
374
+ # [Content model] None
375
+ #
376
+ # Represents a quotation character.
377
+ #
378
+ # The +value+ field needs to contain a Symbol representing the specific quotation character:
379
+ #
380
+ # :lsquo:: Left single quote
381
+ # :rsquo:: Right single quote
382
+ # :ldquo:: Left double quote
383
+ # :rdquo:: Right double quote
384
+ #
385
+ #
386
+ # === :abbreviation
387
+ #
388
+ # [Category] Span-level element
389
+ # [Usage context] Where span-level elements are expected
390
+ # [Content model] None
391
+ #
392
+ # Represents a text part that is an abbreviation.
393
+ #
394
+ # The +value+ field has to contain the text part that is the abbreviation. The definition of the
395
+ # abbreviation is stored in the :root element of the document.
396
+ #
397
+ #
398
+ # == Other Elements
399
+ #
400
+ # === :html_element
401
+ #
402
+ # [Category] Block/span-level element
403
+ # [Usage context] Where block/span-level elements or raw HTML elements are expected
404
+ # [Content model] Depends on the element
405
+ #
406
+ # Represents an HTML element.
407
+ #
408
+ # The +value+ field has to contain the name of the HTML element the element is representing.
409
+ #
410
+ # The option :category has to be set to either :span or :block depending on the whether the
411
+ # element is a block-level or a span-level element. The option :content_model has to be set to the
412
+ # content model for the element (either :block if it contains block-level elements, :span if it
413
+ # contains span-level elements or :raw if it contains raw content).
414
+ #
415
+ #
416
+ # === :xml_comment
417
+ #
418
+ # [Category] Block/span-level element
419
+ # [Usage context] Where block/span-level elements are expected or in raw HTML elements
420
+ # [Content model] None
421
+ #
422
+ # Represents an XML/HTML comment.
423
+ #
424
+ # The +value+ field has to contain the whole XML/HTML comment including the delimiters.
425
+ #
426
+ # The option :category has to be set to either :span or :block depending on the context where the
427
+ # element is used.
428
+ #
429
+ #
430
+ # === :xml_pi
431
+ #
432
+ # [Category] Block/span-level element
433
+ # [Usage context] Where block/span-level elements are expected or in raw HTML elements
434
+ # [Content model] None
435
+ #
436
+ # Represents an XML/HTML processing instruction.
437
+ #
438
+ # The +value+ field has to contain the whole XML/HTML processing instruction including the
439
+ # delimiters.
440
+ #
441
+ # The option :category has to be set to either :span or :block depending on the context where the
442
+ # element is used.
443
+ #
444
+ #
445
+ # === :comment
446
+ #
447
+ # [Category] Block/span-level element
448
+ # [Usage context] Where block/span-level elements are expected
449
+ # [Content model] None
450
+ #
451
+ # Represents a comment.
452
+ #
453
+ # The +value+ field has to contain the comment.
454
+ #
455
+ # The option :category has to be set to either :span or :block depending on the context where the
456
+ # element is used. If it is set to :span, then no blank lines are allowed in the comment.
457
+ #
458
+ #
459
+ # === :raw
460
+ #
461
+ # [Category] Block/span-level element
462
+ # [Usage context] Where block/span-level elements are expected
463
+ # [Content model] None
464
+ #
465
+ # Represents a raw string that should not be modified. For example, the element could contain some
466
+ # HTML code that should be output as-is without modification and escaping.
467
+ #
468
+ # The +value+ field has to contain the actual raw text.
469
+ #
470
+ # The option :category has to be set to either :span or :block depending on the context where the
471
+ # element is used. If it is set to :span, then no blank lines are allowed in the raw text.
472
+ #
473
+ # The option :type can be set to an array of strings to define for which converters the raw string
474
+ # is valid.
475
+ class Element
476
+
477
+ # A symbol representing the element type. For example, :p or :blockquote.
478
+ attr_accessor :type
479
+
480
+ # The value of the element. The interpretation of this field depends on the type of the element.
481
+ # Many elements don't use this field.
482
+ attr_accessor :value
483
+
484
+ # The child elements of this element.
485
+ attr_accessor :children
486
+
487
+
488
+ # Create a new Element object of type +type+. The optional parameters +value+, +attr+ and
489
+ # +options+ can also be set in this constructor for convenience.
490
+ def initialize(type, value = nil, attr = nil, options = nil)
491
+ @type, @value, @attr, @options = type, value, (Utils::OrderedHash.new.merge!(attr) if attr), options
492
+ @children = []
493
+ end
494
+
495
+ # The attributes of the element. Uses an Utils::OrderedHash to retain the insertion order.
496
+ def attr
497
+ @attr ||= Utils::OrderedHash.new
498
+ end
499
+
500
+ # The options hash for the element. It is used for storing arbitray options.
501
+ def options
502
+ @options ||= {}
503
+ end
504
+
505
+ def inspect #:nodoc:
506
+ "<kd:#{@type}#{@value.nil? ? '' : ' ' + @value.inspect} #{@attr.inspect}#{options.empty? ? '' : ' ' + @options.inspect}#{@children.empty? ? '' : ' ' + @children.inspect}>"
507
+ end
508
+
509
+ CATEGORY = {} # :nodoc:
510
+ [:blank, :p, :header, :blockquote, :codeblock, :ul, :ol, :dl, :table, :hr].each {|b| CATEGORY[b] = :block}
511
+ [:text, :a, :br, :img, :codespan, :footnote, :em, :strong, :entity, :typographic_sym,
512
+ :smart_quote, :abbreviation].each {|b| CATEGORY[b] = :span}
513
+
514
+ # Return the category of +el+ which can be :block, :span or +nil+.
515
+ #
516
+ # Most elements have a fixed category, however, some elements can either appear in a block-level
517
+ # or a span-level context. These elements need to have the option :category correctly set.
518
+ def self.category(el)
519
+ CATEGORY[el.type] || el.options[:category]
520
+ end
521
+
522
+ end
523
+
524
+ end