1
0
mirror of https://github.com/ericchiang/pup synced 2025-01-15 10:11:16 +00:00

Implement --invert to remove tags matching selector.

This commit is contained in:
Wolfgang Faust 2017-08-26 13:54:53 -04:00
parent 3b0097e9ed
commit be5dee7868
4 changed files with 35 additions and 1 deletions

View File

@ -19,6 +19,7 @@ var (
pupPreformatted bool = false pupPreformatted bool = false
pupPrintColor bool = false pupPrintColor bool = false
pupEscapeHTML bool = true pupEscapeHTML bool = true
pupInvertSelect bool = false
pupIndentString string = " " pupIndentString string = " "
pupDisplayer Displayer = TreeDisplayer{} pupDisplayer Displayer = TreeDisplayer{}
) )
@ -56,6 +57,7 @@ Flags
-n --number print number of elements selected -n --number print number of elements selected
-l --limit restrict number of levels printed -l --limit restrict number of levels printed
-p --plain don't escape html -p --plain don't escape html
-v --invert invert selection (remove matching elements)
--pre preserve preformatted text --pre preserve preformatted text
--charset specify the charset for pup to use --charset specify the charset for pup to use
--version display version --version display version
@ -89,6 +91,8 @@ func ProcessFlags(cmds []string) (nonFlagCmds []string, err error) {
pupPrintColor = true pupPrintColor = true
case "-p", "--plain": case "-p", "--plain":
pupEscapeHTML = false pupEscapeHTML = false
case "-v", "--invert":
pupInvertSelect = true
case "--pre": case "--pre":
pupPreformatted = true pupPreformatted = true
case "-f", "--file": case "-f", "--file":

28
pup.go
View File

@ -76,5 +76,33 @@ func main() {
} }
} }
selectedNodes = append(selectedNodes, currNodes...) selectedNodes = append(selectedNodes, currNodes...)
if pupInvertSelect {
RemoveInverseMatches(root, selectedNodes)
pupDisplayer.Display([]*html.Node{root})
} else {
pupDisplayer.Display(selectedNodes) pupDisplayer.Display(selectedNodes)
} }
}
func RemoveInverseMatches(root *html.Node, selectedNodes []*html.Node) {
var remove []*html.Node
for node := root.FirstChild; node != nil; node = node.NextSibling {
if HtmlNodeInList(node, selectedNodes) {
remove = append(remove, node)
} else {
RemoveInverseMatches(node, selectedNodes)
}
}
for _, rm := range remove {
root.RemoveChild(rm)
}
}
func HtmlNodeInList(a *html.Node, list []*html.Node) bool {
for _, b := range list {
if b == a {
return true
}
}
return false
}

View File

@ -47,3 +47,4 @@ link , a:parent-of(sup)
link , a:parent-of(sup) sup link , a:parent-of(sup) sup
li --number li --number
li -n li -n
li a --invert

View File

@ -47,3 +47,4 @@ b6a3d6cccd305fcc3e8bf2743c443743bdaaa02b link , a:parent-of(sup)
0d1f66765d1632c70f8608947890524e78459362 link , a:parent-of(sup) sup 0d1f66765d1632c70f8608947890524e78459362 link , a:parent-of(sup) sup
d200756078ef79d77fb17848c5f15b85bcea7e00 li --number d200756078ef79d77fb17848c5f15b85bcea7e00 li --number
d200756078ef79d77fb17848c5f15b85bcea7e00 li -n d200756078ef79d77fb17848c5f15b85bcea7e00 li -n
1fa074385374bcd613394678b5e08ed1ad4d5d9d li a --invert