Use pybabel instead of python setup.py, enable sync

We use already pybabel for django projects, let's use it also for python
projects. This works around a bug in Babel 2.3.3 with keyword option
parsing and unifies on using pybabel for both python and django.

Also extract the installation of horizon so that it's only done once for
modules that have multiple django modules.

This change uses Babel 2.2.0 now but works with 2.3.3 as well.

Reenable syncing of translation.

Change-Id: Ie220fc9418ae31941d182885e44237dc7fafe10a
This commit is contained in:
Andreas Jaeger 2016-04-13 10:11:36 +02:00
parent a9b96f84de
commit adb9486bb8
3 changed files with 37 additions and 28 deletions

View File

@ -34,6 +34,17 @@ function get_modulename {
-p $project -t $target -p $project -t $target
} }
# Setup venv with Babel in it.
function setup_venv {
VENV=$(mktemp -d -p .)
trap "rm -rf $VENV" EXIT
virtualenv $VENV
# Babel version 2.3.0 to 2.3.2 are broken
$VENV/bin/pip install Babel==2.2.0
}
# Setup a project for Zanata. This is used by both Python and Django projects. # Setup a project for Zanata. This is used by both Python and Django projects.
# syntax: setup_project <project> <zanata_version> <modulename> [<modulename> ...] # syntax: setup_project <project> <zanata_version> <modulename> [<modulename> ...]
function setup_project { function setup_project {
@ -268,10 +279,10 @@ function extract_messages {
# Update the .pot files # Update the .pot files
# The "_C" and "_P" prefix are for more-gettext-support blueprint, # The "_C" and "_P" prefix are for more-gettext-support blueprint,
# "_C" for message with context, "_P" for plural form message. # "_C" for message with context, "_P" for plural form message.
python setup.py $QUIET extract_messages --keyword "_C:1c,2 _P:1,2" \ $VENV/bin/pybabel ${QUIET} extract \
--add-comments Translators: \ --add-comments Translators: \
--input-dirs ${modulename} \ -k "_C:1c,2" -k "_P:1,2" \
--output-file ${POT} -o ${POT} ${modulename}
check_empty_pot ${POT} check_empty_pot ${POT}
} }
@ -285,29 +296,24 @@ function extract_messages_log {
# Update the .pot files # Update the .pot files
for level in $LEVELS ; do for level in $LEVELS ; do
POT=${modulename}/locale/${modulename}-log-${level}.pot POT=${modulename}/locale/${modulename}-log-${level}.pot
python setup.py $QUIET extract_messages --no-default-keywords \ $VENV/bin/pybabel ${QUIET} extract --no-default-keywords \
--keyword ${LKEYWORD[$level]} \
--add-comments Translators: \ --add-comments Translators: \
--input-dirs ${modulename} \ -k ${LKEYWORD[$level]} \
--output-file ${POT} -o ${POT} ${modulename}
check_empty_pot ${POT} check_empty_pot ${POT}
done done
} }
# Extract messages for a django project, we need to update django.pot # Django projects need horizon installed for extraction, install it in
# and djangojs.pot. # our venv. The function setup_venv needs to be called first.
function extract_messages_django { function install_horizon {
local modulename=$1
# We need to install horizon
VENV=$(mktemp -d)
trap "rm -rf $VENV" EXIT
virtualenv $VENV
# TODO(jaegerandi): Switch to zuul-cloner once it's safe to use # TODO(jaegerandi): Switch to zuul-cloner once it's safe to use
# zuul-cloner in post jobs and we have a persistent cache on # zuul-cloner in post jobs and we have a persistent cache on
# proposal node. # proposal node.
root=$(mktemp -d) root=$(mktemp -d)
# Note this trap handler overrides the trap handler from
# setup_venv for $VENV.
trap "rm -rf $VENV $root" EXIT trap "rm -rf $VENV $root" EXIT
git clone --depth=1 git://git.openstack.org/openstack/horizon.git $root/horizon git clone --depth=1 git://git.openstack.org/openstack/horizon.git $root/horizon
@ -319,6 +325,14 @@ function extract_messages_django {
# TODO(jagerandi): Install Babel 2.2.0 for now since 2.3.2 does # TODO(jagerandi): Install Babel 2.2.0 for now since 2.3.2 does
# not extract all strings. # not extract all strings.
$VENV/bin/pip install Babel==2.2.0 django-babel $VENV/bin/pip install Babel==2.2.0 django-babel
}
# Extract messages for a django project, we need to update django.pot
# and djangojs.pot.
function extract_messages_django {
local modulename=$1
KEYWORDS="-k gettext_noop -k gettext_lazy -k ngettext_lazy:1,2" KEYWORDS="-k gettext_noop -k gettext_lazy -k ngettext_lazy:1,2"
KEYWORDS+=" -k ugettext_noop -k ugettext_lazy -k ungettext_lazy:1,2" KEYWORDS+=" -k ugettext_noop -k ugettext_lazy -k ungettext_lazy:1,2"
KEYWORDS+=" -k npgettext:1c,2,3 -k pgettext_lazy:1c,2 -k npgettext_lazy:1c,2,3" KEYWORDS+=" -k npgettext:1c,2,3 -k pgettext_lazy:1c,2 -k npgettext_lazy:1c,2,3"
@ -328,14 +342,13 @@ function extract_messages_django {
mkdir -p ${modulename}/locale mkdir -p ${modulename}/locale
POT=${modulename}/locale/${DOMAIN}.pot POT=${modulename}/locale/${DOMAIN}.pot
touch ${POT} touch ${POT}
$VENV/bin/pybabel extract -F babel-${DOMAIN}.cfg \ $VENV/bin/pybabel ${QUIET} extract -F babel-${DOMAIN}.cfg \
--add-comments Translators: \ --add-comments Translators: \
-o ${POT} $KEYWORDS ${modulename} $KEYWORDS \
-o ${POT} ${modulename}
check_empty_pot ${POT} check_empty_pot ${POT}
fi fi
done done
rm -rf $VENV $root
trap "" EXIT
} }
# Extract releasenotes messages # Extract releasenotes messages

View File

@ -12,10 +12,6 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# TODO(jaegerandi): Remove once babel works again
# See https://github.com/python-babel/babel/issues/388
exit 0
PROJECT=$1 PROJECT=$1
BRANCH=$2 BRANCH=$2
# Replace /'s in the branch name with -'s because Zanata does not # Replace /'s in the branch name with -'s because Zanata does not
@ -134,6 +130,7 @@ case "$PROJECT" in
;; ;;
*) *)
# Common setup for python and django repositories # Common setup for python and django repositories
setup_venv
# ---- Python projects ---- # ---- Python projects ----
module_names=$(get_modulename $PROJECT python) module_names=$(get_modulename $PROJECT python)
if [ -n "$module_names" ]; then if [ -n "$module_names" ]; then
@ -150,6 +147,7 @@ case "$PROJECT" in
module_names=$(get_modulename $PROJECT django) module_names=$(get_modulename $PROJECT django)
if [ -n "$module_names" ]; then if [ -n "$module_names" ]; then
setup_project "$PROJECT" "$ZANATA_VERSION" $module_names setup_project "$PROJECT" "$ZANATA_VERSION" $module_names
install_horizon
# Pull updated translations from Zanata. # Pull updated translations from Zanata.
pull_from_zanata "$PROJECT" pull_from_zanata "$PROJECT"
for modulename in $module_names; do for modulename in $module_names; do

View File

@ -12,10 +12,6 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
# TODO(jaegerandi): Remove once babel works again
# See https://github.com/python-babel/babel/issues/388
exit 0
PROJECT=$1 PROJECT=$1
# Replace /'s in branch names with -'s because Zanata doesn't # Replace /'s in branch names with -'s because Zanata doesn't
@ -46,6 +42,7 @@ case "$PROJECT" in
;; ;;
*) *)
# Common setup for python and django repositories # Common setup for python and django repositories
setup_venv
# ---- Python projects ---- # ---- Python projects ----
module_names=$(get_modulename $PROJECT python) module_names=$(get_modulename $PROJECT python)
if [ -n "$module_names" ]; then if [ -n "$module_names" ]; then
@ -61,6 +58,7 @@ case "$PROJECT" in
module_names=$(get_modulename $PROJECT django) module_names=$(get_modulename $PROJECT django)
if [ -n "$module_names" ]; then if [ -n "$module_names" ]; then
setup_project "$PROJECT" "$ZANATA_VERSION" $module_names setup_project "$PROJECT" "$ZANATA_VERSION" $module_names
install_horizon
for modulename in $module_names; do for modulename in $module_names; do
extract_messages_django "$modulename" extract_messages_django "$modulename"
done done