lib/kramdown/parser/kramdown/header.rb in kramdown-0.6.0 vs lib/kramdown/parser/kramdown/header.rb in kramdown-0.7.0
- old
+ new
@@ -22,37 +22,23 @@
module Kramdown
module Parser
class Kramdown
- # Generate an alpha-numeric ID from the the string +str+.
- def generate_id(str)
- gen_id = str.gsub(/[^a-zA-Z0-9 -]/, '').gsub(/^[^a-zA-Z]*/, '').gsub(' ', '-').downcase
- gen_id = 'section' if gen_id.length == 0
- @used_ids ||= {}
- if @used_ids.has_key?(gen_id)
- gen_id += '-' + (@used_ids[gen_id] += 1).to_s
- else
- @used_ids[gen_id] = 0
- end
- gen_id
- end
-
HEADER_ID=/(?:[ \t]\{#((?:\w|\d)[\w\d-]*)\})?/
SETEXT_HEADER_START = /^(#{OPT_SPACE}[^ \t].*?)#{HEADER_ID}[ \t]*?\n(-|=)+\s*?\n/
# Parse the Setext header at the current location.
def parse_setext_header
if @tree.children.last && @tree.children.last.type != :blank
return false
end
@src.pos += @src.matched_size
text, id, level = @src[1].strip, @src[2], @src[3]
- el = Element.new(:header, nil, :level => (level == '-' ? 2 : 1))
+ el = new_block_el(:header, nil, :level => (level == '-' ? 2 : 1), :raw_text => text)
add_text(text, el)
el.options[:attr] = {'id' => id} if id
- el.options[:attr] = {'id' => generate_id(text)} if @doc.options[:auto_ids] && !id
@tree.children << el
true
end
define_parser(:setext_header, SETEXT_HEADER_START)
@@ -65,13 +51,12 @@
if @tree.children.last && @tree.children.last.type != :blank
return false
end
result = @src.scan(ATX_HEADER_MATCH)
level, text, id = @src[1], @src[2].strip, @src[3]
- el = Element.new(:header, nil, :level => level.length)
+ el = new_block_el(:header, nil, :level => level.length, :raw_text => text)
add_text(text, el)
el.options[:attr] = {'id' => id} if id
- el.options[:attr] = {'id' => generate_id(text)} if @doc.options[:auto_ids] && !id
@tree.children << el
true
end
define_parser(:atx_header, ATX_HEADER_START)