Vendor update: github.com/yuin/goldmark v1.2.1 (#12377)
Thanks to @yuin fix #12376
This commit is contained in:
		
					parent
					
						
							
								1f12dc8e88
							
						
					
				
			
			
				commit
				
					
						7e96268fb0
					
				
			
		
					 9 changed files with 233 additions and 39 deletions
				
			
		
							
								
								
									
										2
									
								
								go.mod
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
										
									
									
									
								
							| 
						 | 
					@ -100,7 +100,7 @@ require (
 | 
				
			||||||
	github.com/urfave/cli v1.20.0
 | 
						github.com/urfave/cli v1.20.0
 | 
				
			||||||
	github.com/xanzy/go-gitlab v0.31.0
 | 
						github.com/xanzy/go-gitlab v0.31.0
 | 
				
			||||||
	github.com/yohcop/openid-go v1.0.0
 | 
						github.com/yohcop/openid-go v1.0.0
 | 
				
			||||||
	github.com/yuin/goldmark v1.1.32
 | 
						github.com/yuin/goldmark v1.2.1
 | 
				
			||||||
	github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691
 | 
						github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691
 | 
				
			||||||
	github.com/yuin/goldmark-meta v0.0.0-20191126180153-f0638e958b60
 | 
						github.com/yuin/goldmark-meta v0.0.0-20191126180153-f0638e958b60
 | 
				
			||||||
	golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9
 | 
						golang.org/x/crypto v0.0.0-20200604202706-70a84ac30bf9
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										2
									
								
								go.sum
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								go.sum
									
										
									
									
									
								
							| 
						 | 
					@ -715,6 +715,8 @@ github.com/yuin/goldmark v1.1.25 h1:isv+Q6HQAmmL2Ofcmg8QauBmDPlUUnSoNhEcC940Rds=
 | 
				
			||||||
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
 | 
					github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
 | 
				
			||||||
github.com/yuin/goldmark v1.1.32 h1:5tjfNdR2ki3yYQ842+eX2sQHeiwpKJ0RnHO4IYOc4V8=
 | 
					github.com/yuin/goldmark v1.1.32 h1:5tjfNdR2ki3yYQ842+eX2sQHeiwpKJ0RnHO4IYOc4V8=
 | 
				
			||||||
github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
 | 
					github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
 | 
				
			||||||
 | 
					github.com/yuin/goldmark v1.2.1 h1:ruQGxdhGHe7FWOJPT0mKs5+pD2Xs1Bm/kdGlHO04FmM=
 | 
				
			||||||
 | 
					github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
 | 
				
			||||||
github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691 h1:VWSxtAiQNh3zgHJpdpkpVYjTPqRE3P6UZCOPa1nRDio=
 | 
					github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691 h1:VWSxtAiQNh3zgHJpdpkpVYjTPqRE3P6UZCOPa1nRDio=
 | 
				
			||||||
github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691/go.mod h1:YLF3kDffRfUH/bTxOxHhV6lxwIB3Vfj91rEwNMS9MXo=
 | 
					github.com/yuin/goldmark-highlighting v0.0.0-20200307114337-60d527fdb691/go.mod h1:YLF3kDffRfUH/bTxOxHhV6lxwIB3Vfj91rEwNMS9MXo=
 | 
				
			||||||
github.com/yuin/goldmark-meta v0.0.0-20191126180153-f0638e958b60 h1:gZucqLjL1eDzVWrXj4uiWeMbAopJlBR2mKQAsTGdPwo=
 | 
					github.com/yuin/goldmark-meta v0.0.0-20191126180153-f0638e958b60 h1:gZucqLjL1eDzVWrXj4uiWeMbAopJlBR2mKQAsTGdPwo=
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										14
									
								
								vendor/github.com/yuin/goldmark/README.md
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								vendor/github.com/yuin/goldmark/README.md
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -203,6 +203,18 @@ heading {#id .className attrName=attrValue}
 | 
				
			||||||
============
 | 
					============
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Table extension
 | 
				
			||||||
 | 
					The Table extension implements [Table(extension)](https://github.github.com/gfm/#tables-extension-), as
 | 
				
			||||||
 | 
					defined in [GitHub Flavored Markdown Spec](https://github.github.com/gfm/).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Specs are defined for XHTML, so specs use some deprecated attributes for HTML5.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					You can override alignment rendering method via options.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					| Functional option | Type | Description |
 | 
				
			||||||
 | 
					| ----------------- | ---- | ----------- |
 | 
				
			||||||
 | 
					| `extension.WithTableCellAlignMethod` | `extension.TableCellAlignMethod` | Option indicates how are table cells aligned. |
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Typographer extension
 | 
					### Typographer extension
 | 
				
			||||||
 | 
					
 | 
				
			||||||
The Typographer extension translates plain ASCII punctuation characters into typographic-punctuation HTML entities.
 | 
					The Typographer extension translates plain ASCII punctuation characters into typographic-punctuation HTML entities.
 | 
				
			||||||
| 
						 | 
					@ -219,7 +231,7 @@ Default substitutions are:
 | 
				
			||||||
| `<<`       | `«` |
 | 
					| `<<`       | `«` |
 | 
				
			||||||
| `>>`       | `»` |
 | 
					| `>>`       | `»` |
 | 
				
			||||||
 | 
					
 | 
				
			||||||
You can override the defualt substitutions via `extensions.WithTypographicSubstitutions`:
 | 
					You can override the default substitutions via `extensions.WithTypographicSubstitutions`:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
```go
 | 
					```go
 | 
				
			||||||
markdown := goldmark.New(
 | 
					markdown := goldmark.New(
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										202
									
								
								vendor/github.com/yuin/goldmark/extension/table.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										202
									
								
								vendor/github.com/yuin/goldmark/extension/table.go
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -15,7 +15,113 @@ import (
 | 
				
			||||||
	"github.com/yuin/goldmark/util"
 | 
						"github.com/yuin/goldmark/util"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var tableDelimRegexp = regexp.MustCompile(`^[\s\-\|\:]+$`)
 | 
					// TableCellAlignMethod indicates how are table cells aligned in HTML format.indicates how are table cells aligned in HTML format.
 | 
				
			||||||
 | 
					type TableCellAlignMethod int
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const (
 | 
				
			||||||
 | 
						// TableCellAlignDefault renders alignments by default method.
 | 
				
			||||||
 | 
						// With XHTML, alignments are rendered as an align attribute.
 | 
				
			||||||
 | 
						// With HTML5, alignments are rendered as a style attribute.
 | 
				
			||||||
 | 
						TableCellAlignDefault TableCellAlignMethod = iota
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// TableCellAlignAttribute renders alignments as an align attribute.
 | 
				
			||||||
 | 
						TableCellAlignAttribute
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// TableCellAlignStyle renders alignments as a style attribute.
 | 
				
			||||||
 | 
						TableCellAlignStyle
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// TableCellAlignNone does not care about alignments.
 | 
				
			||||||
 | 
						// If you using classes or other styles, you can add these attributes
 | 
				
			||||||
 | 
						// in an ASTTransformer.
 | 
				
			||||||
 | 
						TableCellAlignNone
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TableConfig struct holds options for the extension.
 | 
				
			||||||
 | 
					type TableConfig struct {
 | 
				
			||||||
 | 
						html.Config
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// TableCellAlignMethod indicates how are table celss aligned.
 | 
				
			||||||
 | 
						TableCellAlignMethod TableCellAlignMethod
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TableOption interface is a functional option interface for the extension.
 | 
				
			||||||
 | 
					type TableOption interface {
 | 
				
			||||||
 | 
						renderer.Option
 | 
				
			||||||
 | 
						// SetTableOption sets given option to the extension.
 | 
				
			||||||
 | 
						SetTableOption(*TableConfig)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// NewTableConfig returns a new Config with defaults.
 | 
				
			||||||
 | 
					func NewTableConfig() TableConfig {
 | 
				
			||||||
 | 
						return TableConfig{
 | 
				
			||||||
 | 
							Config:               html.NewConfig(),
 | 
				
			||||||
 | 
							TableCellAlignMethod: TableCellAlignDefault,
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// SetOption implements renderer.SetOptioner.
 | 
				
			||||||
 | 
					func (c *TableConfig) SetOption(name renderer.OptionName, value interface{}) {
 | 
				
			||||||
 | 
						switch name {
 | 
				
			||||||
 | 
						case optTableCellAlignMethod:
 | 
				
			||||||
 | 
							c.TableCellAlignMethod = value.(TableCellAlignMethod)
 | 
				
			||||||
 | 
						default:
 | 
				
			||||||
 | 
							c.Config.SetOption(name, value)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type withTableHTMLOptions struct {
 | 
				
			||||||
 | 
						value []html.Option
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (o *withTableHTMLOptions) SetConfig(c *renderer.Config) {
 | 
				
			||||||
 | 
						if o.value != nil {
 | 
				
			||||||
 | 
							for _, v := range o.value {
 | 
				
			||||||
 | 
								v.(renderer.Option).SetConfig(c)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (o *withTableHTMLOptions) SetTableOption(c *TableConfig) {
 | 
				
			||||||
 | 
						if o.value != nil {
 | 
				
			||||||
 | 
							for _, v := range o.value {
 | 
				
			||||||
 | 
								v.SetHTMLOption(&c.Config)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// WithTableHTMLOptions is functional option that wraps goldmark HTMLRenderer options.
 | 
				
			||||||
 | 
					func WithTableHTMLOptions(opts ...html.Option) TableOption {
 | 
				
			||||||
 | 
						return &withTableHTMLOptions{opts}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const optTableCellAlignMethod renderer.OptionName = "TableTableCellAlignMethod"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type withTableCellAlignMethod struct {
 | 
				
			||||||
 | 
						value TableCellAlignMethod
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (o *withTableCellAlignMethod) SetConfig(c *renderer.Config) {
 | 
				
			||||||
 | 
						c.Options[optTableCellAlignMethod] = o.value
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (o *withTableCellAlignMethod) SetTableOption(c *TableConfig) {
 | 
				
			||||||
 | 
						c.TableCellAlignMethod = o.value
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// WithTableCellAlignMethod is a functional option that indicates how are table cells aligned in HTML format.
 | 
				
			||||||
 | 
					func WithTableCellAlignMethod(a TableCellAlignMethod) TableOption {
 | 
				
			||||||
 | 
						return &withTableCellAlignMethod{a}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func isTableDelim(bs []byte) bool {
 | 
				
			||||||
 | 
						for _, b := range bs {
 | 
				
			||||||
 | 
							if !(util.IsSpace(b) || b == '-' || b == '|' || b == ':') {
 | 
				
			||||||
 | 
								return false
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return true
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var tableDelimLeft = regexp.MustCompile(`^\s*\:\-+\s*$`)
 | 
					var tableDelimLeft = regexp.MustCompile(`^\s*\:\-+\s*$`)
 | 
				
			||||||
var tableDelimRight = regexp.MustCompile(`^\s*\-+\:\s*$`)
 | 
					var tableDelimRight = regexp.MustCompile(`^\s*\-+\:\s*$`)
 | 
				
			||||||
var tableDelimCenter = regexp.MustCompile(`^\s*\:\-+\:\s*$`)
 | 
					var tableDelimCenter = regexp.MustCompile(`^\s*\:\-+\:\s*$`)
 | 
				
			||||||
| 
						 | 
					@ -37,22 +143,31 @@ func (b *tableParagraphTransformer) Transform(node *gast.Paragraph, reader text.
 | 
				
			||||||
	if lines.Len() < 2 {
 | 
						if lines.Len() < 2 {
 | 
				
			||||||
		return
 | 
							return
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	alignments := b.parseDelimiter(lines.At(1), reader)
 | 
						for i := 1; i < lines.Len(); i++ {
 | 
				
			||||||
	if alignments == nil {
 | 
							alignments := b.parseDelimiter(lines.At(i), reader)
 | 
				
			||||||
		return
 | 
							if alignments == nil {
 | 
				
			||||||
 | 
								continue
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							header := b.parseRow(lines.At(i-1), alignments, true, reader)
 | 
				
			||||||
 | 
							if header == nil || len(alignments) != header.ChildCount() {
 | 
				
			||||||
 | 
								return
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							table := ast.NewTable()
 | 
				
			||||||
 | 
							table.Alignments = alignments
 | 
				
			||||||
 | 
							table.AppendChild(table, ast.NewTableHeader(header))
 | 
				
			||||||
 | 
							for j := i + 1; j < lines.Len(); j++ {
 | 
				
			||||||
 | 
								table.AppendChild(table, b.parseRow(lines.At(j), alignments, false, reader))
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							node.Lines().SetSliced(0, i-1)
 | 
				
			||||||
 | 
							node.Parent().InsertAfter(node.Parent(), node, table)
 | 
				
			||||||
 | 
							if node.Lines().Len() == 0 {
 | 
				
			||||||
 | 
								node.Parent().RemoveChild(node.Parent(), node)
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								last := node.Lines().At(i - 2)
 | 
				
			||||||
 | 
								last.Stop = last.Stop - 1 // trim last newline(\n)
 | 
				
			||||||
 | 
								node.Lines().Set(i-2, last)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	header := b.parseRow(lines.At(0), alignments, true, reader)
 | 
					 | 
				
			||||||
	if header == nil || len(alignments) != header.ChildCount() {
 | 
					 | 
				
			||||||
		return
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	table := ast.NewTable()
 | 
					 | 
				
			||||||
	table.Alignments = alignments
 | 
					 | 
				
			||||||
	table.AppendChild(table, ast.NewTableHeader(header))
 | 
					 | 
				
			||||||
	for i := 2; i < lines.Len(); i++ {
 | 
					 | 
				
			||||||
		table.AppendChild(table, b.parseRow(lines.At(i), alignments, false, reader))
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
	node.Parent().InsertBefore(node.Parent(), node, table)
 | 
					 | 
				
			||||||
	node.Parent().RemoveChild(node.Parent(), node)
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (b *tableParagraphTransformer) parseRow(segment text.Segment, alignments []ast.Alignment, isHeader bool, reader text.Reader) *ast.TableRow {
 | 
					func (b *tableParagraphTransformer) parseRow(segment text.Segment, alignments []ast.Alignment, isHeader bool, reader text.Reader) *ast.TableRow {
 | 
				
			||||||
| 
						 | 
					@ -100,7 +215,7 @@ func (b *tableParagraphTransformer) parseRow(segment text.Segment, alignments []
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (b *tableParagraphTransformer) parseDelimiter(segment text.Segment, reader text.Reader) []ast.Alignment {
 | 
					func (b *tableParagraphTransformer) parseDelimiter(segment text.Segment, reader text.Reader) []ast.Alignment {
 | 
				
			||||||
	line := segment.Value(reader.Source())
 | 
						line := segment.Value(reader.Source())
 | 
				
			||||||
	if !tableDelimRegexp.Match(line) {
 | 
						if !isTableDelim(line) {
 | 
				
			||||||
		return nil
 | 
							return nil
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	cols := bytes.Split(line, []byte{'|'})
 | 
						cols := bytes.Split(line, []byte{'|'})
 | 
				
			||||||
| 
						 | 
					@ -131,16 +246,16 @@ func (b *tableParagraphTransformer) parseDelimiter(segment text.Segment, reader
 | 
				
			||||||
// TableHTMLRenderer is a renderer.NodeRenderer implementation that
 | 
					// TableHTMLRenderer is a renderer.NodeRenderer implementation that
 | 
				
			||||||
// renders Table nodes.
 | 
					// renders Table nodes.
 | 
				
			||||||
type TableHTMLRenderer struct {
 | 
					type TableHTMLRenderer struct {
 | 
				
			||||||
	html.Config
 | 
						TableConfig
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// NewTableHTMLRenderer returns a new TableHTMLRenderer.
 | 
					// NewTableHTMLRenderer returns a new TableHTMLRenderer.
 | 
				
			||||||
func NewTableHTMLRenderer(opts ...html.Option) renderer.NodeRenderer {
 | 
					func NewTableHTMLRenderer(opts ...TableOption) renderer.NodeRenderer {
 | 
				
			||||||
	r := &TableHTMLRenderer{
 | 
						r := &TableHTMLRenderer{
 | 
				
			||||||
		Config: html.NewConfig(),
 | 
							TableConfig: NewTableConfig(),
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	for _, opt := range opts {
 | 
						for _, opt := range opts {
 | 
				
			||||||
		opt.SetHTMLOption(&r.Config)
 | 
							opt.SetTableOption(&r.TableConfig)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	return r
 | 
						return r
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -281,14 +396,33 @@ func (r *TableHTMLRenderer) renderTableCell(w util.BufWriter, source []byte, nod
 | 
				
			||||||
		tag = "th"
 | 
							tag = "th"
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if entering {
 | 
						if entering {
 | 
				
			||||||
		align := ""
 | 
							fmt.Fprintf(w, "<%s", tag)
 | 
				
			||||||
		if n.Alignment != ast.AlignNone {
 | 
							if n.Alignment != ast.AlignNone {
 | 
				
			||||||
			if _, ok := n.AttributeString("align"); !ok { // Skip align render if overridden
 | 
								amethod := r.TableConfig.TableCellAlignMethod
 | 
				
			||||||
				// TODO: "align" is deprecated. style="text-align:%s" instead?
 | 
								if amethod == TableCellAlignDefault {
 | 
				
			||||||
				align = fmt.Sprintf(` align="%s"`, n.Alignment.String())
 | 
									if r.Config.XHTML {
 | 
				
			||||||
 | 
										amethod = TableCellAlignAttribute
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										amethod = TableCellAlignStyle
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								switch amethod {
 | 
				
			||||||
 | 
								case TableCellAlignAttribute:
 | 
				
			||||||
 | 
									if _, ok := n.AttributeString("align"); !ok { // Skip align render if overridden
 | 
				
			||||||
 | 
										fmt.Fprintf(w, ` align="%s"`, n.Alignment.String())
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								case TableCellAlignStyle:
 | 
				
			||||||
 | 
									v, ok := n.AttributeString("style")
 | 
				
			||||||
 | 
									var cob util.CopyOnWriteBuffer
 | 
				
			||||||
 | 
									if ok {
 | 
				
			||||||
 | 
										cob = util.NewCopyOnWriteBuffer(v.([]byte))
 | 
				
			||||||
 | 
										cob.AppendByte(';')
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
									style := fmt.Sprintf("text-align:%s", n.Alignment.String())
 | 
				
			||||||
 | 
									cob.Append(util.StringToReadOnlyBytes(style))
 | 
				
			||||||
 | 
									n.SetAttributeString("style", cob.Bytes())
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		fmt.Fprintf(w, "<%s", tag)
 | 
					 | 
				
			||||||
		if n.Attributes() != nil {
 | 
							if n.Attributes() != nil {
 | 
				
			||||||
			if tag == "td" {
 | 
								if tag == "td" {
 | 
				
			||||||
				html.RenderAttributes(w, n, TableTdCellAttributeFilter) // <td>
 | 
									html.RenderAttributes(w, n, TableTdCellAttributeFilter) // <td>
 | 
				
			||||||
| 
						 | 
					@ -296,7 +430,7 @@ func (r *TableHTMLRenderer) renderTableCell(w util.BufWriter, source []byte, nod
 | 
				
			||||||
				html.RenderAttributes(w, n, TableThCellAttributeFilter) // <th>
 | 
									html.RenderAttributes(w, n, TableThCellAttributeFilter) // <th>
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		fmt.Fprintf(w, "%s>", align)
 | 
							_ = w.WriteByte('>')
 | 
				
			||||||
	} else {
 | 
						} else {
 | 
				
			||||||
		fmt.Fprintf(w, "</%s>\n", tag)
 | 
							fmt.Fprintf(w, "</%s>\n", tag)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					@ -304,16 +438,26 @@ func (r *TableHTMLRenderer) renderTableCell(w util.BufWriter, source []byte, nod
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type table struct {
 | 
					type table struct {
 | 
				
			||||||
 | 
						options []TableOption
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Table is an extension that allow you to use GFM tables .
 | 
					// Table is an extension that allow you to use GFM tables .
 | 
				
			||||||
var Table = &table{}
 | 
					var Table = &table{
 | 
				
			||||||
 | 
						options: []TableOption{},
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// NewTable returns a new extension with given options.
 | 
				
			||||||
 | 
					func NewTable(opts ...TableOption) goldmark.Extender {
 | 
				
			||||||
 | 
						return &table{
 | 
				
			||||||
 | 
							options: opts,
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (e *table) Extend(m goldmark.Markdown) {
 | 
					func (e *table) Extend(m goldmark.Markdown) {
 | 
				
			||||||
	m.Parser().AddOptions(parser.WithParagraphTransformers(
 | 
						m.Parser().AddOptions(parser.WithParagraphTransformers(
 | 
				
			||||||
		util.Prioritized(NewTableParagraphTransformer(), 200),
 | 
							util.Prioritized(NewTableParagraphTransformer(), 200),
 | 
				
			||||||
	))
 | 
						))
 | 
				
			||||||
	m.Renderer().AddOptions(renderer.WithNodeRenderers(
 | 
						m.Renderer().AddOptions(renderer.WithNodeRenderers(
 | 
				
			||||||
		util.Prioritized(NewTableHTMLRenderer(), 500),
 | 
							util.Prioritized(NewTableHTMLRenderer(e.options...), 500),
 | 
				
			||||||
	))
 | 
						))
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										2
									
								
								vendor/github.com/yuin/goldmark/extension/typographer.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/yuin/goldmark/extension/typographer.go
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -223,7 +223,7 @@ func (s *typographerParser) Parse(parent gast.Node, block text.Reader, pc parser
 | 
				
			||||||
					if len(line) > 4 {
 | 
										if len(line) > 4 {
 | 
				
			||||||
						after = util.ToRune(line, 4)
 | 
											after = util.ToRune(line, 4)
 | 
				
			||||||
					}
 | 
										}
 | 
				
			||||||
					if len(line) == 3 || unicode.IsSpace(after) || unicode.IsPunct(after) {
 | 
										if len(line) == 3 || util.IsSpaceRune(after) || util.IsPunctRune(after) {
 | 
				
			||||||
						node := gast.NewString(s.Substitutions[Apostrophe])
 | 
											node := gast.NewString(s.Substitutions[Apostrophe])
 | 
				
			||||||
						node.SetCode(true)
 | 
											node.SetCode(true)
 | 
				
			||||||
						block.Advance(1)
 | 
											block.Advance(1)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										9
									
								
								vendor/github.com/yuin/goldmark/parser/delimiter.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								vendor/github.com/yuin/goldmark/parser/delimiter.go
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -3,7 +3,6 @@ package parser
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
	"unicode"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/yuin/goldmark/ast"
 | 
						"github.com/yuin/goldmark/ast"
 | 
				
			||||||
	"github.com/yuin/goldmark/text"
 | 
						"github.com/yuin/goldmark/text"
 | 
				
			||||||
| 
						 | 
					@ -128,10 +127,10 @@ func ScanDelimiter(line []byte, before rune, min int, processor DelimiterProcess
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		canOpen, canClose := false, false
 | 
							canOpen, canClose := false, false
 | 
				
			||||||
		beforeIsPunctuation := unicode.IsPunct(before)
 | 
							beforeIsPunctuation := util.IsPunctRune(before)
 | 
				
			||||||
		beforeIsWhitespace := unicode.IsSpace(before)
 | 
							beforeIsWhitespace := util.IsSpaceRune(before)
 | 
				
			||||||
		afterIsPunctuation := unicode.IsPunct(after)
 | 
							afterIsPunctuation := util.IsPunctRune(after)
 | 
				
			||||||
		afterIsWhitespace := unicode.IsSpace(after)
 | 
							afterIsWhitespace := util.IsSpaceRune(after)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		isLeft := !afterIsWhitespace &&
 | 
							isLeft := !afterIsWhitespace &&
 | 
				
			||||||
			(!afterIsPunctuation || beforeIsWhitespace || beforeIsPunctuation)
 | 
								(!afterIsPunctuation || beforeIsWhitespace || beforeIsPunctuation)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										2
									
								
								vendor/github.com/yuin/goldmark/renderer/html/html.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/github.com/yuin/goldmark/renderer/html/html.go
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -564,7 +564,7 @@ func (r *Renderer) renderImage(w util.BufWriter, source []byte, node ast.Node, e
 | 
				
			||||||
		_, _ = w.Write(util.EscapeHTML(util.URLEscape(n.Destination, true)))
 | 
							_, _ = w.Write(util.EscapeHTML(util.URLEscape(n.Destination, true)))
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	_, _ = w.WriteString(`" alt="`)
 | 
						_, _ = w.WriteString(`" alt="`)
 | 
				
			||||||
	_, _ = w.Write(n.Text(source))
 | 
						_, _ = w.Write(util.EscapeHTML(n.Text(source)))
 | 
				
			||||||
	_ = w.WriteByte('"')
 | 
						_ = w.WriteByte('"')
 | 
				
			||||||
	if n.Title != nil {
 | 
						if n.Title != nil {
 | 
				
			||||||
		_, _ = w.WriteString(` title="`)
 | 
							_, _ = w.WriteString(` title="`)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										37
									
								
								vendor/github.com/yuin/goldmark/util/util.go
									
										
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								vendor/github.com/yuin/goldmark/util/util.go
									
										
									
										generated
									
									
										vendored
									
									
								
							| 
						 | 
					@ -8,6 +8,7 @@ import (
 | 
				
			||||||
	"regexp"
 | 
						"regexp"
 | 
				
			||||||
	"sort"
 | 
						"sort"
 | 
				
			||||||
	"strconv"
 | 
						"strconv"
 | 
				
			||||||
 | 
						"unicode"
 | 
				
			||||||
	"unicode/utf8"
 | 
						"unicode/utf8"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -27,6 +28,7 @@ func NewCopyOnWriteBuffer(buffer []byte) CopyOnWriteBuffer {
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Write writes given bytes to the buffer.
 | 
					// Write writes given bytes to the buffer.
 | 
				
			||||||
 | 
					// Write allocate new buffer and clears it at the first time.
 | 
				
			||||||
func (b *CopyOnWriteBuffer) Write(value []byte) {
 | 
					func (b *CopyOnWriteBuffer) Write(value []byte) {
 | 
				
			||||||
	if !b.copied {
 | 
						if !b.copied {
 | 
				
			||||||
		b.buffer = make([]byte, 0, len(b.buffer)+20)
 | 
							b.buffer = make([]byte, 0, len(b.buffer)+20)
 | 
				
			||||||
| 
						 | 
					@ -35,7 +37,20 @@ func (b *CopyOnWriteBuffer) Write(value []byte) {
 | 
				
			||||||
	b.buffer = append(b.buffer, value...)
 | 
						b.buffer = append(b.buffer, value...)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Append appends given bytes to the buffer.
 | 
				
			||||||
 | 
					// Append copy buffer at the first time.
 | 
				
			||||||
 | 
					func (b *CopyOnWriteBuffer) Append(value []byte) {
 | 
				
			||||||
 | 
						if !b.copied {
 | 
				
			||||||
 | 
							tmp := make([]byte, len(b.buffer), len(b.buffer)+20)
 | 
				
			||||||
 | 
							copy(tmp, b.buffer)
 | 
				
			||||||
 | 
							b.buffer = tmp
 | 
				
			||||||
 | 
							b.copied = true
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						b.buffer = append(b.buffer, value...)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// WriteByte writes the given byte to the buffer.
 | 
					// WriteByte writes the given byte to the buffer.
 | 
				
			||||||
 | 
					// WriteByte allocate new buffer and clears it at the first time.
 | 
				
			||||||
func (b *CopyOnWriteBuffer) WriteByte(c byte) {
 | 
					func (b *CopyOnWriteBuffer) WriteByte(c byte) {
 | 
				
			||||||
	if !b.copied {
 | 
						if !b.copied {
 | 
				
			||||||
		b.buffer = make([]byte, 0, len(b.buffer)+20)
 | 
							b.buffer = make([]byte, 0, len(b.buffer)+20)
 | 
				
			||||||
| 
						 | 
					@ -44,6 +59,18 @@ func (b *CopyOnWriteBuffer) WriteByte(c byte) {
 | 
				
			||||||
	b.buffer = append(b.buffer, c)
 | 
						b.buffer = append(b.buffer, c)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// AppendByte appends given bytes to the buffer.
 | 
				
			||||||
 | 
					// AppendByte copy buffer at the first time.
 | 
				
			||||||
 | 
					func (b *CopyOnWriteBuffer) AppendByte(c byte) {
 | 
				
			||||||
 | 
						if !b.copied {
 | 
				
			||||||
 | 
							tmp := make([]byte, len(b.buffer), len(b.buffer)+20)
 | 
				
			||||||
 | 
							copy(tmp, b.buffer)
 | 
				
			||||||
 | 
							b.buffer = tmp
 | 
				
			||||||
 | 
							b.copied = true
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						b.buffer = append(b.buffer, c)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Bytes returns bytes of this buffer.
 | 
					// Bytes returns bytes of this buffer.
 | 
				
			||||||
func (b *CopyOnWriteBuffer) Bytes() []byte {
 | 
					func (b *CopyOnWriteBuffer) Bytes() []byte {
 | 
				
			||||||
	return b.buffer
 | 
						return b.buffer
 | 
				
			||||||
| 
						 | 
					@ -777,11 +804,21 @@ func IsPunct(c byte) bool {
 | 
				
			||||||
	return punctTable[c] == 1
 | 
						return punctTable[c] == 1
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// IsPunct returns true if the given rune is a punctuation, otherwise false.
 | 
				
			||||||
 | 
					func IsPunctRune(r rune) bool {
 | 
				
			||||||
 | 
						return int32(r) <= 256 && IsPunct(byte(r)) || unicode.IsPunct(r)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// IsSpace returns true if the given character is a space, otherwise false.
 | 
					// IsSpace returns true if the given character is a space, otherwise false.
 | 
				
			||||||
func IsSpace(c byte) bool {
 | 
					func IsSpace(c byte) bool {
 | 
				
			||||||
	return spaceTable[c] == 1
 | 
						return spaceTable[c] == 1
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// IsSpace returns true if the given rune is a space, otherwise false.
 | 
				
			||||||
 | 
					func IsSpaceRune(r rune) bool {
 | 
				
			||||||
 | 
						return int32(r) <= 256 && IsSpace(byte(r)) || unicode.IsSpace(r)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// IsNumeric returns true if the given character is a numeric, otherwise false.
 | 
					// IsNumeric returns true if the given character is a numeric, otherwise false.
 | 
				
			||||||
func IsNumeric(c byte) bool {
 | 
					func IsNumeric(c byte) bool {
 | 
				
			||||||
	return c >= '0' && c <= '9'
 | 
						return c >= '0' && c <= '9'
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										2
									
								
								vendor/modules.txt
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/modules.txt
									
										
									
									
										vendored
									
									
								
							| 
						 | 
					@ -715,7 +715,7 @@ github.com/xi2/xz
 | 
				
			||||||
# github.com/yohcop/openid-go v1.0.0
 | 
					# github.com/yohcop/openid-go v1.0.0
 | 
				
			||||||
## explicit
 | 
					## explicit
 | 
				
			||||||
github.com/yohcop/openid-go
 | 
					github.com/yohcop/openid-go
 | 
				
			||||||
# github.com/yuin/goldmark v1.1.32
 | 
					# github.com/yuin/goldmark v1.2.1
 | 
				
			||||||
## explicit
 | 
					## explicit
 | 
				
			||||||
github.com/yuin/goldmark
 | 
					github.com/yuin/goldmark
 | 
				
			||||||
github.com/yuin/goldmark/ast
 | 
					github.com/yuin/goldmark/ast
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue