49 lines
950 B
Sed
49 lines
950 B
Sed
# $NetBSD: nanpa.sed,v 1.1 2003/03/03 01:13:36 jhawk Exp $
|
|
#
|
|
# Parse HTML tables output by
|
|
# http://docs.nanpa.com/cgi-bin/npa_reports/nanpa
|
|
# Specifically, for each html table row (TR),
|
|
# print the <TD> elements seperated by colons.
|
|
#
|
|
# This could break on HTML comments.
|
|
#
|
|
:top
|
|
# Strip ^Ms
|
|
s/
|
|
//g
|
|
# Join all lines with unterminated HTML tags
|
|
/<[^>]*$/{
|
|
N
|
|
b top
|
|
}
|
|
# Replace all </TR> with EOL tag
|
|
s;</[Tt][Rr]>;$;g
|
|
# Join lines with only <TR>.
|
|
/<[Tt][Rr][^>]*>$/{
|
|
N
|
|
s/\n//g
|
|
b top
|
|
}
|
|
# Also, join all lines starting with <TR>.
|
|
/<[TtRr][^>]*>[^$]*$/{
|
|
N
|
|
s/\n//g
|
|
b top
|
|
}
|
|
# Remove EOL markers
|
|
s/\$$//
|
|
# Remove lines not starting with <TR>
|
|
/<[Tt][Rr][^>]*>/!d
|
|
# Replace all <TD> with colon
|
|
s/[ ]*<TD[^>]*> */:/g
|
|
# Strip all HTML tags
|
|
s/<[^>]*>//g
|
|
# Handle HTML characters
|
|
s/ / /g
|
|
# Compress spaces/tabs
|
|
s/[ ][ ]*/ /g
|
|
# Strip leading colons
|
|
s/^://
|
|
# Strip leading/trailing whitespace
|
|
s/^ //
|
|
s/ $//
|