#!/bin/bash
dir='/srv/arch-mirror/arch/arch/archlinux32/irc-logs/#archlinux-ports/'
declare -A colors
create_color() {
if [ -z "${colors["$1"]}" ]; then
colors["$1"]=$(
find "${dir}" -type f -name '*-*-*.html' -exec \
grep -h "style=\"color:#[0-9a-f]\{6\}\"><$1>" {} \; | \
sed 's@.* style="color:#\([0-9a-f]\{6\}\)"><.*@\1@' | \
sort -u
)
fi
if [ -z "${colors["$1"]}" ]; then
colors["${b}"]=$(hexdump -n 4 -e '4/4 "%08X" 1 "\n"' /dev/urandom | head -c 6)
# >&2 printf 'unkown user "%s"\n' "$1"
# exit 42
fi
if [ $(echo "${colors["$1"]}" | wc -l) -ne 1 ]; then
>&2 printf 'user "%s" has multiple colors\n' "$1"
exit 42
fi
}
if [ "$1" = 'html' ]; then
shift
sed -n '
/^/{
s@^(\([^)]\+\)) @\1 @
/entered the room\.<\/b>
$/{
s@^\(\S\+\) \(.*\S\) \[.*] entered the room\.<\/b>
$@\1 --> | \2 has joined #archlinux-ports @
p
d
}
/ left the room /{
s@^\(\S\+\) \(.*\S\) left the room (quit: \(.*\))\.
$@\1 <-- | \2 has quit (\3)@
p
d
}
/ left the room\./{
s@^\(\S\+\) \(.*\S\) left the room\.
$@\1 <-- | \2 has quit (Quit: \2)@
p
d
}
/ is now known as /{
s@^\(\S\+\) \(.*\S\)\s*
$@\1 -- | \2@
p
d
}
d
}
\@ \*\*\*\S\+ @{
s@^(\([^)]\+\)) \*\*\*\(\S*\) \(.*\)
$@\1 * | \2 \3@
p
d
}
//{
s@^(\([^)]\+\)) \(\S\+\): @\1 \2 | @
s@
$@@
p
d
}
'
else
sed '
s/([^()]*@[^()]*) //
'
cat
fi | \
sed '
:a
$!N
s/\n\s\+ | / /
ta
P
D
' | \
while read -r a b dummy c; do
if [ "${dummy}" != '|' ]; then
>&2 printf 'wrong dummy "%s"\n' "${dummy}"
exit 42
fi
time=$(
date -d@$(($(date -d"${a}" +%s)+3600*$2)) +%T
)
if [ "${b}" = '-->' ]; then
name="${c%% *}"
channel="${c##* }"
printf '[%s] -!- %s has joined %s\n
\n' \
"${time}" "${time}" "${time}" "${name}" "${channel}"
continue
fi
if [ "${b}" = '<--' ]; then
name="${c%% *}"
reason="${c##* (}"
reason="${reason%)*}"
printf '[%s] -!- %s has quit [%s]\n
\n' \
"${time}" "${time}" "${time}" "${name}" "${reason}"
continue
fi
if [ "${b}" = '--' ]; then
before="${c%% *}"
after="${c##* }"
printf '[%s] %s is now known as %s\n
\n' \
"${time}" "${time}" "${time}" "${before}" "${after}"
continue
fi
if [ "${b}" = '*' ]; then
nick="${c%% *}"
action="${c#* }"
create_color "${nick}"
printf '[%s] * %s %s\n
\n' \
"${time}" "${time}" "${time}" "${colors["${nick}"]}" "${nick}" "${action}"
continue
fi
create_color "${b}"
printf '[%s] <%s> %s\n
\n' \
"${time}" "${time}" "${time}" "${colors["${b}"]}" "${b}" "${c}"
done