diff options
author | Michał Górny <mgorny@gentoo.org> | 2016-06-30 19:26:21 +0200 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2016-07-03 18:08:35 +0200 |
commit | 4cd5b18679a3e4bcb1049c4213fca6570639851a (patch) | |
tree | 71f843b8800bb1f230a322b821eeccf80c616a58 | |
parent | app-office/calligra-l10n: Migrate to L10N (diff) | |
download | gentoo-4cd5b18679a3e4bcb1049c4213fca6570639851a.tar.gz gentoo-4cd5b18679a3e4bcb1049c4213fca6570639851a.tar.bz2 gentoo-4cd5b18679a3e4bcb1049c4213fca6570639851a.zip |
kde4-*.eclass: Migrate to L10N flags
-rw-r--r-- | eclass/kde4-base.eclass | 4 | ||||
-rw-r--r-- | eclass/kde4-functions.eclass | 43 |
2 files changed, 29 insertions, 18 deletions
diff --git a/eclass/kde4-base.eclass b/eclass/kde4-base.eclass index b6ee447c9aec..6f71dea72153 100644 --- a/eclass/kde4-base.eclass +++ b/eclass/kde4-base.eclass @@ -333,13 +333,13 @@ fi # add a dependency over kde4-l10n if [[ ${KDEBASE} != "kde-base" && -n ${KDE_LINGUAS} ]]; then - for _lingua in ${KDE_LINGUAS}; do + for _lingua in $(kde4_lingua_to_l10n ${KDE_LINGUAS}); do # if our package has linguas, pull in kde4-l10n with selected lingua enabled, # but only for selected ones. # this can't be done on one line because if user doesn't use any localisation # then he is probably not interested in kde4-l10n at all. kderdepend+=" - linguas_${_lingua}? ( $(add_kdeapps_dep kde4-l10n "linguas_${_lingua}(+)") ) + l10n_${_lingua}? ( $(add_kdeapps_dep kde4-l10n "l10n_${_lingua}(+)") ) " done unset _lingua diff --git a/eclass/kde4-functions.eclass b/eclass/kde4-functions.eclass index 8c2fa4a19fda..a600d55c2418 100644 --- a/eclass/kde4-functions.eclass +++ b/eclass/kde4-functions.eclass @@ -76,6 +76,27 @@ case ${KDE_SCM} in *) die "KDE_SCM: ${KDE_SCM} is not supported" ;; esac +# @FUNCTION: kde4_lingua_to_l10n +# @USAGE: <lingua>... +# @INTERNAL +# @DESCRIPTION: +# Output l10n flag name(s) (without prefix(es)) appropriate for given KDE +# locale(s). +kde4_lingua_to_l10n() { + local l + for l; do + case ${l} in + ca@valencia) echo ca-valencia;; + sr@ijekavian) echo sr-ijekavsk;; + sr@ijekavianlatin) echo sr-Latn-ijekavsk;; + sr@latin|sr@Latn) echo sr-Latn;; + uz@cyrillic) echo uz-Cyrl;; + *@*) die "${FUNCNAME}: Unhandled KDE_LINGUAS: ${l}";; + *) echo "${l/_/-}";; + esac + done +} + # @ECLASS-VARIABLE: KDE_LINGUAS # @DESCRIPTION: # This is a whitespace-separated list of translations this ebuild supports. @@ -86,8 +107,8 @@ esac # # Example: KDE_LINGUAS="de en_GB nl" if [[ ${KDE_BUILD_TYPE} != live || -n ${KDE_LINGUAS_LIVE_OVERRIDE} ]]; then - for _lingua in ${KDE_LINGUAS}; do - IUSE="${IUSE} linguas_${_lingua}" + for _lingua in $(kde4_lingua_to_l10n ${KDE_LINGUAS}); do + IUSE="${IUSE} l10n_${_lingua}" done fi @@ -139,7 +160,7 @@ comment_all_add_subdirectory() { # @FUNCTION: enable_selected_linguas # @DESCRIPTION: -# Enable translations based on LINGUAS settings and translations supported by +# Enable translations based on L10N settings and translations supported by # the package (see KDE_LINGUAS). By default, translations are found in "${S}"/po # but this default can be overridden by defining KDE_LINGUAS_DIR. enable_selected_linguas() { @@ -147,11 +168,6 @@ enable_selected_linguas() { local x - # if there is no linguas defined we enable everything - if ! $(env | grep -q "^LINGUAS="); then - return 0 - fi - # @ECLASS-VARIABLE: KDE_LINGUAS_DIR # @DESCRIPTION: # Specified folder where application translations are located. @@ -171,7 +187,7 @@ enable_selected_linguas() { # @FUNCTION: enable_selected_doc_linguas # @DESCRIPTION: -# Enable only selected linguas enabled doc folders. +# Enable only selected L10N enabled doc folders. enable_selected_doc_linguas() { debug-print-function ${FUNCNAME} "$@" @@ -195,11 +211,6 @@ enable_selected_doc_linguas() { -e "/ADD_SUBDIRECTORY[[:space:]]*([[:space:]]*${handbookdir}[[:space:]]*)/s/^/#DONOTCOMPILE /" \ -i CMakeLists.txt || die 'failed to comment out all handbooks' else - # if there is no linguas defined we enable everything (i.e. comment out nothing) - if ! $(env | grep -q "^LINGUAS="); then - return 0 - fi - # Disable subdirectories recursively comment_all_add_subdirectory "${handbookdir}" @@ -213,7 +224,7 @@ enable_selected_doc_linguas() { # Add requested translations local lingua for lingua in en ${KDE_LINGUAS}; do - if [[ ${lingua} = en ]] || use linguas_${lingua}; then + if [[ ${lingua} = en ]] || use "l10n_$(kde4_lingua_to_l10n "${lingua}")"; then if [[ -d ${handbookdir}/${translationdir//%lingua/${lingua}} ]]; then sed -e "/add_subdirectory[[:space:]]*([[:space:]]*${translationdir//%lingua/${lingua}}/s/^#DONOTCOMPILE //" \ -e "/ADD_SUBDIRECTORY[[:space:]]*([[:space:]]*${translationdir//%lingua/${lingua}}/s/^#DONOTCOMPILE //" \ @@ -376,7 +387,7 @@ _enable_selected_linguas_dir() { done for lingua in ${KDE_LINGUAS}; do - if use linguas_${lingua} ; then + if use "l10n_$(kde4_lingua_to_l10n ${lingua})" ; then if [[ -d ${lingua} ]]; then linguas="${linguas} ${lingua}" sed -e "/add_subdirectory([[:space:]]*${lingua}[[:space:]]*)[[:space:]]*$/ s/^#DONOTCOMPILE //" \ |