commit:     a1e1efbebd56623d5929e79d96bc318daa99ce75
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Fri Jun  9 07:07:29 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Fri Jun  9 07:33:08 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a1e1efbe

app-i18n/mozc: add 2.28.5029.102

See the discussion on the bug for the full details.

While at it, I've ported to edo. I'm likely to change the mozcdic-ut setup to
use savedconfig as well.

Thanks-to: Jack Daniels
Thanks-to: gertoe
Thanks-to: Martin Sekera
Bug: https://bugs.gentoo.org/877765
Closes: https://bugs.gentoo.org/843227
Signed-off-by: Sam James <sam <AT> gentoo.org>

 app-i18n/mozc/Manifest                  |   3 +
 app-i18n/mozc/metadata.xml              |   1 +
 app-i18n/mozc/mozc-2.28.5029.102.ebuild | 394 ++++++++++++++++++++++++++++++++
 3 files changed, 398 insertions(+)

diff --git a/app-i18n/mozc/Manifest b/app-i18n/mozc/Manifest
index eb3863c7a745..76f3cad6b368 100644
--- a/app-i18n/mozc/Manifest
+++ b/app-i18n/mozc/Manifest
@@ -1,3 +1,6 @@
 DIST fcitx-mozc-2.26.4220-20201219202429.tar.gz 37174759 BLAKE2B 
3f320523103ee7a35a763f6613889e282e8a654db8ef11b5a1168db12611387e300621f015977875ffec3c10c055e36b3cb525a1e8559013f3ac42bc5b0cc296
 SHA512 
823e64267aa69e4d30dd7408f946a54072994f9a2d68691a3d393b216a15e70fd28bcb24705f9d9f483a2291517c48c5a1aeda893d2315f9a1d9cd352fb3feb2
+DIST fcitx-mozc-2.28.5029.102-2.28.5029.102.tar.gz 37246575 BLAKE2B 
54381968e33870f2d9f769184cf49428548d04de66e767140c8f053fad7873f1b2e3b02be81ce54e51b824d2c9cd971da37bff8b60efe60c9e2c748ff298afbd
 SHA512 
4962e9505b79d4680a260c257719ba2486a6fe127018298758728faa9535504bc2dd6b1bfb430ac2982cb377cda52c145430531afd0968f49f91d366fdd43d92
 DIST japanese-usage-dictionary-20180701040110.tar.gz 71285 BLAKE2B 
dfad056a1d5061b6764f583da15b9ad60a3c4421cee0430c4665d1c2779a64f9b31473c1746a3e2b9bda5167349432e51dcf7d4d48f75fde9543e9c16ff74c0d
 SHA512 
68b4d3f52dd6cd4f00a8012a870b4f5929519cd69815b1729f3881d1f964802308f4aa101e236824b4c0f832183a9e8097437ed620403f2a652f126e7cdc1eb3
 DIST mozc-2.26.4220-20201212102434.tar.gz 37106063 BLAKE2B 
7d3c236809c8feb017f35e3f7a9b024ac34204f483c69913a2d1ae6b771054548f7f81afde35ed3a6887c9f7503584cee0fc646653fc7cde6fd015158de9c3d3
 SHA512 
9d87947b9b9256a3cc66cb23ab6caf4b6974142090b0d315c101bdc700fd289c259d09cb7f02f5f9e7462f48d652cd2d5b4822a645751fdcaed88b939520c429
+DIST mozc-2.28.5029.102-2.28.5029.102.tar.gz 37247099 BLAKE2B 
4bb528991102d34a26321e6fa00a73cc83cb103e0b765f1ebb837dd6894387288b13ed75cc255003d07d6f0c4a82f963684fa4f2bd9b5043cfaddb57a5f5cef0
 SHA512 
b20aa45757db92f66d1c135eacf907b4cec937226a8d09e5f9f6768ae22a6b8464e3b75276773ce55413f2002ffcc3d8cae136e7fd3acfc0733e48bccf848d5b
+DIST mozc-2.28.5029.102-patches.tar.xz 224380 BLAKE2B 
377d2cac6ec8a9c90661f10c0b105d8347ca8080ec43cee3dfd4660feadfe2d9b204d6e4b9e22bd11a5fdbbf26e7f6f298b703b88fb1621ea1847741408c1953
 SHA512 
5836a19ea68de271475b3ca1efce928b0ad012c96ff7ecdc4474b05daf8b8df022203eb46ec839b76e7d50be7a75b8f278d534d762fac0e612a8f09ae13c7c16

