1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-29 01:59:41 +02:00
documize/vendor/github.com/documize/html-diff/pos.go
2016-11-30 17:56:36 -08:00

47 lines
1,017 B
Go

package htmldiff
import "golang.org/x/net/html"
// posTT gives the relative position within one level of a nested container.
type posTT struct {
nodesBefore int
node *html.Node
}
// posT gives the relative position within a nested set of containers.
type posT []posTT
// getPos returns the relative posion of this node within the enclosing containers, if there are any.
func getPos(n *html.Node) posT {
if n == nil {
return nil
}
depth := 0
for root := n; inContainer(root); root = root.Parent {
depth++
}
ret := make([]posTT, 0, depth) // for speed
for root := n; depth > 0; root = root.Parent {
var before int
for sib := root.Parent.FirstChild; sib != root; sib = sib.NextSibling {
if sib.Type == html.ElementNode {
before++
}
}
ret = append(ret, posTT{before, root})
depth--
}
return ret
}
func posEqual(a, b posT) bool {
if len(a) != len(b) {
return false
}
for i, aa := range a {
if aa.nodesBefore != b[i].nodesBefore {
return false
}
}
return true
}