-echo Now downloading BINUTILS...
-wget ${WGET_OPTS} ${BINUTILS}
-
-echo Now downloading GCC...
-wget ${WGET_OPTS} ${GCCCORE}
-
-echo Now downloading G++...
-wget ${WGET_OPTS} ${GPP}
-
-echo Now downloading NEWLIB...
-wget ${WGET_OPTS} ${NEWLIB}
-
-echo Now downloading INSIGHT...
-wget ${WGET_OPTS} ${INSIGHT}
-
-echo Now downloading GDB...
-wget ${WGET_OPTS} ${GDB}
-
-echo Now downloading GMP...
-wget ${WGET_OPTS} ${GMP}
-
-echo Now downloading MPFR...
-wget ${WGET_OPTS} ${MPFR}
+if [[ -f all.downloaded ]]; then
+ echo Looks like all downloads are complete, skipping downloads
+else
+ wget ${WGET_OPTS} ${GNU_KEYRING}
+ # TODO: need to avoid polluting the users keyring, but how?!
+ gpg --import ${GNU_KEYRING_GPG}
+
+ # TODO: guess it's better to have a function that "downloads, checks file-presence and signature, and returns true/false" whether the file is ok
+ # Function will check if file exists (otherwise try to download the file - if failed and file still doesn't exist, complain and exit the script)
+ # Check if signature file exists (otherwise download the signature file as well - if download fail, warn the user and return function)
+ # Check the signature. If failed, backup-by-renaming current files, redownload both file & signature, run the function body one more time - if still no success, warn and return from function
+
+ # NOTE: If new downloads are added here, please see the IMPORTANT note below
+ echo Now downloading BINUTILS...
+ wget ${WGET_OPTS} ${BINUTILS}
+ wget -N ${WGET_OPTS} ${BINUTILS}.sig
+ gpg --verify ${BINUTILS_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${BINUTILS_TAR}.sig
+ exit 1
+ fi
+
+ echo Now downloading GCC...
+ wget ${WGET_OPTS} ${GCCCORE}
+ wget -N ${WGET_OPTS} ${GCCCORE}.sig
+ gpg --verify ${GCCCORE_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${GCCCORE_TAR}.sig
+ exit 1
+ fi
+
+ echo Now downloading G++...
+ wget ${WGET_OPTS} ${GPP}
+ wget -N ${WGET_OPTS} ${GPP}.sig
+ gpg --verify ${GPP_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${GPP_TAR}.sig
+ exit 1
+ fi
+
+ echo Now downloading NEWLIB...
+ wget ${WGET_OPTS} ${NEWLIB}
+ # TODO: signature/hash check
+
+ echo Now downloading INSIGHT...
+ wget ${WGET_OPTS} ${INSIGHT}
+ # TODO: signature/hash check
+
+ echo Now downloading GDB...
+ wget ${WGET_OPTS} ${GDB}
+ wget -N ${WGET_OPTS} ${GDB}.sig
+ gpg --verify ${GDB_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${GDB_TAR}.sig
+ exit 1
+ fi
+
+ echo Now downloading GMP...
+ wget ${WGET_OPTS} ${GMP}
+ wget -N ${WGET_OPTS} ${GMP}.sig
+ gpg --verify ${GMP_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${GMP_TAR}.sig
+ exit 1
+ fi
+
+ echo Now downloading MPFR...
+ wget ${WGET_OPTS} ${MPFR}
+ wget -N ${WGET_OPTS} ${MPFR}.sig
+ gpg --verify ${MPFR_TAR}.sig 2> /dev/null
+ if [[ $? != 0 ]]; then
+ echo "Failed signature check for:" ${MPFR_TAR}.sig
+ exit 1
+ fi
+
+ # IMPORTANT: Here is the number of .tar. archives downloaded above. Please update if new .tar. are added to download list.
+ if [[ `ls -1 *.tar.bz2 *.tar.gz | wc -l` != 8 ]]; then
+ echo "Seems like not all prerequisite files donwloaded... Exiting."
+ exit 1
+ else
+ touch all.downloaded
+ fi
+fi