1
0
mirror of https://github.com/ericchiang/pup synced 2025-01-28 08:31:26 +00:00

allow preservation of preformatted text

This commit is contained in:
Eric Chiang 2015-04-05 15:02:03 -04:00
parent db016ce23c
commit 0b21bd0bc8
2 changed files with 58 additions and 0 deletions

View File

@ -66,6 +66,54 @@ func (t TreeDisplayer) Display(nodes []*html.Node) {
} }
} }
// The <pre> tag indicates that the text within it should always be formatted
// as is. See https://github.com/ericchiang/pup/issues/33
func (t TreeDisplayer) printPre(n *html.Node) {
switch n.Type {
case html.TextNode:
s := n.Data
if pupEscapeHTML {
// don't escape javascript
if n.Parent == nil || n.Parent.DataAtom != atom.Script {
s = html.EscapeString(s)
}
}
fmt.Print(s)
for c := n.FirstChild; c != nil; c = c.NextSibling {
t.printPre(c)
}
case html.ElementNode:
fmt.Printf("<%s", n.Data)
for _, a := range n.Attr {
val := a.Val
if pupEscapeHTML {
val = html.EscapeString(val)
}
fmt.Printf(` %s="%s"`, a.Key, val)
}
fmt.Print(">")
if !isVoidElement(n) {
for c := n.FirstChild; c != nil; c = c.NextSibling {
t.printPre(c)
}
fmt.Printf("</%s>", n.Data)
}
case html.CommentNode:
data := n.Data
if pupEscapeHTML {
data = html.EscapeString(data)
}
fmt.Printf("<!--%s-->\n", data)
for c := n.FirstChild; c != nil; c = c.NextSibling {
t.printPre(c)
}
case html.DoctypeNode, html.DocumentNode:
for c := n.FirstChild; c != nil; c = c.NextSibling {
t.printPre(c)
}
}
}
// Print a node and all of it's children to `maxlevel`. // Print a node and all of it's children to `maxlevel`.
func (t TreeDisplayer) printNode(n *html.Node, level int) { func (t TreeDisplayer) printNode(n *html.Node, level int) {
switch n.Type { switch n.Type {
@ -84,6 +132,12 @@ func (t TreeDisplayer) printNode(n *html.Node, level int) {
} }
case html.ElementNode: case html.ElementNode:
t.printIndent(level) t.printIndent(level)
// TODO: allow pre with color
if n.DataAtom == atom.Pre && !pupPrintColor && pupPreformatted {
t.printPre(n)
fmt.Println()
return
}
if pupPrintColor { if pupPrintColor {
tokenColor.Print("<") tokenColor.Print("<")
tagColor.Printf("%s", n.Data) tagColor.Printf("%s", n.Data)

View File

@ -16,6 +16,7 @@ var (
pupIn io.ReadCloser = os.Stdin pupIn io.ReadCloser = os.Stdin
pupCharset string = "" pupCharset string = ""
pupMaxPrintLevel int = -1 pupMaxPrintLevel int = -1
pupPreformatted bool = false
pupPrintColor bool = false pupPrintColor bool = false
pupEscapeHTML bool = true pupEscapeHTML bool = true
pupIndentString string = " " pupIndentString string = " "
@ -55,6 +56,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
--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
` `
@ -87,6 +89,8 @@ func ProcessFlags(cmds []string) (nonFlagCmds []string, err error) {
pupPrintColor = true pupPrintColor = true
case "-p", "--plain": case "-p", "--plain":
pupEscapeHTML = false pupEscapeHTML = false
case "--pre":
pupPreformatted = true
case "-f", "--file": case "-f", "--file":
filename := cmds[i+1] filename := cmds[i+1]
pupIn, err = os.Open(filename) pupIn, err = os.Open(filename)