diff --git a/app-i18n/mozc/metadata.xml b/app-i18n/mozc/metadata.xml
index 7fd885c8d62f..36b5449ea94d 100644
--- a/app-i18n/mozc/metadata.xml
+++ b/app-i18n/mozc/metadata.xml
@@ -13,6 +13,7 @@
                <flag name="fcitx4">Enable support for 
<pkg>app-i18n/fcitx</pkg> 4</flag>
                <flag name="gui">Install graphical user interface tool 
(mozc_tool)</flag>
                <flag name="ibus">Enable support for 
<pkg>app-i18n/ibus</pkg></flag>
+               <flag name="mozcdic-ut">Enable support for Mozc UT 
Dictionaries. Must be placed at compile time at /tmp/mozcdic-ut.txt</flag>
                <flag name="renderer">Enable native candidate window</flag>
        </use>
        <upstream>

diff --git a/app-i18n/mozc/mozc-2.28.5029.102.ebuild 
b/app-i18n/mozc/mozc-2.28.5029.102.ebuild
new file mode 100644
index 000000000000..366320f57f8f
--- /dev/null
+++ b/app-i18n/mozc/mozc-2.28.5029.102.ebuild
@@ -0,0 +1,394 @@
+# Copyright 2010-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI="8"
+
+PYTHON_COMPAT=( python3_{10..11} )
+
+inherit edo elisp-common multiprocessing python-any-r1 toolchain-funcs desktop 
xdg
+
+if [[ "${PV}" == "9999" ]]; then
+       inherit git-r3
+
+       EGIT_REPO_URI="https://github.com/google/mozc";
+       EGIT_SUBMODULES=(src/third_party/japanese_usage_dictionary)
+else
+       MOZC_GIT_REVISION="305e9a7374254148474d067c46d55a4ee6081837"
+       MOZC_DATE="${PV#*_p}"
+       MOZC_DATE="${MOZC_DATE%%_p*}"
+
+       FCITX_MOZC_GIT_REVISION="242b4f703cba27d4ff4dc123c713a478f964e001"
+       FCITX_MOZC_DATE="${PV#*_p}"
+       FCITX_MOZC_DATE="${FCITX_MOZC_DATE#*_p}"
+       FCITX_MOZC_DATE="${FCITX_MOZC_DATE%%_p*}"
+
+       
JAPANESE_USAGE_DICTIONARY_GIT_REVISION="a4a66772e33746b91e99caceecced9a28507e925"
+       JAPANESE_USAGE_DICTIONARY_DATE="20180701040110"
+fi
+
+DESCRIPTION="Mozc - Japanese input method editor"
+HOMEPAGE="https://github.com/google/mozc";
+if [[ "${PV}" == "9999" ]]; then
+       SRC_URI=""
+else
+       SRC_URI="
+               
https://github.com/google/${PN}/archive/${MOZC_GIT_REVISION}.tar.gz -> 
${PN}-${PV%%_p*}-${MOZC_DATE}.tar.gz
+               
https://github.com/hiroyuki-komatsu/japanese-usage-dictionary/archive/${JAPANESE_USAGE_DICTIONARY_GIT_REVISION}.tar.gz
 -> japanese-usage-dictionary-${JAPANESE_USAGE_DICTIONARY_DATE}.tar.gz
