+function eog {(unset eog; touch /tmp/eog.$$;eog "$@" {,,,,,,,,,}/tmp/eog.$$;rm -f /tmp/eog.$$; );}
+function diffc { diff -up "$@"|grep -v '^\(Only in \|Binary files\)'; }
+function diffi { diffc -X ~/.diffi.list "$@" | diffdecvs; }
+function cvs {(unset cvs
+ local _opts _opts_d _now _line _o
+ _opts_d="-d"
+ if grep -iw '\(sources.redhat.com\|sourceware.org\):/cvs/src' CVS/Root &>/dev/null;then _opts_d="";fi
+ if grep -iw '\(cvs.fedoraproject.org\):/cvs/pkgs' CVS/Root &>/dev/null;then _opts_d="";fi
+ if grep '^tests/kernel/syscalls/ptrace' CVS/Repository &>/dev/null;then _opts_d="";fi
+ _now=false
+ _line=""
+ _opts=""
+ while [ $# != 0 ];do
+ _o="$1"
+ shift
+ _line="$_line $_o"
+ if [ "$_o" = "--" ] && ! $_now;then _now=true;continue;fi
+ if [ "${_o#-}" != "$_o" ] && ! $_now;then continue;fi
+ if [ "$_o" = update -o "$_o" = upd -o "$_o" = up ];then _opts="$_opts_d";fi
+ break
+ done
+ cvs $_line $_opts "$@"
+ ); }
+function perlrpm { repoquery -q --whatprovides $(for i in "$@";do echo "perl($i)";done|sed -e 's/\//::/g' -e 's/[.]pm//g'); }
+# `-u' limits the search to $UID.
+function pidof
+{(unset pidof
+ if [ "$1" = "-u" ];then
+ shift
+ local r="$(pidof "$@")"
+ local space=""
+ local p
+ for p in $r;do
+ if grep -q "$(echo -e "^Uid:\t$UID\t")" "/proc/$p/status";then
+ echo -n "${space}$p"
+ space=" "
+ fi
+ done
+ echo
+ else
+ pidof "$@"
+ fi
+)}
+function sumlog { find "$@" ! -name config.log -name "*.log" -o -name "*.sum"; }
+function sourcewarecvscheckout {(set -ex
+ ! test -d src
+ ! test -d $1-cvs
+ (set +x;cvs -z3 -d :pserver:anoncvs:@sourceware.org:/cvs/src checkout $1)
+ mv src $1-cvs
+ cd $1-cvs
+ (set +x;cvs update)
+ #(set +x;cvsignoresall)
+ (set +x;ignoresall)
+ );}
+function gdbgitclone { git clone git://sourceware.org/git/gdb.git gdb-git; }
+function binutilsgitclone { git clone git://sourceware.org/git/binutils.git binutils-git; }
+function gdbcvscheckout { sourcewarecvscheckout gdb; }
+function binutilscvscheckout { sourcewarecvscheckout binutils; }
+function gdbdevelcvscheckout {(set -ex
+ ! test -d gdb-devel
+ (set +x;CVSROOT=:pserver:anonymous@cvs.fedoraproject.org:/cvs/pkgs cvs checkout -d gdb-devel rpms/gdb/devel)
+ cd gdb-devel
+ make sources
+ );}
+function gdbf12cvscheckout {(set -ex
+ ! test -d gdb-F-12
+ (set +x;CVSROOT=:pserver:anonymous@cvs.fedoraproject.org:/cvs/pkgs cvs checkout -d gdb-F-12 rpms/gdb/F-12)
+ cd gdb-F-12
+ make sources
+ );}
+function gdbf13cvscheckout {(set -ex
+ ! test -d gdb-F-13
+ (set +x;CVSROOT=:pserver:anonymous@cvs.fedoraproject.org:/cvs/pkgs cvs checkout -d gdb-F-13 rpms/gdb/F-13)
+ cd gdb-F-13
+ make sources
+ );}
+function uri_escape { perl -MURI::Escape -le '$_=<>;chomp;print uri_escape $_;'; };
+function uri_unescape { perl -MURI::Escape -le '$_=<>;chomp;print uri_unescape $_;'; };
+if which ionice &>/dev/null;then
+ IONICE="ionice -c3"
+else
+ IONICE=""
+fi
+function n { if [ "$1" = "-p" ];then renice +19 "$@";test -n "$IONICE" && $IONICE "$@";else nice -n19 $IONICE "$@";fi };
+alias fetchmail='n fetchmail'
+function rpmsrclist
+{
+ if [ -z "$*" ]; then
+ echo >&2 "rpmsrclist gcc-4.3.2-7 [4.4.0-0.25 [-|http://kojipkgs.fedoraproject.org/packages/gcc/4.4.0/0.25/]]"
+ else
+ rpm -q --qf '%{SOURCERPM} %{name}-%{version}-%{release}.%{arch}\n' -a \
+ | grep "^$1.src.rpm " | sed 's/^[^ ]* //' \
+ | \
+ if [ -z "$2" ]; then \
+ cat; \
+ else \
+ sed "s/-$(echo "$1"|sed 's/^.*-\([^-]*-[^-]*\)$/\1/')/-$2/"
+ fi \
+ | \
+ if [ -z "$3" ]; then \
+ cat; \
+ else \
+ if [ "$3" != - ]; then
+ sed "s#.*#$3&.rpm#"; \
+ else \
+ base="$(echo "$1"|sed 's/^\(.*\)-[^-]*-[^-]*$/\1/')"; \
+ sed "s#^.*-\([^-]*\)-\([^-]*\)\.\([^.]*\)\$#http://kojipkgs.fedoraproject.org/packages/$base/\1/\2/\3/&.rpm#"; \
+ fi; \
+ fi \
+ | sort -u
+ fi
+}
+function valgrind {(set -e;unset valgrind;s=~/.python.valgrind;rm -f $s;cp -p /usr/share/doc/python-devel-2.*/valgrind-python.supp $s;patch $s <$s.patch;perl -i -e 'undef $/;$_=<>;1 while s/^(?:###)?({\n)(?:###)?( *ADDRESS_IN_RANGE.*\n(?:[^}#].*\n)*)###/$1$2/gm;print;' $s;valgrind --suppressions=$s "$@";);}
+function yumupdate {(ulimit -v unlimited;yum makecache;yum -y --skip-broken update "$@";);}