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:
parent
a9b96f84de
commit
adb9486bb8
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user