+               
https://dev.gentoo.org/~sam/distfiles/${CATEGORY}/${PN}/${PN}-2.28.5029.102-patches.tar.xz
+               fcitx4? ( 
https://github.com/fcitx/${PN}/archive/${FCITX_MOZC_GIT_REVISION}.tar.gz -> 
fcitx-${PN}-${PV%%_p*}-${FCITX_MOZC_DATE}.tar.gz )
+       "
+fi
+
+# Mozc: BSD
+# src/data/dictionary_oss: ipadic, public-domain
+# src/data/unicode: unicode
+# japanese-usage-dictionary: BSD-2
+LICENSE="BSD BSD-2 ipadic public-domain unicode"
+SLOT="0"
+KEYWORDS="~amd64 ~arm64 ~ppc64 ~x86"
+IUSE="debug emacs fcitx4 +gui ibus renderer test mozcdic-ut"
+REQUIRED_USE="|| ( emacs fcitx4 ibus )"
+RESTRICT="!test? ( test )"
+
+BDEPEND="$(python_gen_any_dep 'dev-python/six[${PYTHON_USEDEP}]')
+       >=dev-libs/protobuf-3.0.0
+       dev-util/gyp
+       dev-util/ninja
+       virtual/pkgconfig
+       emacs? ( app-editors/emacs:* )
+       fcitx4? ( sys-devel/gettext )"
+DEPEND="dev-cpp/abseil-cpp:=[cxx17(+)]
+       >=dev-libs/protobuf-3.0.0:=
+       fcitx4? (
+               app-i18n/fcitx:4
+               virtual/libintl
+       )
+       gui? (
+               dev-qt/qtcore:5
+               dev-qt/qtgui:5
+               dev-qt/qtwidgets:5
+       )
+       ibus? (
+               >=app-i18n/ibus-1.4.1
+               dev-libs/glib:2
+               x11-libs/libxcb
+       )
+       renderer? (
+               dev-libs/glib:2
+               x11-libs/cairo
+               x11-libs/gtk+:2
+               x11-libs/pango
+       )
+       test? (
+               >=dev-cpp/gtest-1.8.0
+               dev-libs/jsoncpp
+       )"
+RDEPEND="dev-cpp/abseil-cpp:=[cxx17(+)]
+       >=dev-libs/protobuf-3.0.0:=
+       emacs? ( app-editors/emacs:* )
+       fcitx4? (
+               app-i18n/fcitx:4
+               virtual/libintl
+       )
+       gui? (
+               dev-qt/qtcore:5
+               dev-qt/qtgui:5
+               dev-qt/qtwidgets:5
+       )
+       ibus? (
+               >=app-i18n/ibus-1.4.1
+               dev-libs/glib:2
+               x11-libs/libxcb
+       )
+       renderer? (
+               dev-libs/glib:2
+               x11-libs/cairo
+               x11-libs/gtk+:2
+               x11-libs/pango
+       )"
+
+S="${WORKDIR}/${P}/src"
+
+SITEFILE="50${PN}-gentoo.el"
+
+PATCHES=(
+       "${WORKDIR}"/mozc-2.28.5029.102-patches
+)
+
+python_check_deps() {
+       has_version -b "dev-python/six[${PYTHON_USEDEP}]"
+}
+
+src_unpack() {
+       if [[ "${PV}" == "9999" ]]; then
+               git-r3_src_unpack
+
+               if use fcitx4; then
+                       local EGIT_SUBMODULES=()
+                       git-r3_fetch https://github.com/fcitx/mozc 
refs/heads/fcitx
+                       git-r3_checkout https://github.com/fcitx/mozc 
"${WORKDIR}/fcitx-mozc"
+               fi
+       else
+               unpack ${PN}-${PV%%_p*}-${MOZC_DATE}.tar.gz
+               mv mozc-${MOZC_GIT_REVISION} ${P} || die
+
+               unpack ${PN}-2.28.5029.102-patches.tar.xz
+
+               unpack 
japanese-usage-dictionary-${JAPANESE_USAGE_DICTIONARY_DATE}.tar.gz
+               cp -p 
japanese-usage-dictionary-${JAPANESE_USAGE_DICTIONARY_GIT_REVISION}/usage_dict.txt
 ${P}/src/third_party/japanese_usage_dictionary || die
+
+               if use fcitx4; then
+                       unpack fcitx-${PN}-${PV%%_p*}-${FCITX_MOZC_DATE}.tar.gz
+                       mv mozc-${FCITX_MOZC_GIT_REVISION} fcitx-${PN} || die
+               fi
+       fi
+}
+
+src_prepare() {
+       if use fcitx4; then
+               cp -pr "${WORKDIR}/fcitx-mozc/src/unix/fcitx" unix || die
+       fi
+
+       pushd "${WORKDIR}/${P}" > /dev/null || die
+       default
+       popd > /dev/null || die
+
+       sed \
+               -e "s/def GypMain(options, unused_args):/def GypMain(options, 
gyp_args):/" \
+               -e "s/RunOrDie(gyp_command + gyp_options)/RunOrDie(gyp_command 
+ gyp_options + gyp_args)/" \
+               -e "s/RunOrDie(\[ninja/&, '-j$(makeopts_jobs "${MAKEOPTS}" 
999)', '-l$(makeopts_loadavg "${MAKEOPTS}" 0)', '-v'/" \
+               -i build_mozc.py || die
+
+       local ar=($(tc-getAR))
+       local cc=($(tc-getCC))
+       local cxx=($(tc-getCXX))
+       local ld=($(tc-getLD))
+       local nm=($(tc-getNM))
+       local readelf=($(tc-getREADELF))
+
+       # Use absolute paths. Non-absolute paths are mishandled by GYP.
+       ar[0]=$(type -P ${ar[0]})
+       cc[0]=$(type -P ${cc[0]})
+       cxx[0]=$(type -P ${cxx[0]})
+       ld[0]=$(type -P ${ld[0]})
+       nm[0]=$(type -P ${nm[0]})
+       readelf[0]=$(type -P ${readelf[0]})
+
+       sed \
+               -e "s:<!(which ar):${ar[@]}:" \
+               -e "s:<!(which clang):${cc[@]}:" \
+               -e "s:<!(which clang++):${cxx[@]}:" \
+               -e "s:<!(which ld):${ld[@]}:" \
+               -e "s:<!(which nm):${nm[@]}:" \
+               -e "s:<!(which readelf):${readelf[@]}:" \
+               -i gyp/common.gypi || die
+
+       # https://github.com/google/mozc/issues/489
+       sed \
+               -e "/'-lc++'/d" \
+               -e "/'-stdlib=libc++'/d" \
+               -i gyp/common.gypi || die
+
+       # Add mozcdic-ut
+       if use mozcdic-ut; then
+               if [ ! -f "${BROOT}"/tmp/mozcdic-ut.txt ]; then
+                       ewarn "No mozcdic-ut.txt found. Please place your 
customized mozcdic-ut.txt in /tmp/.";
+                       die
+               else
+                       einfo "mozcdic-ut.txt found. Adding to mozc 
dictionary..."
+                       cat "${BROOT}"/tmp/mozcdic-ut.txt >> 
"${WORKDIR}/${P}/src/data/dictionary_oss/dictionary00.txt" || die
+               fi
+       fi
+}
+
+src_configure() {
+       if use debug; then
+               BUILD_TYPE="Debug"
+       else
+               BUILD_TYPE="Release"
+       fi
+
+       local gyp_arguments=()
+
+       if tc-is-gcc; then
+               gyp_arguments+=(-D compiler_host=gcc -D compiler_target=gcc)
+       elif tc-is-clang; then
+               gyp_arguments+=(-D compiler_host=clang -D compiler_target=clang)
+       else
+               gyp_arguments+=(-D compiler_host=unknown -D 
compiler_target=unknown)
+       fi
+
+       gyp_arguments+=(-D debug_extra_cflags=)
+       gyp_arguments+=(-D release_extra_cflags=)
+
+       gyp_arguments+=(-D use_fcitx=$(usex fcitx4 YES NO))
+       gyp_arguments+=(-D use_libibus=$(usex ibus 1 0))
+       gyp_arguments+=(-D use_libprotobuf=1)
+       gyp_arguments+=(-D use_system_abseil_cpp=1)
+       gyp_arguments+=(-D use_system_gtest=$(usex test 1 0))
+       gyp_arguments+=(-D use_system_jsoncpp=$(usex test 1 0))
+       gyp_arguments+=(-D enable_gtk_renderer=$(usex renderer 1 0))
+
+       gyp_arguments+=(-D server_dir="${EPREFIX}/usr/libexec/mozc")
+       gyp_arguments+=(-D document_dir="${EPREFIX}/usr/libexec/mozc/documents")
+
+       if use ibus; then
+               gyp_arguments+=(-D 
ibus_mozc_path="${EPREFIX}/usr/libexec/ibus-engine-mozc")
+               gyp_arguments+=(-D 
ibus_mozc_icon_path="${EPREFIX}/usr/share/ibus-mozc/product_icon.png")
+       fi
+
+       unset AR CC CXX LD NM READELF
+
+       edo "${PYTHON}" build_mozc.py gyp \
+               --gypdir="${EPREFIX}/usr/bin" \
+               --server_dir="${EPREFIX}/usr/libexec/mozc" \
+               --verbose \
+               $(usex gui "" --noqt) \
+               -- "${gyp_arguments[@]}"
+}
+
+src_compile() {
+       local targets=(server/server.gyp:mozc_server)
+       if use emacs; then
+               targets+=(unix/emacs/emacs.gyp:mozc_emacs_helper)
+       fi
+       if use fcitx4; then
+               targets+=(unix/fcitx/fcitx.gyp:fcitx-mozc)
+       fi
+       if use gui; then
+               targets+=(gui/gui.gyp:mozc_tool)
+       fi
+       if use ibus; then
+               targets+=(unix/ibus/ibus.gyp:ibus_mozc)
+       fi
+       if use renderer; then
+               targets+=(renderer/renderer.gyp:mozc_renderer)
+       fi
+       if use test; then
+               targets+=(gyp/tests.gyp:unittests)
+       fi
+
+       if use ibus; then
+               GYP_IBUS_FLAG="--use_gyp_for_ibus_build"
+       fi
+
+       edo "${PYTHON}" build_mozc.py build -c ${BUILD_TYPE} ${GYP_IBUS_FLAG} 
-v "${targets[@]}"
+
+       if use emacs; then
+               elisp-compile unix/emacs/*.el
+       fi
+}
+
+src_test() {
+       edo "${PYTHON}" build_mozc.py runtests -c ${BUILD_TYPE} --test_jobs 1
+}
+
+src_install() {
+       exeinto /usr/libexec/mozc
+       doexe out_linux/${BUILD_TYPE}/mozc_server
+
+       if use gui; then
+               doexe out_linux/${BUILD_TYPE}/mozc_tool
+       fi
+
+       if use renderer; then
+               doexe out_linux/${BUILD_TYPE}/mozc_renderer
+       fi
+
+       insinto /usr/libexec/mozc/documents
+       doins data/installer/credits_en.html
+
+       if use emacs; then
+               dobin out_linux/${BUILD_TYPE}/mozc_emacs_helper
+               elisp-install ${PN} unix/emacs/*.{el,elc}
+               elisp-site-file-install "${FILESDIR}/${SITEFILE}" ${PN}
+       fi
+
+       if use fcitx4; then
+               exeinto /usr/$(get_libdir)/fcitx
+               doexe out_linux/${BUILD_TYPE}/fcitx-mozc.so
+
+               insinto /usr/share/fcitx/addon
+               doins unix/fcitx/fcitx-mozc.conf
+
+               insinto /usr/share/fcitx/inputmethod
+               doins unix/fcitx/mozc.conf
+
+               insinto /usr/share/fcitx/mozc/icon
+               newins data/images/product_icon_32bpp-128.png mozc.png
+               local image
+               for image in ../../fcitx-${PN}/src/data/images/unix/ui-*.png; do
+                       newins "${image}" 
"mozc-${image#../../fcitx-${PN}/src/data/images/unix/ui-}"
+               done
+
+               local locale mo_file
+               for mo_file in out_linux/${BUILD_TYPE}/gen/unix/fcitx/po/*.mo; 
do
+                       locale="${mo_file##*/}"
+                       locale="${locale%.mo}"
+                       insinto /usr/share/locale/${locale}/LC_MESSAGES
+                       newins "${mo_file}" fcitx-mozc.mo
+               done
+       fi
+
+       if use ibus; then
+               exeinto /usr/libexec
+               newexe out_linux/${BUILD_TYPE}/ibus_mozc ibus-engine-mozc
+
+               insinto /usr/share/ibus/component
+               doins out_linux/${BUILD_TYPE}/gen/unix/ibus/mozc.xml
+
+               insinto /usr/share/ibus-mozc
+               newins data/images/unix/ime_product_icon_opensource-32.png 
product_icon.png
+               local image
+               for image in data/images/unix/ui-*.png; do
+                       newins "${image}" "${image#data/images/unix/ui-}"
+               done
+       fi
+}
+
+pkg_postinst() {
+       elog
+       elog "ENVIRONMENTAL VARIABLES"
+       elog
+       elog "MOZC_SERVER_DIRECTORY"
+       elog "  Mozc server directory"
+       elog "  Value used by default: \"${EPREFIX}/usr/libexec/mozc\""
+       elog "MOZC_DOCUMENTS_DIRECTORY"
+       elog "  Mozc documents directory"
+       elog "  Value used by default: 
\"${EPREFIX}/usr/libexec/mozc/documents\""
+       elog "MOZC_CONFIGURATION_DIRECTORY"
+       elog "  Mozc configuration directory"
+       elog "  Value used by default: \"~/.mozc\""
+       elog
+       if use emacs; then
+               elog
+               elog "USAGE IN EMACS"
+               elog
+               elog "mozc-mode is minor mode to input Japanese text using Mozc 
server."
+               elog "mozc-mode can be used via LEIM (Library of Emacs Input 
Method)."
+               elog
+               elog "In order to use mozc-mode by default, the following 
settings should be added to"
+               elog "Emacs init file (~/.emacs.d/init.el or ~/.emacs):"
+               elog
+               elog "  (require 'mozc)"
+               elog "  (set-language-environment \"Japanese\")"
+               elog "  (setq default-input-method \"japanese-mozc\")"
+               elog
+               elog "With the above settings, typing C-\\ (which is bound to 
\"toggle-input-method\""
+               elog "by default) will enable mozc-mode."
+               elog
+               elog "Alternatively, at run time, after loading mozc.el, 
mozc-mode can be activated by"
+               elog "calling \"set-input-method\" and entering 
\"japanese-mozc\"."
+               elog
+
+               elisp-site-regen
+       fi
+       xdg_pkg_postinst
+}
+
+pkg_postrm() {
+       if use emacs; then
+               elisp-site-regen
+       fi
+       xdg_pkg_postrm
+}

Reply via email to