Commit 043e0004 authored by Henrique Dias's avatar Henrique Dias

Merge pull request #1 from mholt/master

Update
parents 4c642e9d 66fb8f03
...@@ -131,6 +131,40 @@ func (c Context) Truncate(input string, length int) string { ...@@ -131,6 +131,40 @@ func (c Context) Truncate(input string, length int) string {
return input return input
} }
// StripHTML returns s without HTML tags. It is fairly naive
// but works with most valid HTML inputs.
func (c Context) StripHTML(s string) string {
var buf bytes.Buffer
var inTag, inQuotes bool
var tagStart int
for i, ch := range s {
if inTag {
if ch == '>' && !inQuotes {
inTag = false
} else if ch == '<' && !inQuotes {
// false start
buf.WriteString(s[tagStart:i])
tagStart = i
} else if ch == '"' {
inQuotes = !inQuotes
}
continue
}
if ch == '<' {
inTag = true
tagStart = i
continue
}
buf.WriteRune(ch)
}
if inTag {
// false start
buf.WriteString(s[tagStart:])
inTag = false
}
return buf.String()
}
// StripExt returns the input string without the extension, // StripExt returns the input string without the extension,
// which is the suffix starting with the final '.' character // which is the suffix starting with the final '.' character
// but not before the final path separator ('/') character. // but not before the final path separator ('/') character.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment