From 8d98b4104a7c8ff068c10e33aade524027ff75cd Mon Sep 17 00:00:00 2001 From: Kenneth Reitz <me@kennethreitz.com> Date: Thu, 10 Nov 2011 11:43:20 -0800 Subject: [PATCH] Check for virtualenv collisions. Warn if folders exist. Reject if a conflict will occur. --- bin/compile | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/bin/compile b/bin/compile index ecb91097..e03fc088 100755 --- a/bin/compile +++ b/bin/compile @@ -33,6 +33,18 @@ if [ "$NAME" = "Python" ]; then [ -f manage.py ] && [ -f settings.py ] && { echo " ! Django app must be in a package subdirectory"; exit 1; } fi +# warn a checked-in virtualenv +if [ -d "lib" ] || [ -d "bin" ]; then + echo " ! You have a virtualenv checked in. You should ignore the appropriate paths in your repo. See http://devcenter.heroku.com/articles/gitignore for more info."; +fi + +# reject a conflicting checked-in virtualenv +if [ -f "lib/python2.7" ]; then + echo " ! Checked-in virtualenv conflict." + exit 1; +fi + + # copy artifacts out of cache if exists mkdir -p $CACHE_DIR for dir in $VIRTUALENV_DIRS; do @@ -49,7 +61,7 @@ if [ "$NAME" = "Python/Django" ]; then SETTINGS_FILE=$(ls **/settings.py | head -1) PROJECT=$(dirname $SETTINGS_FILE) echo "Injecting code into $SETTINGS_FILE to read from DATABASE_URL" | indent - + cat >>$SETTINGS_FILE <<EOF import os, sys, urlparse -- GitLab