1 Isn't this functionality a part of what [[plugins/toc]] needs and does? Then probably the [[plugins/toc]] plugin's code could be split into the part that implements the [[plugins/headinganchors]]'s functionality and the TOC generation itself. That will bring more order into the code and the set of available plugins. --Ivan Z.
3 > Indeed it is. Except [[plugins/toc]] generates headings differently - and independently of this. *Even* if [[toc]]'s functionality would be split, you'd probably want to retain backwards compatibility there, so it's unlikely that this will happen... Also see [[todo/toc-with-human-readable-anchors]]. --[[anarcat]]
7 A patch to make it more like MediaWiki:
9 <pre>--- headinganchors.pm
18 hook(type => "sanitize", id => "headinganchors", call => \&headinganchors);
24 - $str =~ s/[&\?"\'\.,\(\)!]//mig;
25 - $str =~ s/[^a-z]/_/mig;
28 + $str =~ s/^[^a-zA-Z]/z-/; # must start with an alphabetical character
29 + $str = uri_escape_utf8($str);
37 > This was applied in 3.20110608 --[[smcv]]
41 I think using this below would let the source html clear for the browser
42 without changing the render:
48 #$str = uri_escape_utf8($str);
49 $str = Encode::decode_utf8($str);
55 > Older HTML and URI specifications didn't allow Unicode in IDs or fragments,
56 > but HTML5 and IRIs do. See also [[plugins/contrib/i18nheadinganchors]]
57 > and its [[plugins/contrib/i18nheadinganchors/discussion]] page.
59 > I think we should probably try to make these autogenerated IDs
60 > punctuation-independent by stripping most non-word characters, like
61 > Pandoc does: I would not expect changing
62 > `## Headings, maybe with punctuation` to
63 > `## Headings (maybe with punctuation)` to have any effect on the
64 > generated "slug" `headings-maybe-with-punctuation`. --[[smcv]]