Make find replace script more macOS friendly

Also, make handling of arbitrary filenames a bit more robust.
This commit is contained in:
David Sanders 2018-04-22 01:35:08 -06:00
parent f7535eb992
commit cdc83bd498
No known key found for this signature in database
GPG Key ID: 87A8D53EF6038397

View File

@ -4,9 +4,6 @@ set -o errexit
set -o nounset set -o nounset
set -o pipefail set -o pipefail
# List of all non-executable files
TEMPLATE_FILES=$(find . ! -perm -u=x -type f | grep -v "\.git")
echo "What is your python module name?" echo "What is your python module name?"
read MODULE_NAME read MODULE_NAME
@ -29,12 +26,20 @@ PROJECT_NAME=${PROJECT_INPUT:-$REPO_NAME}
echo "What is a one-liner describing the project?" echo "What is a one-liner describing the project?"
read SHORT_DESCRIPTION read SHORT_DESCRIPTION
sed -i "s/<MODULE_NAME>/$MODULE_NAME/g" $TEMPLATE_FILES _replace() {
sed -i "s/<PYPI_NAME>/$PYPI_NAME/g" $TEMPLATE_FILES local find_cmd=(find . ! -perm -u=x ! -path '*/.git/*' -type f)
sed -i "s/<REPO_NAME>/$REPO_NAME/g" $TEMPLATE_FILES
sed -i "s/<RTD_NAME>/$RTD_NAME/g" $TEMPLATE_FILES if [[ $(uname) == Darwin ]]; then
sed -i "s/<PROJECT_NAME>/$PROJECT_NAME/g" $TEMPLATE_FILES "${find_cmd[@]}" -exec sed -i '' "$1" {} +
sed -i "s/<SHORT_DESCRIPTION>/$SHORT_DESCRIPTION/g" $TEMPLATE_FILES else
"${find_cmd[@]}" -exec sed -i "$1" {} +
fi
}
_replace "s/<PYPI_NAME>/$PYPI_NAME/g"
_replace "s/<REPO_NAME>/$REPO_NAME/g"
_replace "s/<RTD_NAME>/$RTD_NAME/g"
_replace "s/<PROJECT_NAME>/$PROJECT_NAME/g"
_replace "s/<SHORT_DESCRIPTION>/$SHORT_DESCRIPTION/g"
mkdir $MODULE_NAME mkdir $MODULE_NAME
touch $MODULE_NAME/__init__.py touch $MODULE_NAME/__init__.py