Created
October 13, 2015 07:59
-
-
Save robertsky/2bda1f396d01ef559d7c to your computer and use it in GitHub Desktop.
Deploy WordPress plugin from git to wordpress.org repo. Adapted from https://github.com/pdclark/deploy-plugin-to-wordpress-dot-org
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#! /bin/bash | |
# Source: https://raw.github.com/thenbrent/multisite-user-management/master/deploy.sh | |
# http://thereforei.am/2011/04/21/git-to-svn-automated-wordpress-plugin-deployment/ | |
# A modification of Dean Clatworthy's deploy script as found here: https://github.com/deanc/wordpress-plugin-git-svn | |
# The difference is that this script lives in the plugin's git repo & doesn't require an existing SVN repo. | |
# main config | |
PLUGINSLUG=${PWD##*/} # returns basename of current directory | |
CURRENTDIR=`pwd` | |
MAINFILE="display-ssh.php" # this should be the name of your main php file in the wordpress plugin | |
SVNUSER="robertsky_" # your svn username (case sensitive) | |
# git config | |
GITPATH="$CURRENTDIR/" # this file should be in the base of your git repository | |
# svn config | |
SVNPATH="/tmp/$PLUGINSLUG" # path to a temp SVN repo. No trailing slash required and don't add trunk. | |
SVNURL="http://plugins.svn.wordpress.org/$PLUGINSLUG" # Remote SVN repo on wordpress.org, with no trailing slash | |
# Let's begin... | |
echo ".........................................." | |
echo | |
echo "Preparing to deploy WordPress plugin" | |
echo | |
echo ".........................................." | |
echo | |
# Check version in readme.txt is the same as plugin file | |
NEWVERSION1=`grep "^Stable tag" "$GITPATH/readme.txt" | awk -F' ' '{print $3}' | sed 's/[[:space:]]//g'` | |
echo "readme version: $NEWVERSION1" | |
NEWVERSION2=`grep " * Version" "$GITPATH/$MAINFILE" | awk -F' ' '{print $3}' | sed 's/[[:space:]]//g'` | |
echo "$MAINFILE version: $NEWVERSION2" | |
if [ "$NEWVERSION1" != "$NEWVERSION2" ]; then echo "Versions don't match. Exiting...."; exit 1; fi | |
echo "Versions match in readme.txt and PHP file. Let's proceed..." | |
cd "$GITPATH" | |
echo -e "Enter a commit message for this new version: \c" | |
read COMMITMSG | |
# git commit -am "$COMMITMSG" | |
echo "Tagging new version in git" | |
git tag -a "$NEWVERSION1" -m "Tagging version $NEWVERSION1" | |
echo "Pushing latest commit to origin, with tags" | |
git push origin master | |
git push origin master --tags | |
echo | |
echo "Creating local copy of SVN repo ..." | |
svn co $SVNURL $SVNPATH | |
echo "Exporting the HEAD of master from git to the trunk of SVN" | |
git checkout-index -a -f --prefix=$SVNPATH/trunk/ | |
echo "Ignoring github specific files and deployment script" | |
svn propset svn:ignore "assets | |
deploy.sh | |
README.md | |
.git | |
.gitignore" "$SVNPATH/trunk/" | |
echo "Changing directory to SVN and committing to trunk" | |
cd $SVNPATH/trunk/ | |
# Add all new files that are not set to be ignored | |
svn status | grep -v "^.[ \t]*\..*" | grep "^?" | awk '{print $2}' | xargs svn add | |
svn commit --username=$SVNUSER -m "$COMMITMSG" | |
# echo "Creating new SVN tag & committing it" | |
cd $SVNPATH | |
svn copy trunk/ tags/$NEWVERSION1/ | |
cd $SVNPATH/tags/$NEWVERSION1 | |
svn commit --username=$SVNUSER -m "Tag $NEWVERSION1" | |
echo "Removing temporary directory $SVNPATH" | |
rm -fr $SVNPATH/ | |
echo "*** FIN ***" |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment