#!/bin/bash -xe # Copyright 2013 IBM Corp. # # Licensed under the Apache License, Version 2.0 (the "License"); you may # not use this file except in compliance with the License. You may obtain # a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the # License for the specific language governing permissions and limitations # under the License. # The script is to pull the translations from Transifex, # and push to Gerrit. PROJECT=$1 DocFolder="doc" if [ $PROJECT = "api-site" ] ; then DocFolder="./" fi COMMIT_MSG="Imported Translations from Transifex" git config user.name "OpenStack Proposal Bot" git config user.email "openstack-infra@lists.openstack.org" git config gitreview.username "proposal-bot" git review -s # See if there is an open change in the transifex/translations topic # If so, get the change id for the existing change for use in the commit msg. change_info=`ssh -p 29418 proposal-bot@review.openstack.org gerrit query --current-patch-set status:open project:openstack/$PROJECT topic:transifex/translations owner:proposal-bot` previous=`echo "$change_info" | grep "^ number:" | awk '{print $2}'` if [ "x${previous}" != "x" ] ; then change_id=`echo "$change_info" | grep "^change" | awk '{print $2}'` # read return a non zero value when it reaches EOF. Because we use a # heredoc here it will always reach EOF and return a nonzero value. # Disable -e temporarily to get around the read. set +e read -d '' COMMIT_MSG < ${DocFolder}/high-availability-guide/bk-ha-guide.xml fi # Update the .pot file ./tools/generatepot ${DOCNAME} if [ -f ${DocFolder}/${DOCNAME}/locale/${DOCNAME}.pot ] then # Add all changed files to git git add ${DocFolder}/${DOCNAME}/locale/* # Set auto-local tx set --auto-local -r openstack-manuals-i18n.${DOCNAME} \ "${DocFolder}/${DOCNAME}/locale/.po" --source-lang en \ --source-file ${DocFolder}/${DOCNAME}/locale/${DOCNAME}.pot \ -t PO --execute fi done # Pull all upstream translations tx pull -a -f for FILE in ${DocFolder}/* do DOCNAME=${FILE#${DocFolder}/} if [ -d ${DocFolder}/${DOCNAME}/locale ] then git add ${DocFolder}/${DOCNAME}/locale/* fi done # Don't send files where the only things which have changed are the # creation date, the version number, the revision date, or comment # lines. for f in `git diff --cached --name-only` do if [ `git diff --cached $f |egrep -v "(POT-Creation-Date|Project-Id-Version|PO-Revision-Date|^\+{3}|^\-{3}|^[-+]#)" | egrep -c "^[\-\+]"` -eq 0 ] then git reset -q $f git checkout -- $f fi done # Don't send a review if nothing has changed. if [ `git diff --cached |wc -l` -gt 0 ] then # Commit and review git commit -F- <