markup/goldmark: Make the autoID type config a string
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 5 Jan 2020 10:29:22 +0000 (11:29 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 5 Jan 2020 10:29:22 +0000 (11:29 +0100)
To potentially make room for one more.

See #6707

markup/goldmark/autoid.go
markup/goldmark/convert.go
markup/goldmark/convert_test.go
markup/goldmark/goldmark_config/config.go

index c064a76b3d2b32ca7ee3f8df37f73d27e0af3a28..aaf1852d1616b71481d45eee264f5a6863d1093e 100644 (file)
@@ -19,6 +19,8 @@ import (
        "unicode"
        "unicode/utf8"
 
+       "github.com/gohugoio/hugo/markup/goldmark/goldmark_config"
+
        "github.com/gohugoio/hugo/common/text"
 
        "github.com/yuin/goldmark/ast"
@@ -85,10 +87,10 @@ type idFactory struct {
        vals      map[string]struct{}
 }
 
-func newIDFactory(asciiOnly bool) *idFactory {
+func newIDFactory(idType string) *idFactory {
        return &idFactory{
                vals:      make(map[string]struct{}),
-               asciiOnly: asciiOnly,
+               asciiOnly: idType == goldmark_config.AutoHeadingIDTypeGitHubAscii,
        }
 }
 
index 7d50839e23390259a8a8f218dfad28cf24773f9b..c6f958366180b0986bdea398044d5d5e74d330ae 100644 (file)
@@ -28,8 +28,8 @@ import (
        "github.com/spf13/afero"
 
        "github.com/gohugoio/hugo/hugofs"
-
        "github.com/gohugoio/hugo/markup/converter"
+       "github.com/gohugoio/hugo/markup/goldmark/goldmark_config"
        "github.com/gohugoio/hugo/markup/highlight"
        "github.com/gohugoio/hugo/markup/tableofcontents"
        "github.com/yuin/goldmark"
@@ -57,7 +57,7 @@ func (p provide) New(cfg converter.ProviderConfig) (converter.Provider, error) {
                        cfg: cfg,
                        md:  md,
                        sanitizeAnchorName: func(s string) string {
-                               return sanitizeAnchorNameString(s, cfg.MarkupConfig.Goldmark.Parser.AutoHeadingIDAsciiOnly)
+                               return sanitizeAnchorNameString(s, cfg.MarkupConfig.Goldmark.Parser.AutoHeadingIDType == goldmark_config.AutoHeadingIDTypeGitHub)
                        },
                }, nil
        }), nil
@@ -280,7 +280,7 @@ func (c *goldmarkConverter) Supports(feature identity.Identity) bool {
 }
 
 func (c *goldmarkConverter) newParserContext(rctx converter.RenderContext) *parserContext {
-       ctx := parser.NewContext(parser.WithIDs(newIDFactory(c.cfg.MarkupConfig.Goldmark.Parser.AutoHeadingIDAsciiOnly)))
+       ctx := parser.NewContext(parser.WithIDs(newIDFactory(c.cfg.MarkupConfig.Goldmark.Parser.AutoHeadingIDType)))
        ctx.Set(tocEnableKey, rctx.RenderTOC)
        return &parserContext{
                Context: ctx,
index b9bf01ef5e18337c02b06a2bb0892eaf40947a98..3c173fb0a35f8138ae2e272cb1534698880b1373 100644 (file)
@@ -17,6 +17,8 @@ import (
        "strings"
        "testing"
 
+       "github.com/gohugoio/hugo/markup/goldmark/goldmark_config"
+
        "github.com/gohugoio/hugo/markup/highlight"
 
        "github.com/gohugoio/hugo/markup/markup_config"
@@ -169,7 +171,7 @@ func TestConvertAutoIDAsciiOnly(t *testing.T) {
 ## God is Good: 神真美好
 `
        mconf := markup_config.Default
-       mconf.Goldmark.Parser.AutoHeadingIDAsciiOnly = true
+       mconf.Goldmark.Parser.AutoHeadingIDType = goldmark_config.AutoHeadingIDTypeGitHubAscii
        b := convert(c, mconf, content)
        got := string(b.Bytes())
 
index 2454eb46f24c9b33218744aff99485ead01457ae..47399b52c54b2bc0301f51d269e66d3bc77b67d7 100644 (file)
 // Package goldmark_config holds Goldmark related configuration.
 package goldmark_config
 
+const (
+       AutoHeadingIDTypeGitHub      = "github"
+       AutoHeadingIDTypeGitHubAscii = "github-ascii"
+)
+
 // DefaultConfig holds the default Goldmark configuration.
 var Default = Config{
        Extensions: Extensions{
@@ -29,8 +34,9 @@ var Default = Config{
                Unsafe: false,
        },
        Parser: Parser{
-               AutoHeadingID: true,
-               Attribute:     true,
+               AutoHeadingID:     true,
+               AutoHeadingIDType: AutoHeadingIDTypeGitHub,
+               Attribute:         true,
        },
 }
 
@@ -69,9 +75,10 @@ type Parser struct {
        // auto generated heading ids.
        AutoHeadingID bool
 
-       // When AutoHeadingID is enabled this will generate IDs with Ascii
-       // characters only.
-       AutoHeadingIDAsciiOnly bool
+       // The strategy to use when generating heading IDs.
+       // Available options are "github", "github-ascii".
+       // Default is "github", which will create GitHub-compatible anchor names.
+       AutoHeadingIDType string
 
        // Enables custom attributes.
        Attribute bool