#!/bin/sh # $FreeBSD$ # # Read a single errorlogfile and output a line of the format # $filename|$portname|$affected|$logsize|$dir|$maintainer|\ # $reason|$tag|$broken|$datetime # # Originally factored out of: ports/Tools/portbuild/scripts/processlogs filename=$1 indexdir=. errordir=. if [ "$2" != "" ]; then indexdir=$2; fi if [ "$3" != "" ]; then errordir=$3; fi indexdir=$(realpath $indexdir) errordir=$(realpath $errordir) indexfilename=$indexdir/INDEX portname=$(basename $filename .log) affected=$(($(grep -cF $portname < $indexfilename) -1)) logsize=$(/bin/ls -sk $errordir/$filename | awk '{print $1}') dir=$(sed -n -e '3p' $errordir/$filename | grep '^with arguments' | awk '{print $4}' | \ sed -e 's,^/[^/]*/[^/]*/,,') maintainer=$(sed -n -e '4p' $errordir/$filename | grep '^maintained by' | awk '{print $3}') datetime=$(sed -n -e '5p' $errordir/$filename | grep '^build started at' | \ sed -e 's/build started at ...//' | tr ' ' '_' ) # now try to classify the type of error found in the file. # the first case handles failures to even try to build any # port (i.e. HTML file no longer there, bento being unable # to fetch any file, bento being able to build any port, etc.) if [ -z "$dir" -o -z "$datetime" ]; then reason="cluster"; tag="cluster" elif grep -q 'list of extra files and directories' $1; then reason="mtree"; tag="mtree" elif grep -q "See for instructions." $1; then reason="gcc_bug"; tag="gcc-bug" elif grep -q "See for instructions." $1; then reason="gcc_bug"; tag="gcc-bug" elif grep -q 'Checksum mismatch' $1; then reason="checksum"; tag="checksum" elif grep -qE '/usr/local/bin/(perl|perl5.6.1):.*(not found|No such file or directory)' $1; then reason="perl"; tag="perl" elif grep -qE 'perl(.*): Perl is not installed, try .pkg_add -r perl.' $1; then reason="perl"; tag="perl" elif grep -q 'cannot find -lc_r' $1; then reason="threads"; tag="threads" elif grep -q "checking for.*lc_r\.\.\. no" $1; then reason="threads"; tag="threads" elif grep -qE '(No checksum recorded for|(Maybe|Either) .* is out of date, or)' $1; then reason="distinfo_update"; tag="distinfo" elif grep -q "checking whether apxs works.*apxs: not found" $1; then reason="apxs"; tag="apxs" # note: must run before the configure_error check elif grep -qE "Configuration .* not supported" $1; then reason="arch"; tag="arch" elif grep -qE '(configure: error:|Script.*configure.*failed unexpectedly|script.*failed: here are the contents of)' $1; then if grep -qE "configure: error: cpu .* not supported" $1; then reason="arch"; tag="arch" elif grep -qE "configure: error: (This program requires STL to compile|One or more.*STL headers are missing)" $1; then reason="stl"; tag="stl" elif grep -qE "configure: error: [Pp]erl (5.* required|version too old)" $1; then reason="perl"; tag="perl" else reason="configure_error"; tag="configure" fi elif grep -qE '(bison:.*(No such file|not found)|multiple definition of `yy)' $1; then reason="bison"; tag="bison" elif grep -q "Couldn't fetch it - please try" $1; then reason="fetch"; tag="fetch" elif grep -q "out of .* hunks .*--saving rejects to" $1; then reason="patch"; tag="patch" elif grep -q 'Error: category .* not in list of valid categories' $1; then reason="CATEGORIES"; tag="categories" elif grep -q 'make: don.t know how to make .*\.man. Stop' $1; then reason="X_manpage"; tag="xfree4man" elif grep -q 'Xm/Xm\.h: No such file' $1; then reason="MOTIF"; tag="motif" elif grep -q 'undefined reference to `Xp' $1; then reason="MOTIFLIB"; tag="motiflib" elif grep -qi 'read-only file system' $1; then reason="WRKDIR"; tag="wrkdir" elif grep -q 'makeinfo: .* use --force' $1; then reason="texinfo"; tag="texinfo" elif grep -q 'means that you did not run the h2ph script' $1; then reason="perl5"; tag="perl5" elif grep -q "Error: shared library \".*\" does not exist" $1; then reason="LIB_DEPENDS"; tag="libdepends" elif grep -qE "(crt0|c\+\+rt0)\.o: No such file" $1; then reason="ELF"; tag="elf" elif grep -q "machine/soundcard.h: No such file or directory" $1; then reason="soundcard.h"; tag="soundcard.h" elif grep -q "values.h: No such file or directory" $1; then reason="values.h"; tag="values.h" elif grep -q ".*\.h: No such file" $1; then if grep -qE "(X11/.*|Xosdefs)\.h: No such file" $1; then if grep -q "XFree86-.*\.tgz" $1; then reason="missing_header"; tag="header" else reason="USE_XLIB"; tag="usexlib" fi else reason="missing_header"; tag="header" fi elif grep -q "pnohang: killing make checksum" $1; then reason="fetch_timeout"; tag="fetch-timeout" elif grep -q "USER PID PPID PGID JOBC STAT TT TIME COMMAND" $1; then reason="runaway_process"; tag="runaway" elif grep -q "pnohang: killing make package" $1; then reason="runaway_process"; tag="runaway" elif grep -qE "pkg_add: (can't find enough temporary space|projected size of .* exceeds available free space)" $1; then reason="disk_full"; tag="df" elif grep -qE '(parse error|too (many|few) arguments to|argument.*doesn.*prototype|incompatible type for argument|conflicting types for|undeclared \(first use (in |)this function\)|incorrect number of parameters|has incomplete type and cannot be initialized)' $1; then reason="compiler_error"; tag="cc" elif grep -qE '(ANSI C.. forbids|is a contravariance violation|changed for new ANSI .for. scoping|[0-9]: passing .* changes signedness|discards qualifiers|lacks a cast|redeclared as different kind of symbol|invalid type .* for default argument to|wrong type argument to unary exclamation mark|duplicate explicit instantiation of|incompatible types in assignment|assuming . on overloaded member function|call of overloaded .* is ambiguous|declaration of C function .* conflicts with|initialization of non-const reference type|using typedef-name .* after|[0-9]: implicit declaration of function|[0-9]: size of array .* is too large|fixed or forbidden register .* for class)' $1; then reason="new_compiler_error"; tag="newgcc" elif grep -qE '(syntax error before|ISO C\+\+ forbids|friend declaration|no matching function for call to|.main. must return .int.|invalid conversion from|cannot be used as a macro name as it is an operator in C\+\+|is not a member of type|after previous specification in|no class template named|because worst conversion for the former|better than worst conversion|no match for.*operator|no match for call to|undeclared in namespace|is used as a type, but is not)' $1; then reason="bad_C++_code"; tag="badc++" elif grep -qE '(/usr/libexec/elf/ld: cannot find|undefined reference to|cannot open -l.*: No such file)' $1; then reason="linker_error"; tag="ld" elif grep -qE 'chown:.*[Ii]nvalid argument' $1; then reason="chown"; tag="chown" #elif grep -qE 'cp:.*Invalid argument' $1; then # reason="munmap"; tag="munmap" elif grep -q 'install: .*: No such file' $1; then if grep -q 'install: /usr/local/www/cgi-bin.*No such file or directory' $1; then reason="cgi-bin"; tag="cgi-bin" else reason="install_error"; tag="install" fi elif grep -q "/usr/.*/man/.*: No such file or directory" $1; then reason="manpage"; tag="manpage" elif grep -qE "(Can't|unable to) open display" $1; then reason="DISPLAY"; tag="display" elif grep -q " is already installed - perhaps an older version" $1; then reason="depend_object"; tag="dependobj" elif grep -q "You may wish to ..make deinstall.. and install this port again" $1; then reason="depend_object"; tag="dependobj" elif grep -q "error in dependency .*, exiting" $1; then reason="depend_package"; tag="dependpkg" elif grep -q "#error \" has been replaced by \"" $1; then reason="malloc.h"; tag="malloc.h" elif grep -q "core dumped" $1; then reason="coredump"; tag="coredump" elif grep -q "Segmentation fault" $1; then reason="segfault"; tag="segfault" elif egrep -q "storage size of.*isn't known" $1; then reason="union_wait"; tag="wait" elif grep -q "initializer element is not constant" $1; then reason="stdio"; tag="stdio" elif grep -q "structure has no member named" $1; then reason="struct_changes"; tag="struct" elif grep -q "Error: alignment not a power of 2" $1; then reason="alignment"; tag="alignment" elif grep -qE "bin.apxs:(.)(not found|No such file or directory)" $1; then reason="apxs"; tag="apxs" elif grep -qE "failed to exec .*bin/apxs" $1; then reason="apxs"; tag="apxs" elif grep -q ".s: Assembler messages:" $1; then reason="arch"; tag="arch" elif grep -qE "Cannot (determine .* target|find the byte order) for this architecture" $1; then reason="arch"; tag="arch" elif grep -q "cast from pointer to integer of different size" $1; then reason="arch"; tag="arch" elif grep -qE "^cc1: bad value.*for -mcpu.*switch" $1; then reason="arch"; tag="arch" elif grep -qE "^cc1: invalid option " $1; then reason="arch"; tag="arch" elif grep -q "could not read symbols: File in wrong format" $1; then reason="arch"; tag="arch" elif grep -qE "[Ee]rror: [Uu]nknown opcode" $1; then reason="arch"; tag="arch" elif grep -qE "error.*Unsupported architecture" $1; then reason="arch"; tag="arch" elif grep -q "ENDIAN must be defined 0 or 1" $1; then reason="arch"; tag="arch" elif grep -q "failed to merge target-specific data" $1; then reason="arch"; tag="arch" elif grep -qE "(file not recognized|failed to set dynamic section sizes): File format not recognized" $1; then reason="arch"; tag="arch" elif grep -q "impossible register constraint" $1; then reason="arch"; tag="arch" elif grep -qE "inconsistent operand constraints in an .asm" $1; then reason="arch"; tag="arch" elif grep -q "invalid lvalue in asm statement" $1; then reason="arch"; tag="arch" elif grep -qE "is only for.*, and you are running" $1; then reason="arch"; tag="arch" elif grep -q "not a valid 64 bit base/index expression" $1; then reason="arch"; tag="arch" elif grep -qE "relocation R_X86_64_32.*can not be used when making a shared object" $1; then reason="arch"; tag="arch" elif grep -q "relocation truncated to fit: " $1; then reason="arch"; tag="arch" elif grep -qE "The target cpu, .*, is not currently supported." $1; then reason="arch"; tag="arch" elif grep -q "This architecture seems to be neither big endian nor little endian" $1; then reason="arch"; tag="arch" elif grep -q "unknown register name" $1; then reason="arch"; tag="arch" elif grep -q "Unable to correct byte order" $1; then reason="arch"; tag="arch" elif grep -q "Unsupported platform, sorry" $1; then reason="arch"; tag="arch" elif grep -q "won't run on this architecture" $1; then reason="arch"; tag="arch" elif grep -qE "#error .Cannot compile:" $1; then reason="assert"; tag="assert" elif grep -qE "autoconf(.*): not found" $1; then reason="autoconf"; tag="autoconf" elif grep -qE "autoconf(.*): No such file or directory" $1; then reason="autoconf"; tag="autoconf" elif grep -q "autoheader: not found" $1; then reason="autoheader"; tag="autoheader" elif grep -qE "automake(.*): not found" $1; then reason="automake"; tag="automake" elif grep -q "awk: empty regular expression" $1; then reason="awk"; tag="awk" elif grep -qE "(mv:|mv: rename|cannot open) y.tab.c(.*): No such file or directory" $1; then reason="bison"; tag="bison" elif grep -q "sorry, cannot determine the header file bison generates" $1; then reason="bison"; tag="bison" elif grep -q "usage: yacc" $1; then reason="bison"; tag="bison" elif grep -q "/usr/local/www/cgi-bin does not exist" $1; then reason="cgi-bin"; tag="cgi-bin" elif grep -q "Cannot open /dev/tty for read" $1; then reason="DISPLAY"; tag="display" elif grep -q "RuntimeError: cannot open display" $1; then reason="DISPLAY"; tag="display" elif grep -q "You must run this program under the X-Window System" $1; then reason="DISPLAY"; tag="display" elif grep -q "ld: unrecognised emulation mode: elf_i386" $1; then reason="ELF"; tag="elf" elif grep -qE "Member name contains .\.\." $1; then reason="fetch"; tag="fetch" elif grep -q "fetch: transfer timed out" $1; then reason="fetch_timeout"; tag="fetch-timeout" elif grep -q "fetch: transfer timed out" $1; then reason="fetch_timeout"; tag="fetch-timeout" elif grep -q "strings.h:.* previous declaration of .int ffs" $1; then reason="ffs_conflict"; tag="ffs_conflict" elif grep -q "is forbidden: FreeBSD-SA-" $1; then reason="forbidden"; tag="forbidden" elif grep -q "/usr/bin/ld: cannot find -lgnugetopt" $1; then reason="getopt"; tag="getopt" elif grep -qE "previous declaration.*int getopt" $1; then reason="getopt.h"; tag="getopt.h" elif grep -q "imake: Exit code 1" $1; then reason="imake"; tag="imake" elif grep -q 'Run-time system build failed for some reason' $1; then reason="install_error"; tag="install" elif grep -q "/usr/bin/ld: cannot find -lc_r" $1; then reason="lc_r"; tag="lc_r" elif grep -q "cc: .*libintl.*: No such file or directory" $1; then reason="linker_error"; tag="ld" elif grep -qE "cc: ndbm\.so: No such file or directory" $1; then reason="linker_error"; tag="ld" elif grep -q "error: The X11 shared library could not be loaded" $1; then reason="linker_error"; tag="ld" elif grep -q "relocation against dynamic symbol" $1; then reason="linker_error"; tag="ld" elif grep -qE "make.*(don.t know how to make|fatal errors encountered|No rule to make target|built-in)" $1; then reason="makefile"; tag="makefile" elif grep -qE "Error: mtree file ./etc/mtree/BSD.local.dist. is missing" $1; then reason="mtree"; tag="mtree" elif grep -qE "cp:.*site_perl: No such file or directory" $1; then reason="perl"; tag="perl" elif grep -q "Perl .* required--this is only version" $1; then reason="perl"; tag="perl" elif grep -q "pod2man: not found" $1; then reason="pod2man"; tag="pod2man" elif grep -q "Syntax error: .(. unexpected (expecting .fi.)" $1; then reason="portcomment"; tag="portcomment" elif grep -q "Abort trap" $1; then reason="process_failed"; tag="process" elif grep -q "Bus error" $1; then reason="process_failed"; tag="process" elif grep -q "Signal 11" $1; then reason="process_failed"; tag="process" elif grep -q "python: not found" $1; then reason="python"; tag="python" elif grep -qE "sed: illegal option" $1; then reason="sed"; tag="sed" elif grep -qE "sed: [0-9]*:.*(RE error:|not defined in the RE|bad flag in substitute command|unescaped newline inside substitute pattern|invalid command code)" $1; then reason="sed"; tag="sed" elif grep -q "Your STL string implementation is unusable" $1; then reason="stl"; tag="stl" elif grep -q ': The -pthread option is deprecated' $1; then reason="threads"; tag="threads" elif grep -q "Error: pthreads are required to build this package" $1; then reason="threads"; tag="threads" elif grep -q "Please install/update your POSIX threads (pthreads) library" $1; then reason="threads"; tag="threads" elif grep -qE "requires.*thread support" $1; then reason="threads"; tag="threads" elif grep -q "/usr/bin/ld: cannot find -lpthread" $1; then reason="threads"; tag="threads" elif grep -q "/usr/bin/ld: cannot find -lXThrStub" $1; then reason="threads"; tag="threads" elif grep -q " is obsolete with this version of GCC" $1; then reason="varargs"; tag="varargs" # Although these can be fairly common, and thus in one sense ought to be # earlier in the evaluation, in practice they are most often secondary # types of errors, and thus need to be evaluated after all the specific # cases. elif grep -q "Cannot stat: " $1; then reason="configure_error"; tag="configure" elif grep -q "cd: can't cd to" $1; then reason="NFS"; tag="nfs" elif grep -q "pkg_create: make_dist: tar command failed with code" $1; then reason="PLIST"; tag="plist" else reason="???"; tag="unknown" fi # XXX MCL perhaps segfault, coredump should be unified into process failed? # clean up some error cases -- the way .logs works, it expects that # every field in it MUST be nonblank, so we insert a metatoken here. # See below. if [ -z "$dir" ]; then dir="NONE" fi if [ -z "$maintainer" ]; then maintainer="NONE" fi if [ -z "$datetime" ]; then datetime="NONE" fi broken="no" if grep -q "Trying build of .* even though it is marked BROKEN" $1; then broken="broken" fi echo "$filename|$portname|$affected|$logsize|$dir|$maintainer|$reason|$tag|$broken|$datetime"