Go to:
Gentoo Home
Documentation
Forums
Lists
Bugs
Planet
Store
Wiki
Get Gentoo!
Gentoo's Bugzilla – Attachment 920146 Details for
Bug 950479
dev-java/batik-1.18-r1:failed (compile phase) with jdk-1.8: class file has wrong version 55.0, should be 52.0 (org/mozilla/javascript/ClassShutter.class)
Home
|
New
–
[Ex]
|
Browse
|
Search
|
Privacy Policy
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
environment
environment (text/plain), 107.89 KB, created by
Toralf Förster
on 2025-03-02 20:13:24 UTC
(
hide
)
Description:
environment
Filename:
MIME Type:
Creator:
Toralf Förster
Created:
2025-03-02 20:13:24 UTC
Size:
107.89 KB
patch
obsolete
>declare -x ABI="amd64" >declare -x ABI_MIPS="" >declare -x ABI_S390="" >declare -x ABI_X86="64" >declare -x ADA_TARGET="" >declare -x ALLOW_TEST="network" >declare -x ALSA_CARDS="" >declare -x AMDGPU_TARGETS="" >declare -x ANT_HOME="/usr/share/ant" >declare -x ANT_OPTS="" >declare -x ANT_RESPECT_JAVA_HOME="" >declare -x ANT_TASKS="" >declare -x APACHE2_MODULES="" >declare -x APACHE2_MPMS="" >declare -x ARCH="amd64" >declare -x AUTOJUMP_ERROR_PATH="/root/.local/share/autojump/errors.log" >declare -x AUTOJUMP_SOURCED="1" >declare -a BATIK_MODULES=([0]="batik-constants" [1]="batik-i18n" [2]="batik-test" [3]="batik-util" [4]="batik-awt-util" [5]="batik-css" [6]="batik-ext" [7]="batik-xml" [8]="batik-dom" [9]="batik-parser" [10]="batik-svg-dom" [11]="batik-anim" [12]="batik-gvt" [13]="batik-script" [14]="batik-bridge" [15]="batik-svggen" [16]="batik-transcoder" [17]="batik-codec" [18]="batik-extension" [19]="batik-gui-util" [20]="batik-svgrasterizer" [21]="batik-rasterizer" [22]="batik-slideshow" [23]="batik-swing" [24]="batik-svgbrowser" [25]="batik-squiggle" [26]="batik-svgpp" [27]="batik-ttf2svg" [28]="batik-test-swing" [29]="batik-test-svg") >declare BDEPEND=$'\n\tapp-arch/zip\n\tverify-sig? ( sec-keys/openpgp-keys-apache-xmlgraphics-batik )\n \n\t\t\tverify-sig? (\n\t\t\t\tapp-crypt/gnupg\n\t\t\t\t>=app-portage/gemato-20\n\t\t\t)\n\t\t' >declare -x BINPKG_FORMAT="gpkg" >declare -x BINPKG_GPG_SIGNING_BASE_COMMAND="/usr/bin/flock /run/lock/portage-binpkg-gpg.lock /usr/bin/gpg --sign --armor [PORTAGE_CONFIG]" >declare -x BINPKG_GPG_SIGNING_DIGEST="SHA512" >declare -x BINPKG_GPG_VERIFY_BASE_COMMAND="/usr/bin/gpg --verify --batch --no-tty --no-auto-check-trustdb --status-fd 2 [PORTAGE_CONFIG] [SIGNATURE]" >declare -x BINPKG_GPG_VERIFY_GPG_HOME="/etc/portage/gnupg" >declare -x BOOTSTRAP_USE="unicode pkg-config split-usr xml python_targets_python3_12 python_single_target_python3_12 multilib zstd cet hardened pic xtpax -jit -orc" >declare -x CALLIGRA_FEATURES="" >declare -x CAMERAS="" >declare -x CARGO_TERM_COLOR="never" >declare -x CBUILD="x86_64-pc-linux-gnu" >declare -x CCL_DEFAULT_DIRECTORY="/usr/lib64/clozurecl" >declare -x CFLAGS="-O2 -pipe -march=native -fno-diagnostics-color" >declare -x CFLAGS_amd64="-m64" >declare -x CFLAGS_x32="-mx32" >declare -x CFLAGS_x86="-m32 -mfpmath=sse" >declare -x CHOST="x86_64-pc-linux-gnu" >declare -x CHOST_amd64="x86_64-pc-linux-gnu" >declare -x CHOST_x32="x86_64-pc-linux-gnux32" >declare -x CHOST_x86="i686-pc-linux-gnu" >declare -x CLASSPATH="" >declare -x CMAKE_COLOR_DIAGNOSTICS="OFF" >declare -x CMAKE_COLOR_MAKEFILE="OFF" >declare -x COLLECTD_PLUGINS="" >declare -x CPU_FLAGS_ARM="" >declare -x CPU_FLAGS_PPC="" >declare -x CPU_FLAGS_X86="" >declare -- CP_DEPEND=$'\n\tdev-java/jacl:0\n\t>=dev-java/rhino-1.8.0:0\n\tdev-java/xalan:0\n\tdev-java/xml-commons-external:1.4\n\tdev-java/xmlgraphics-commons:0\n' >declare -x CURL_QUIC="" >declare -x CURL_SSL="" >declare -x CXXFLAGS="-O2 -pipe -march=native -fno-diagnostics-color" >declare -x DEFAULT_ABI="amd64" >declare -x DEFINED_PHASES=" compile install postinst postrm preinst prepare setup test unpack" >declare DEPEND=$'\n\t\n\tdev-java/jacl:0\n\t>=dev-java/rhino-1.8.0:0\n\tdev-java/xalan:0\n\tdev-java/xml-commons-external:1.4\n\tdev-java/xmlgraphics-commons:0\n\n\t>=virtual/jdk-1.8:*\n >=dev-java/java-config-2.2.0-r3 source? ( app-arch/zip ) test? ( dev-java/junit:4 )' >declare DESCRIPTION="XML Graphics Batik" >declare -- DESKTOP_DATABASE_DIR="/usr/share/applications" >declare -x DIROPTIONS="-m0755" >declare -a DOCS=([0]="CHANGES" [1]="NOTICE" [2]="README") >declare -x DOTNET_ROOT="/opt/dotnet-sdk-bin-9.0" >declare -x EAPI="8" >declare -- EBUILD_DEATH_HOOKS=" java-pkg_die" >declare -x ELIBC="glibc" >declare -x ENV_UNSET="CARGO_HOME DBUS_SESSION_BUS_ADDRESS DISPLAY GDK_PIXBUF_MODULE_FILE GOBIN GOPATH PERL5LIB PERL5OPT PERLPREFIX PERL_CORE PERL_MB_OPT PERL_MM_OPT XAUTHORITY XDG_CACHE_HOME XDG_CONFIG_HOME XDG_DATA_HOME XDG_RUNTIME_DIR XDG_STATE_HOME" >declare -- EPOCHREALTIME="1740945933.996928" >declare -- EPOCHSECONDS="1740945933" >declare -x ETCKEEPER_CONF_DIR="/etc/etckeeper" >declare -x EXEOPTIONS="-m0755" >declare -x FCFLAGS="-O2 -pipe -march=native -fno-diagnostics-color" >declare -x FETCHCOMMAND_SSH="bash -c \"x=\\\${2#ssh://} ; host=\\\${x%%/*} ; port=\\\${host##*:} ; host=\\\${host%:*} ; [[ \\\${host} = \\\${port} ]] && port= ; exec rsync --rsh=\\\"ssh \\\${port:+-p\\\${port}} \\\${3}\\\" -avP \\\"\\\${host}:/\\\${x#*/}\\\" \\\"\\\$1\\\"\" rsync \"\${DISTDIR}/\${FILE}\" \"\${URI}\" \"\${PORTAGE_SSH_OPTS}\"" >declare -x FFLAGS="-O2 -pipe -march=native -fno-diagnostics-color" >declare -x FFTOOLS="" >declare -x GCC_COLORS="" >declare -x GCC_SPECS="" >declare -x GENTOO_VM="openjdk-bin-8" >declare -x GIT_PAGER="cat" >declare -x GPG_VERIFY_GROUP_DROP="nogroup" >declare -x GPG_VERIFY_USER_DROP="nobody" >declare -x GPSD_PROTOCOLS="" >declare -x GRUB_PLATFORMS="" >declare -x GUILE_SINGLE_TARGET="" >declare -x GUILE_TARGETS="" >declare HOMEPAGE="https://xmlgraphics.apache.org/batik/" >declare IDEPEND="" >declare -x INHERITED=" desktop java-utils-2 java-pkg-2 java-pkg-simple xdg-utils eapi9-pipestatus verify-sig" >declare -x INPUT_DEVICES="" >declare -x INSOPTIONS="-m0644" >declare IUSE="doc source test verify-sig" >declare -x IUSE_EFFECTIVE="abi_x86_64 alpha amd64 amd64-linux arm arm64 arm64-macos doc elibc_Darwin elibc_SunOS elibc_bionic elibc_glibc elibc_mingw elibc_musl hppa kernel_Darwin kernel_SunOS kernel_linux loong m68k mips ppc ppc-macos ppc64 ppc64-linux prefix prefix-guest prefix-stack riscv s390 source sparc test verify-sig x64-macos x64-solaris x86 x86-linux" >declare -x IUSE_IMPLICIT="abi_x86_64 prefix prefix-guest prefix-stack" >declare -- I_WANT_GLOBAL_JAVA_OPTIONS="true" >declare -x JAVA="/opt/openjdk-bin-8.442_p06/bin/java" >declare -x JAVAC="/opt/openjdk-bin-8.442_p06/bin/javac" >declare -x JAVACC_HOME="/usr/share/javacc/" >declare -x JAVACFLAGS="-source 1.8 -target 1.8" >declare -- JAVA_ENCODING="UTF-8" >declare -x JAVA_HOME="/opt/openjdk-bin-8.442_p06" >declare -- JAVA_JAR_FILENAME="batik.jar" >declare -- JAVA_LAUNCHER_FILENAME="batik" >declare -- JAVA_PKG_ALLOW_VM_CHANGE="yes" >declare -- JAVA_PKG_BUILD_DEPEND_FILE="/var/tmp/portage/dev-java/batik-1.18-r1/temp/java-pkg-build-depend" >declare -- JAVA_PKG_COMPILERS_CONF="/etc/java-config-2/build/compilers.conf" >declare -- JAVA_PKG_COMPILER_DIR="/usr/share/java-config-2/compiler" >declare -- JAVA_PKG_DEPEND_FILE="/var/tmp/portage/dev-java/batik-1.18-r1/temp/java-pkg-depend" >declare -- JAVA_PKG_EXTRA_ENV="/var/tmp/portage/dev-java/batik-1.18-r1/temp/java-pkg-extra-env" >declare -- JAVA_PKG_EXTRA_ENV_VARS="" >declare -- JAVA_PKG_E_DEPEND=">=dev-java/java-config-2.2.0-r3 source? ( app-arch/zip )" >declare -- JAVA_PKG_IUSE="doc source test" >declare -- JAVA_PKG_OPT="0" >declare -- JAVA_PKG_OPTIONAL_DEPEND_FILE="/var/tmp/portage/dev-java/batik-1.18-r1/temp/java-pkg-optional-depend" >declare -- JAVA_TESTING_FRAMEWORKS="junit-4" >declare -x JDK_HOME="/opt/openjdk-bin-8.442_p06" >declare -x KERNEL="linux" >declare -x KEYWORDS="~amd64 ~arm64 ~ppc64" >declare -x L10N="" >declare -x LADSPA_PATH="/usr/lib64/ladspa" >declare -x LAGAN_DIR="/usr/lib64/lagan" >declare -x LAMMPS_POTENTIALS="share/lammps/potentials" >declare -x LANG="C.UTF8" >declare -x LCD_DEVICES="" >declare -x LC_COLLATE="C" >declare -x LC_MESSAGES="C" >declare -x LDFLAGS="-Wl,-O1 -Wl,--as-needed -Wl,-z,pack-relative-relocs -Wl,--defsym=__gentoo_check_ldflags__=0" >declare -x LDFLAGS_amd64="-m elf_x86_64" >declare -x LDFLAGS_x32="-m elf32_x86_64" >declare -x LDFLAGS_x86="-m elf_i386" >declare -x LD_LIBRARY_PATH="/opt/openjdk-bin-8.442_p06/lib/:/opt/openjdk-bin-8.442_p06/lib/server/" >declare -x LEX="flex" >declare -x LIBDIR_amd64="lib64" >declare -x LIBDIR_x32="libx32" >declare -x LIBDIR_x86="lib" >declare -x LIBOPTIONS="-m0644" >declare -x LIBREOFFICE_EXTENSIONS="" >declare -x LICENSE="Apache-2.0" >declare -x LLVM_SLOT="" >declare -x LLVM_TARGETS="" >declare -x LOGTALKHOME="/usr/share/logtalk-3.47.0" >declare -x LUA_SINGLE_TARGET="" >declare -x LUA_TARGETS="" >declare -x MAILTO="tinderbox@zwiebeltoralf.de" >declare -x MAKEOPTS="-O -j4" >declare -x MANPAGER="manpager" >declare -- MAVEN_ID="org.apache.xmlgraphics:batik:1.18" >declare -- MIMEINFO_DATABASE_DIR="/usr/share/mime" >declare -x MIX_REBAR3="/usr/bin/rebar3" >declare -x MOZ_GMP_PATH="/usr/lib64/nsbrowser/plugins/gmp-gmpopenh264/system-installed" >declare -x MSI2LMP_LIBRARY="share/lammps/frc_files" >declare -x MULTILIB_ABIS="amd64 x86" >declare -x MULTILIB_STRICT_DENY="64-bit.*shared object" >declare -x MULTILIB_STRICT_DIRS="/lib32 /lib /usr/lib32 /usr/lib /usr/kde/*/lib32 /usr/kde/*/lib /usr/qt/*/lib32 /usr/qt/*/lib /usr/X11R6/lib32 /usr/X11R6/lib" >declare -x MULTILIB_STRICT_EXEMPT="(perl5|gcc|binutils|eclipse-3|debug|portage|udev|systemd|clang|python-exec|llvm)" >declare -x NGINX_MODULES_HTTP="" >declare -x NGINX_MODULES_MAIL="" >declare -x NGINX_MODULES_STREAM="" >declare -a NO_DELETE=() >declare -x NPM_CONFIG_GLOBALCONFIG="/etc/npm/npmrc" >declare -x OCAML_COLOR="never" >declare -x OFFICE_IMPLEMENTATION="" >declare -x OMP_DYNAMIC="FALSE" >declare -x OMP_NESTED="FALSE" >declare -x OMP_NUM_THREADS="4" >declare -x OPENHAB_CONF="/etc/openhab" >declare -x OPENHAB_HOME="/usr/share/openhab" >declare -x OPENHAB_LOGDIR="/var/log/openhab" >declare -x OPENHAB_RUNTIME="/usr/share/openhab/runtime" >declare -x OPENHAB_USERDATA="/var/lib/openhab" >declare -x OPENMPI_FABRICS="" >declare -x OPENMPI_OFED_FEATURES="" >declare -x OPENMPI_RM="" >declare -x ORACLE_HOME="/usr/lib64/oracle/client" >declare -x PATH="/opt/openjdk-bin-8.442_p06/bin:/usr/lib/portage/python3.12/ebuild-helpers/xattr:/usr/lib/portage/python3.12/ebuild-helpers:/usr/local/sbin:/usr/local/bin:/usr/bin:/opt/bin:/usr/lib/spark-3/bin:/usr/lib/spark-3/sbin:/usr/lib/llvm/19/bin:/usr/lib/llvm/18/bin:/opt/ucsc-genome-browser/bin" >declare -x PAX_MARKINGS="none" >declare PDEPEND="" >declare -x PERL_FEATURES="" >declare -x PHP_TARGETS="" >declare -x PKGSYSTEM_ENABLE_FSYNC="0" >declare -x PKG_CONFIG_PATH="/usr/share/guile-data/3.0/pkgconfig" >declare -x PORTAGE_BZIP2_COMMAND="bzip2" >declare -x PORTAGE_COMPRESSION_COMMAND="zstd -T4" >declare -a PORTAGE_DOCOMPRESS=([0]="/usr/share/doc" [1]="/usr/share/info" [2]="/usr/share/man") >declare -x PORTAGE_DOCOMPRESS_SIZE_LIMIT="128" >declare -a PORTAGE_DOCOMPRESS_SKIP=([0]="/usr/share/doc/batik-1.18-r1/html") >declare -a PORTAGE_DOSTRIP=([0]="/") >declare -a PORTAGE_DOSTRIP_SKIP=() >declare -x PORTAGE_REPO_REVISIONS="{\"gentoo\": \"9130aaa7c850091feee4d2e9f5c6ec3a91d8b5a3\"}" >declare -x PORT_LOGDIR="/var/log/portage" >declare -x POSTGRES_TARGETS="" >declare -x PROFILE_IS_HARDENED="1" >declare -x PROFILE_ONLY_VARIABLES="ARCH ELIBC IUSE_IMPLICIT KERNEL USE_EXPAND_IMPLICIT USE_EXPAND_UNPREFIXED USE_EXPAND_VALUES_ARCH USE_EXPAND_VALUES_ELIBC USE_EXPAND_VALUES_KERNEL" >declare -- PROPERTIES="" >declare -x PYTEST_ADDOPTS="--color=no" >declare -x PYTHONDOCS_3_13="/usr/share/doc/python-docs-3.13.2/html/library" >declare -x PYTHONDONTWRITEBYTECODE="1" >declare -x PYTHON_SINGLE_TARGET="" >declare -x PYTHON_TARGETS="" >declare -x PY_FORCE_COLOR="0" >declare -x QEMU_SOFTMMU_TARGETS="" >declare -x QEMU_USER_TARGETS="" >declare RDEPEND=$'\n\t\n\tdev-java/jacl:0\n\t>=dev-java/rhino-1.8.0:0\n\tdev-java/xalan:0\n\tdev-java/xml-commons-external:1.4\n\tdev-java/xmlgraphics-commons:0\n\n\t>=virtual/jre-1.8:*\n >=dev-java/java-config-2.2.0-r3 source? ( app-arch/zip )' >declare REPOSITORY >declare REQUIRED_USE="" >declare RESTRICT="test" >declare -x RESUMECOMMAND_SSH="bash -c \"x=\\\${2#ssh://} ; host=\\\${x%%/*} ; port=\\\${host##*:} ; host=\\\${host%:*} ; [[ \\\${host} = \\\${port} ]] && port= ; exec rsync --rsh=\\\"ssh \\\${port:+-p\\\${port}} \\\${3}\\\" -avP \\\"\\\${host}:/\\\${x#*/}\\\" \\\"\\\$1\\\"\" rsync \"\${DISTDIR}/\${FILE}\" \"\${URI}\" \"\${PORTAGE_SSH_OPTS}\"" >declare -x RUBY_TARGETS="" >declare -x RUST_TEST_TASKS="4" >declare -x RUST_TEST_THREADS="4" >declare -x R_HOME="/usr/lib64/R" >declare -x S="/var/tmp/portage/dev-java/batik-1.18-r1/work/batik-1.18" >declare -x SANDBOX_DEBUG="0" >declare -x SANDBOX_DENY="" >declare -x SANDBOX_METHOD="any" >declare -x SANDBOX_PREDICT="/var/tmp/portage/dev-java/batik-1.18-r1/homedir:/dev/crypto:/var/cache/man:/dev/random:/proc/self/coredump_filter:/dev/random:/proc/self/coredump_filter:/dev/random:/proc/self/coredump_filter:/dev/random:/proc/self/coredump_filter:/var/cache/fontconfig" >declare -x SANDBOX_READ="/:/var/tmp/portage" >declare -x SANDBOX_VERBOSE="1" >declare -x SANDBOX_WRITE=":/dev/console:/dev/fd:/dev/full:/dev/null:/dev/ptmx:/dev/pts/:/dev/pty:/dev/shm:/dev/tts:/dev/tty:/dev/vc/:/dev/zero:/proc/self/fd:/run/firejail:/tmp/:/usr/lib/cf:/usr/lib/conftest:/usr/lib32/cf:/usr/lib32/conftest:/usr/lib64/cf:/usr/lib64/conftest:/usr/tmp/:/usr/tmp/cf:/usr/tmp/conftest:/var/tmp/:/var/tmp/portage:/var/tmp/portage/dev-java/batik-1.18-r1/homedir/.bash_history" >declare -x SANE_BACKENDS="" >declare -x SHELL="/bin/bash" >declare -x SLOT="0" >declare -x SPARK_HOME="/usr/lib/spark-3" >declare -i SRANDOM="1293853474" >declare SRC_URI=$'mirror://apache/xmlgraphics/batik/source/batik-src-1.18.tar.gz\n\tverify-sig? ( https://downloads.apache.org/xmlgraphics/batik/source/batik-src-1.18.tar.gz.asc )' >declare -x SVDIR="/etc/service/" >declare -x SYMLINK_LIB="no" >declare -x TERMINFO="/etc/terminfo" >declare -x TNS_ADMIN="/etc/oracle/" >declare -x TWISTED_DISABLE_WRITING_OF_PLUGIN_CACHE="1" >declare -x USE="abi_x86_64 amd64 elibc_glibc kernel_linux" >declare -x USERLAND="GNU" >declare -x USE_EXPAND_IMPLICIT="ARCH ELIBC KERNEL" >declare -x USE_EXPAND_UNPREFIXED="ARCH" >declare -x USE_EXPAND_VALUES_ARCH="alpha amd64 amd64-linux arm arm64 arm64-macos hppa loong m68k mips ppc ppc64 ppc64-linux ppc-macos riscv s390 sparc x64-macos x64-solaris x86 x86-linux" >declare -x USE_EXPAND_VALUES_ELIBC="bionic Darwin glibc mingw musl SunOS" >declare -x USE_EXPAND_VALUES_KERNEL="Darwin linux SunOS" >declare -x UWSGI_PLUGINS="" >declare -- VERIFY_SIG_METHOD="openpgp" >declare -- VERIFY_SIG_OPENPGP_KEY_PATH="/usr/share/openpgp-keys/xmlgraphics-batik.apache.org.asc" >declare -- VERIFY_SIG_OPENPGP_KEY_REFRESH="no" >declare -x VGL_READBACK="pbo" >declare -x VIDEO_CARDS="" >declare -x VOICEMAIL_STORAGE="" >declare -x WANT_JAVA_CONFIG="2" >declare -x XTABLES_ADDONS="" >declare -x XZ_OPT="-9 -T4" >declare -- _DESKTOP_ECLASS="1" >declare -- _JAVA_PKG_2_ECLASS="1" >declare -- _JAVA_PKG_SIMPLE_ECLASS="1" >declare -- _JAVA_UTILS_2_ECLASS="1" >declare -- _VERIFY_SIG_ECLASS="1" >declare -x __E_DESTTREE="/usr" >declare -x __E_DOCDESTTREE="" >declare -x __E_EXEDESTTREE="" >declare -x __E_INSDESTTREE="" >declare -x ac_cv_c_undeclared_builtin_options="none needed" >declare -x enable_year2038="no" >declare -- framework="junit-4" >declare -x gl_cv_compiler_check_decl_option="-Werror=implicit-function-declaration" >declare -x gl_cv_func_getcwd_path_max="yes" >declare -- load="40" >declare -x name="23.0_hardened-20250222-171007" >declare -- vcpu="32" >SwitchGCC () >{ > local highest=$(gcc-config --list-profiles --nocolor | cut -f 3 -d ' ' -s | grep -E 'x86_64-(pc|gentoo)-linux-(gnu|musl)-[0-9]+$' | tail -n 1); > if [[ -z $highest ]]; then > Mail "cannot get GCC version"; > return; > fi; > if [[ $(gcc-config --get-current-profile --nocolor) != "$highest" ]]; then > local v; > v=$(gcc -dumpversion); > gcc-config --nocolor $highest; > source_profile; > add2backlog "%emerge -1 --selective=n --deep=0 -u dev-build/libtool"; > if grep -q '^LIBTOOL="rdlibtool"' /etc/portage/make.conf; then > add2backlog "dev-build/slibtool"; > fi; > add2backlog "%emerge --unmerge sys-devel/gcc:$(cut -f 1 -d '.' <<< $v)"; > fi >} >declare -fx SwitchGCC >__tinderbox_checkEOL () >{ > if [[ -f /var/tmp/tb/EOL || -f /var/tmp/tb/STOP ]]; then > exit 42; > fi >} >_gpg_verify_signed_checksums () >{ > local checksum_file=${1}; > local algo=${2}; > local files=${3}; > local key=${4}; > verify-sig_verify_unsigned_checksums - "${algo}" "${files}" < <(verify-sig_verify_message "${checksum_file}" - "${key}") >} >_iconins () >{ > ( insopts -m 0644; > local funcname=$1; > shift; > local size dir; > local context=apps; > local theme=hicolor; > while [[ $# -gt 0 ]]; do > case $1 in > -s | --size) > if [[ ${2%%x*}x${2%%x*} == "$2" ]]; then > size=${2%%x*}; > else > size=${2}; > fi; > case ${size} in > 16 | 22 | 24 | 32 | 36 | 48 | 64 | 72 | 96 | 128 | 192 | 256 | 512 | 1024) > size=${size}x${size} > ;; > symbolic | scalable) > > ;; > *) > eerror "${size} is an unsupported icon size!"; > exit 1 > ;; > esac; > shift 2 > ;; > -t | --theme) > theme=${2}; > shift 2 > ;; > -c | --context) > context=${2}; > shift 2 > ;; > *) > if [[ -z ${size} ]]; then > insinto /usr/share/pixmaps; > else > insinto /usr/share/icons/${theme}/${size}/${context}; > fi; > if [[ ${funcname} == doicon ]]; then > if [[ -f $1 ]]; then > doins "${1}"; > else > if [[ -d $1 ]]; then > shopt -s nullglob; > doins "${1}"/*.{png,svg}; > shopt -u nullglob; > else > eerror "${1} is not a valid file/directory!"; > exit 1; > fi; > fi; > else > break; > fi; > shift 1 > ;; > esac; > done; > if [[ ${funcname} == newicon ]]; then > newins "$@"; > fi ) >} >add2backlog () >{ > local bl=/var/tmp/tb/backlog.1st; > if [[ $1 == '@preserved-rebuild' ]]; then > sed -i -e "/$1/d" $bl; > if [[ -s $bl ]]; then > sed -i -e "1 i$1" $bl; > else > echo "$1" >> $bl; > fi; > else > if [[ $1 =~ "emerge -e @world" ]]; then > echo "%emerge --resume" >> $bl; > else > sed -i -e "/^$(sed -e 's,/,\\/,g' <<< $1)$/d" $bl; > echo "$1" >> $bl; > fi; > fi; > if [[ $1 != "%SwitchGCC" ]] && grep -q '%SwitchGCC' $bl; then > sed -i -e '/%SwitchGCC/d' $bl; > echo "%SwitchGCC" >> $bl; > fi >} >declare -fx add2backlog >doicon () >{ > _iconins ${FUNCNAME} "$@" >} >domenu () >{ > ( local i ret=0; > insopts -m 0644; > insinto /usr/share/applications; > for i in "$@"; > do > if [[ -d ${i} ]]; then > doins "${i}"/*.desktop; > ((ret|=$?)); > else > doins "${i}"; > ((ret|=$?)); > fi; > done; > exit ${ret} ) >} >eant () >{ > debug-print-function ${FUNCNAME} $*; > local antflags="-Dnoget=true -Dmaven.mode.offline=true -Dbuild.sysclasspath=ignore"; > java-pkg_init-compiler_; > local compiler="${GENTOO_COMPILER}"; > local compiler_env="${JAVA_PKG_COMPILER_DIR}/${compiler}"; > local build_compiler="$(source ${compiler_env} > /dev/null 2>&1; echo ${ANT_BUILD_COMPILER})"; > if [[ "${compiler}" != "javac" && -z "${build_compiler}" ]]; then > die "ANT_BUILD_COMPILER undefined in ${compiler_env}"; > fi; > if [[ ${compiler} != "javac" ]]; then > antflags="${antflags} -Dbuild.compiler=${build_compiler}"; > local build_compiler_deps="$(source ${JAVA_PKG_COMPILER_DIR}/${compiler} > /dev/null 2>&1; echo ${ANT_BUILD_COMPILER_DEPS})"; > if [[ -n ${build_compiler_deps} ]]; then > antflags="${antflags} -lib $(java-config -p ${build_compiler_deps})"; > fi; > fi; > for arg in "${@}"; > do > if [[ ${arg} = -lib ]]; then > if is-java-strict; then > eerror "You should not use the -lib argument to eant because it will fail"; > eerror "with JAVA_PKG_STRICT. Please use for example java-pkg_jar-from"; > eerror "or ant properties to make dependencies available."; > eerror "For ant tasks use WANT_ANT_TASKS or ANT_TASKS from."; > eerror "split ant (>=dev-java/ant-core-1.7)."; > die "eant -lib is deprecated/forbidden"; > else > echo "eant -lib is deprecated. Turn JAVA_PKG_STRICT on for"; > echo "more info."; > fi; > fi; > done; > local want_ant_tasks; > for i in ${WANT_ANT_TASKS}; > do > if [[ ${i} = */*:* ]]; then > i=${i#*/}; > i=${i%:0}; > want_ant_tasks+="${i/:/-} "; > else > want_ant_tasks+="${i} "; > fi; > done; > ANT_TASKS="${ANT_TASKS:-${want_ant_tasks% }}"; > ANT_TASKS="${JAVA_PKG_FORCE_ANT_TASKS:-${ANT_TASKS}}"; > ANT_TASKS="${ANT_TASKS:-none}"; > if [[ "${ANT_TASKS}" == "all" ]]; then > einfo "Using all available ANT_TASKS"; > else > if [[ "${ANT_TASKS}" == "none" ]]; then > einfo "Disabling all optional ANT_TASKS"; > else > einfo "Using following ANT_TASKS: ${ANT_TASKS}"; > fi; > fi; > export ANT_TASKS; > [[ -n ${JAVA_PKG_DEBUG} ]] && antflags="${antflags} --execdebug -debug"; > [[ -n ${PORTAGE_QUIET} ]] && antflags="${antflags} -q"; > local gcp="${EANT_GENTOO_CLASSPATH}"; > local getjarsarg=""; > if [[ ${EBUILD_PHASE} = "test" ]]; then > antflags="${antflags} -DJunit.present=true"; > getjarsarg="--with-dependencies"; > local re="\bant-junit4?([-:]\S+)?\b"; > [[ ${ANT_TASKS} =~ ${re} ]] && gcp+=" ${BASH_REMATCH[0]}"; > else > antflags="${antflags} -Dmaven.test.skip=true"; > fi; > local cp; > for atom in ${gcp}; > do > cp+=":$(java-pkg_getjars ${getjarsarg} ${atom})"; > done; > [[ -n ${EANT_NEEDS_TOOLS} ]] && cp+=":$(java-config --tools)"; > [[ -n ${EANT_GENTOO_CLASSPATH_EXTRA} ]] && cp+=":${EANT_GENTOO_CLASSPATH_EXTRA}"; > if [[ -n ${cp#:} ]]; then > antflags="${antflags} -Dgentoo.classpath=${cp#:}"; > fi; > [[ -n ${JAVA_PKG_DEBUG} ]] && echo ant ${antflags} "${@}"; > debug-print "Calling ant (GENTOO_VM: ${GENTOO_VM}): ${antflags} ${@}"; > ant ${antflags} "${@}" || die "eant failed" >} >ejavac () >{ > debug-print-function ${FUNCNAME} $*; > local compiler_executable; > compiler_executable=$(java-pkg_get-javac); > local javac_args; > javac_args="$(java-pkg_javac-args)"; > if [[ -n ${JAVA_PKG_DEBUG} ]]; then > einfo "Verbose logging for \"${FUNCNAME}\" function"; > einfo "Compiler executable: ${compiler_executable}"; > einfo "Extra arguments: ${javac_args}"; > einfo "Complete command:"; > einfo "${compiler_executable} ${javac_args} ${@}"; > fi; > local args=(${compiler_executable} ${javac_args} "${@}"); > echo "${args[@]}" 1>&2; > "${args[@]}" || die "ejavac failed" >} >ejavadoc () >{ > debug-print-function ${FUNCNAME} $*; > local javadoc_args=""; > if java-pkg_is-vm-version-ge "1.8"; then > javadoc_args="-Xdoclint:none"; > fi; > if [[ -n ${JAVA_PKG_DEBUG} ]]; then > einfo "Verbose logging for \"${FUNCNAME}\" function"; > einfo "Javadoc executable: javadoc"; > einfo "Extra arguments: ${javadoc_args}"; > einfo "Complete command:"; > einfo "javadoc ${javadoc_args} ${@}"; > fi; > if [[ -n "${JAVADOC_SRC_DIRS[@]}" ]]; then > mkdir -p target/api || die "cannot create target/api"; > local dependency; > for dependency in ${JAVADOC_CLASSPATH}; > do > classpath="${classpath}:$(java-pkg_getjars --build-only --with-dependencies ${dependency})"; > done; > find "${JAVADOC_SRC_DIRS[@]}" -name '*.java' > sources; > javadoc "${javadoc_args}" -d target/api -cp "${classpath}" -quiet @sources || die "ejavadoc failed"; > else > local args=(javadoc ${javadoc_args} "${@}"); > echo "${args[@]}" 1>&2; > "${args[@]}" || die "ejavadoc failed"; > fi >} >ejunit () >{ > debug-print-function ${FUNCNAME} $*; > ejunit_ "junit" "${@}" >} >ejunit4 () >{ > debug-print-function ${FUNCNAME} $*; > ejunit_ "junit-4" "${@}" >} >ejunit_ () >{ > debug-print-function ${FUNCNAME} $*; > local pkgs; > if [[ -f ${JAVA_PKG_DEPEND_FILE} ]]; then > for atom in $(cat ${JAVA_PKG_DEPEND_FILE} | tr : ' '); > do > pkgs=${pkgs},$(echo ${atom} | sed -re "s/^.*@//"); > done; > fi; > local junit=${1}; > shift 1; > local cp=$(java-pkg_getjars --build-only --with-dependencies ${junit}${pkgs}); > if [[ ${1} = -cp || ${1} = -classpath ]]; then > cp="${2}:${cp}"; > shift 2; > else > cp=".:${cp}"; > fi; > local runner=junit.textui.TestRunner; > if [[ "${junit}" == "junit-4" ]]; then > runner=org.junit.runner.JUnitCore; > fi; > local args=(-cp ${cp} -Djava.io.tmpdir="${T}" -Djava.awt.headless=true ${JAVA_TEST_EXTRA_ARGS[@]} ${runner} ${JAVA_TEST_RUNNER_EXTRA_ARGS[@]} ${@}); > debug-print "Calling: java ${args[@]}"; > java "${args[@]}" || die "Running junit failed" >} >etestng () >{ > debug-print-function ${FUNCNAME} $*; > local runner=org.testng.TestNG; > if [[ ${PN} != testng ]]; then > local cp=$(java-pkg_getjars --build-only --with-dependencies testng); > else > local cp=testng.jar; > fi; > local tests; > if [[ ${1} = -cp || ${1} = -classpath ]]; then > cp="${cp}:${2}"; > shift 2; > else > cp="${cp}:."; > fi; > for test in ${@}; > do > tests+="${test},"; > done; > local args=(-cp ${cp} -Djava.io.tmpdir="${T}" -Djava.awt.headless=true ${JAVA_TEST_EXTRA_ARGS[@]} ${runner} ${JAVA_TEST_RUNNER_EXTRA_ARGS[@]}); > if [[ ! "${JAVA_TEST_RUNNER_EXTRA_ARGS[@]}" =~ "-usedefaultlisteners" ]]; then > args+=(-verbose 3 -usedefaultlisteners true); > fi; > if [[ "${test%.xml}" == "${test}" ]]; then > args+=(-testclass ${tests}); > else > args+=(${tests%,}); > fi; > debug-print "java ${args[@]}"; > java ${args[@]} || die "Running TestNG failed." >} >is-java-strict () >{ > [[ -n ${JAVA_PKG_STRICT} ]]; > return $? >} >java-pkg-2_pkg_preinst () >{ > java-utils-2_pkg_preinst >} >java-pkg-2_pkg_setup () >{ > java-pkg_init >} >java-pkg-2_src_prepare () >{ > java-utils-2_src_prepare >} >java-pkg-simple_getclasspath () >{ > debug-print-function ${FUNCNAME} $*; > local dependency; > local deep_jars="--with-dependencies"; > local buildonly_jars="--build-only"; > classpath+=":${JAVA_GENTOO_CLASSPATH_EXTRA}"; > [[ -n ${JAVA_NEEDS_TOOLS} ]] && classpath+=":$(java-config --tools)"; > for dependency in ${JAVA_CLASSPATH_EXTRA}; > do > classpath="${classpath}:$(java-pkg_getjars ${buildonly_jars} ${deep_jars} ${dependency})"; > done; > if has test ${JAVA_PKG_IUSE} && use test; then > for dependency in ${JAVA_TEST_GENTOO_CLASSPATH}; > do > classpath="${classpath}:$(java-pkg_getjars ${buildonly_jars} ${deep_jars} ${dependency})"; > done; > fi; > for dependency in ${JAVA_GENTOO_CLASSPATH}; > do > classpath="${classpath}:$(java-pkg_getjars ${deep_jars} ${dependency})"; > done; > while [[ $classpath = *::* ]]; do > classpath="${classpath//::/:}"; > done; > classpath=${classpath%:}; > classpath=${classpath#:}; > debug-print "CLASSPATH=${classpath}" >} >java-pkg-simple_prepend_resources () >{ > debug-print-function ${FUNCNAME} $*; > local destination="${1}"; > shift 1; > [[ -n "$@" ]] || return; > local resources=("${@}"); > for resource in "${resources[@]}"; > do > cp -rT "${resource:-.}" "${destination}" || die "Could not copy resources from ${resource:-.} to ${destination}"; > done >} >java-pkg-simple_src_compile () >{ > [[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return; > local sources=sources.lst classes=target/classes apidoc=target/api moduleinfo; > if has binary ${JAVA_PKG_IUSE} && use binary; then > for dependency in ${JAVA_GENTOO_CLASSPATH//,/ }; > do > java-pkg_record-jar_ ${dependency}; > done; > cp "${DISTDIR}"/${JAVA_BINJAR_FILENAME} ${JAVA_JAR_FILENAME} || die "Could not copy the binary jar file to ${S}"; > return 0; > else > java-pkg_gen-cp JAVA_GENTOO_CLASSPATH; > fi; > local target="$(java-pkg_get-target)"; > if [[ ${target#1.} -lt 9 ]]; then > find "${JAVA_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${sources}; > else > find "${JAVA_SRC_DIR[@]}" -name \*.java > ${sources}; > fi; > moduleinfo=$(find "${JAVA_SRC_DIR[@]}" -name module-info.java); > mkdir -p ${classes} || die "Could not create target directory"; > local classpath=""; > java-pkg-simple_getclasspath; > java-pkg-simple_prepend_resources ${classes} "${JAVA_RESOURCE_DIRS[@]}"; > if [[ -z ${moduleinfo} ]] || [[ ${target#1.} -lt 9 ]]; then > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+-classpath ${classpath}} ${JAVAC_ARGS} @${sources}; > else > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+--module-path ${classpath}} --module-version ${PV} ${JAVAC_ARGS} @${sources}; > fi; > if [[ -n ${moduleinfo} ]] && [[ ${target#1.} -lt 9 ]]; then > if java-pkg_is-vm-version-ge "9"; then > local tmp_source=${JAVA_PKG_WANT_SOURCE} tmp_target=${JAVA_PKG_WANT_TARGET}; > JAVA_PKG_WANT_SOURCE="9"; > JAVA_PKG_WANT_TARGET="9"; > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+--module-path ${classpath}} --module-version ${PV} ${JAVAC_ARGS} "${moduleinfo}"; > JAVA_PKG_WANT_SOURCE=${tmp_source}; > JAVA_PKG_WANT_TARGET=${tmp_target}; > else > eqawarn "Need at least JDK 9 to compile module-info.java in src_compile."; > eqawarn "Please adjust DEPEND accordingly. See https://bugs.gentoo.org/796875#c3"; > fi; > fi; > if has doc ${JAVA_PKG_IUSE} && use doc; then > if [[ -n ${JAVADOC_SRC_DIRS} ]]; then > einfo "JAVADOC_SRC_DIRS exists, you need to call ejavadoc separately"; > else > mkdir -p ${apidoc}; > if [[ -z ${moduleinfo} ]] || [[ ${target#1.} -lt 9 ]]; then > ejavadoc -d ${apidoc} -encoding ${JAVA_ENCODING} -docencoding UTF-8 -charset UTF-8 ${classpath:+-classpath ${classpath}} ${JAVADOC_ARGS:- -quiet} @${sources} || die "javadoc failed"; > else > ejavadoc -d ${apidoc} -encoding ${JAVA_ENCODING} -docencoding UTF-8 -charset UTF-8 ${classpath:+--module-path ${classpath}} ${JAVADOC_ARGS:- -quiet} @${sources} || die "javadoc failed"; > fi; > fi; > fi; > local jar_args; > if [[ -e ${classes}/META-INF/MANIFEST.MF ]]; then > sed '/Created-By: /Id' -i ${classes}/META-INF/MANIFEST.MF; > jar_args="cfm ${JAVA_JAR_FILENAME} ${classes}/META-INF/MANIFEST.MF"; > else > jar_args="cf ${JAVA_JAR_FILENAME}"; > fi; > jar ${jar_args} -C ${classes} . || die "jar failed"; > if [[ -n "${JAVA_AUTOMATIC_MODULE_NAME}" ]]; then > echo "Automatic-Module-Name: ${JAVA_AUTOMATIC_MODULE_NAME}" >> "${T}/add-to-MANIFEST.MF" || die "adding module name failed"; > fi; > if [[ -n "${JAVA_MAIN_CLASS}" ]]; then > echo "Main-Class: ${JAVA_MAIN_CLASS}" >> "${T}/add-to-MANIFEST.MF" || die "adding main class failed"; > fi; > if [[ -f "${T}/add-to-MANIFEST.MF" ]]; then > jar ufmv ${JAVA_JAR_FILENAME} "${T}/add-to-MANIFEST.MF" || die "updating MANIFEST.MF failed"; > rm -f "${T}/add-to-MANIFEST.MF" || die "cannot remove"; > fi >} >java-pkg-simple_src_install () >{ > [[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return; > local sources=sources.lst classes=target/classes apidoc=target/api; > java-pkg_dojar ${JAVA_JAR_FILENAME}; > if [[ -n ${JAVA_MAIN_CLASS} ]]; then > java-pkg_dolauncher "${JAVA_LAUNCHER_FILENAME}" --main ${JAVA_MAIN_CLASS}; > fi; > if has doc ${JAVA_PKG_IUSE} && use doc; then > java-pkg_dojavadoc ${apidoc}; > fi; > if has source ${JAVA_PKG_IUSE} && use source; then > local srcdirs=""; > if [[ -n "${JAVA_SRC_DIR[@]}" ]]; then > local parent child; > for parent in "${JAVA_SRC_DIR[@]}"; > do > srcdirs="${srcdirs} ${parent}"; > done; > else > srcdirs="$(cut -d/ -f1 ${sources} | sort -u)"; > fi; > java-pkg_dosrc ${srcdirs}; > fi; > einstalldocs >} >java-pkg-simple_src_test () >{ > [[ ${JAVA_PKG_OPT} == 1 ]] && ! use ${JAVA_PKG_OPT_USE} && return; > local test_sources=test_sources.lst classes=target/test-classes moduleinfo; > local tests_to_run classpath; > if ! has test ${JAVA_PKG_IUSE}; then > return; > else > if ! use test; then > return; > else > if [[ ! -n "${JAVA_TESTING_FRAMEWORKS}" ]]; then > return; > fi; > fi; > fi; > rm -rf ${classes} || die; > mkdir -p ${classes} || die "Could not create target directory for testing"; > if [[ -d generated-test ]]; then > cp -r generated-test/* "${classes}" || die "cannot copy generated test classes"; > fi; > classpath="${classes}:${JAVA_JAR_FILENAME}"; > java-pkg-simple_getclasspath; > java-pkg-simple_prepend_resources ${classes} "${JAVA_TEST_RESOURCE_DIRS[@]}"; > local target="$(java-pkg_get-target)"; > if [[ ${target#1.} -lt 9 ]]; then > find "${JAVA_TEST_SRC_DIR[@]}" -name \*.java ! -name module-info.java > ${test_sources}; > else > find "${JAVA_TEST_SRC_DIR[@]}" -name \*.java > ${test_sources}; > fi; > moduleinfo=$(find "${JAVA_TEST_SRC_DIR[@]}" -name module-info.java); > if [[ -s ${test_sources} ]]; then > if [[ -z ${moduleinfo} ]] || [[ ${target#1.} -lt 9 ]]; then > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+-classpath ${classpath}} ${JAVAC_ARGS} @${test_sources}; > else > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+--module-path ${classpath}} --module-version ${PV} ${JAVAC_ARGS} @${test_sources}; > fi; > fi; > if [[ -n ${moduleinfo} ]] && [[ ${target#1.} -lt 9 ]]; then > if java-pkg_is-vm-version-ge "9"; then > local tmp_source=${JAVA_PKG_WANT_SOURCE} tmp_target=${JAVA_PKG_WANT_TARGET}; > JAVA_PKG_WANT_SOURCE="9"; > JAVA_PKG_WANT_TARGET="9"; > ejavac -d ${classes} -encoding ${JAVA_ENCODING} ${classpath:+--module-path ${classpath}} --module-version ${PV} ${JAVAC_ARGS} "${moduleinfo}"; > JAVA_PKG_WANT_SOURCE=${tmp_source}; > JAVA_PKG_WANT_TARGET=${tmp_target}; > else > ewarn "Need at least JDK 9 to compile module-info.java in src_test,"; > ewarn "see https://bugs.gentoo.org/796875"; > fi; > fi; > if [[ -n ${JAVA_TEST_RUN_ONLY} ]]; then > tests_to_run="${JAVA_TEST_RUN_ONLY[@]}"; > else > tests_to_run=$(find "${classes}" -type f \( -name "*Test.class" -o -name "Test*.class" -o -name "*Tests.class" -o -name "*TestCase.class" \) ! -name "*Abstract*" ! -name "*BaseTest*" ! -name "*TestTypes*" ! -name "*TestUtils*" ! -name "*\$*"); > tests_to_run=${tests_to_run//"${classes}"\/}; > tests_to_run=${tests_to_run//.class}; > tests_to_run=${tests_to_run//\//.}; > for class in "${JAVA_TEST_EXCLUDES[@]}"; > do > tests_to_run=${tests_to_run//${class}}; > done; > fi; > for framework in ${JAVA_TESTING_FRAMEWORKS}; > do > case ${framework} in > junit) > ejunit -classpath "${classpath}" ${tests_to_run} > ;; > junit-4) > ejunit4 -classpath "${classpath}" ${tests_to_run} > ;; > pkgdiff) > java-pkg-simple_test_with_pkgdiff_ > ;; > testng) > etestng -classpath "${classpath}" ${tests_to_run} > ;; > *) > elog "No suitable function found for framework ${framework}" > ;; > esac; > done >} >java-pkg-simple_test_with_pkgdiff_ () >{ > debug-print-function ${FUNCNAME} $*; > if [[ ! ${ARCH} == "amd64" ]]; then > elog "For architectures other than amd64, " "the pkgdiff test is currently unavailable " "because 'dev-util/japi-compliance-checker " "and 'dev-util/pkgdiff' do not support those architectures."; > return; > fi; > local report1=${PN}-japi-compliance-checker.html; > local report2=${PN}-pkgdiff.html; > if [[ -f "${DISTDIR}/${JAVA_BINJAR_FILENAME}" ]]; then > cp "${DISTDIR}/${JAVA_BINJAR_FILENAME}" ./ || die "Cannot copy binjar file to ${S}."; > japi-compliance-checker ${JAVA_BINJAR_FILENAME} ${JAVA_JAR_FILENAME} --lib=${PN} -v1 ${PV}-bin -v2 ${PV} -report-path ${report1} --binary || die "japi-compliance-checker returns $?," "check the report in ${S}/${report1}"; > pkgdiff ${JAVA_BINJAR_FILENAME} ${JAVA_JAR_FILENAME} -vnum1 ${PV}-bin -vnum2 ${PV} -skip-pattern "META-INF|.class$" -name ${PN} -report-path ${report2} || die "pkgdiff returns $?, check the report in ${S}/${report2}"; > fi >} >java-pkg_addcp () >{ > java-pkg_append_ JAVA_PKG_CLASSPATH "${@}"; > java-pkg_do_write_ >} >java-pkg_addres () >{ > debug-print-function ${FUNCNAME} $*; > [[ ${#} -lt 2 ]] && die "at least two arguments needed"; > local jar=$(realpath "$1" || die "realpath $1 failed"); > local dir="$2"; > shift 2; > pushd "${dir}" > /dev/null || die "pushd ${dir} failed"; > find -L -type f ! -path "./target/*" ! -path "./sources.lst" ! -name "MANIFEST.MF" ! -regex ".*\.\(class\|jar\|java\)" "${@}" -print0 | xargs -r0 jar uf "${jar}" || die "jar failed"; > popd > /dev/null || die "popd failed" >} >java-pkg_announce-qa-violation () >{ > local nodie; > if [[ ${1} == "--nodie" ]]; then > nodie="true"; > shift; > fi; > [[ -z "${nodie}" ]] && is-java-strict && die "${@}" >} >java-pkg_ant-tasks-depend () >{ > debug-print-function ${FUNCNAME} ${WANT_ANT_TASKS}; > if [[ -n "${WANT_ANT_TASKS}" ]]; then > local DEP=""; > for i in ${WANT_ANT_TASKS}; > do > if [[ ${i} = ant-* ]]; then > DEP="${DEP}dev-java/${i} "; > else > if [[ ${i} = */*:* ]]; then > DEP="${DEP}${i} "; > else > echo "Invalid atom in WANT_ANT_TASKS: ${i}"; > return 1; > fi; > fi; > done; > echo ${DEP}; > return 0; > else > return 0; > fi >} >java-pkg_append_ () >{ > debug-print-function ${FUNCNAME} $*; > local var="${1}" value="${2}"; > if [[ -z "${!var}" ]]; then > export ${var}="${value}"; > else > local oldIFS=${IFS} cur haveit; > IFS=':'; > for cur in ${!var}; > do > if [[ ${cur} == ${value} ]]; then > haveit="yes"; > break; > fi; > done; > [[ -z ${haveit} ]] && export ${var}="${!var}:${value}"; > IFS=${oldIFS}; > fi >} >java-pkg_build-vm-from-handle () >{ > debug-print-function ${FUNCNAME} "$*"; > local vm; > vm=$(java-pkg_get-current-vm 2> /dev/null); > if [[ $? -eq 0 ]]; then > if has ${vm} ${JAVA_PKG_WANT_BUILD_VM}; then > echo ${vm}; > return 0; > fi; > fi; > for vm in ${JAVA_PKG_WANT_BUILD_VM}; > do > local java_config; > for java_config in java-config{,-2}; > do > type -p ${java_config} > /dev/null && break; > done; > [[ -z ${java_config} ]] && die "No java-config binary in PATH"; > if ${java_config} --select-vm=${vm} 2> /dev/null; then > echo ${vm}; > return 0; > fi; > done; > eerror "${FUNCNAME}: No vm found for handles: ${JAVA_PKG_WANT_BUILD_VM}"; > return 1 >} >java-pkg_check-phase () >{ > local phase=${1}; > local funcname=${FUNCNAME[1]}; > if [[ ${EBUILD_PHASE} != ${phase} ]]; then > local msg="${funcname} used outside of src_${phase}"; > java-pkg_announce-qa-violation "${msg}"; > fi >} >java-pkg_check-versioned-jar () >{ > local jar=${1}; > if [[ ${jar} =~ ${PV} ]]; then > java-pkg_announce-qa-violation "installing versioned jar '${jar}'"; > fi >} >java-pkg_clean () >{ > NO_DELETE=(); > for keep in ${JAVA_PKG_NO_CLEAN[@]}; > do > NO_DELETE+=('!' '-path' ${keep}); > done; > find "${@}" '(' -name '*.class' -o -name '*.jar' ${NO_DELETE[@]} ')' -type f -delete -print || die >} >java-pkg_current-vm-matches () >{ > has $(java-pkg_get-current-vm) ${@}; > return $? >} >java-pkg_die () >{ > echo "!!! When you file a bug report, please include the following information:" 1>&2; > echo "GENTOO_VM=${GENTOO_VM} CLASSPATH=\"${CLASSPATH}\" JAVA_HOME=\"${JAVA_HOME}\"" 1>&2; > echo "JAVACFLAGS=\"${JAVACFLAGS}\" COMPILER=\"${GENTOO_COMPILER}\"" 1>&2; > echo "and of course, the output of emerge --info =${CATEGORY}/${PF}" 1>&2 >} >java-pkg_do_write_ () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_init_paths_; > dodir "${JAVA_PKG_SHAREPATH}"; > ( echo "DESCRIPTION=\"${DESCRIPTION}\""; > echo "GENERATION=\"2\""; > echo "SLOT=\"${SLOT}\""; > echo "CATEGORY=\"${CATEGORY}\""; > echo "PVR=\"${PVR}\""; > echo "LIBDIR=\"$(get_libdir)\""; > [[ -n "${JAVA_PKG_CLASSPATH}" ]] && echo "CLASSPATH=\"${JAVA_PKG_CLASSPATH}\""; > [[ -n "${JAVA_PKG_LIBRARY}" ]] && echo "LIBRARY_PATH=\"${JAVA_PKG_LIBRARY}\""; > [[ -n "${JAVA_PROVIDE}" ]] && echo "PROVIDES=\"${JAVA_PROVIDE}\""; > [[ -f "${JAVA_PKG_DEPEND_FILE}" ]] && echo "DEPEND=\"$(sort -u "${JAVA_PKG_DEPEND_FILE}" | tr '\n' ':')\""; > [[ -f "${JAVA_PKG_OPTIONAL_DEPEND_FILE}" ]] && echo "OPTIONAL_DEPEND=\"$(sort -u "${JAVA_PKG_OPTIONAL_DEPEND_FILE}" | tr '\n' ':')\""; > echo "VM=\"$(echo ${RDEPEND} ${DEPEND} | sed -e 's/ /\n/g' | sed -n -e '/virtual\/\(jre\|jdk\)/ { p;q }')\""; > [[ -f "${JAVA_PKG_BUILD_DEPEND_FILE}" ]] && echo "BUILD_DEPEND=\"$(sort -u "${JAVA_PKG_BUILD_DEPEND_FILE}" | tr '\n' ':')\"" ) > "${JAVA_PKG_ENV}"; > local target="$(java-pkg_get-target)"; > local source="$(java-pkg_get-source)"; > [[ -n ${target} ]] && echo "TARGET=\"${target}\"" >> "${JAVA_PKG_ENV}"; > [[ -n ${source} ]] && echo "SOURCE=\"${source}\"" >> "${JAVA_PKG_ENV}"; > [[ -n ${JAVADOC_PATH} ]] && echo "JAVADOC_PATH=\"${JAVADOC_PATH}\"" >> ${JAVA_PKG_ENV}; > [[ -n ${JAVA_SOURCES} ]] && echo "JAVA_SOURCES=\"${JAVA_SOURCES}\"" >> ${JAVA_PKG_ENV}; > echo "MERGE_VM=\"${GENTOO_VM}\"" >> "${JAVA_PKG_ENV}"; > [[ -n ${GENTOO_COMPILER} ]] && echo "MERGE_COMPILER=\"${GENTOO_COMPILER}\"" >> "${JAVA_PKG_ENV}"; > if [[ -n "${JAVA_PKG_EXTRA_ENV_VARS}" ]]; then > cat "${JAVA_PKG_EXTRA_ENV}" >> "${JAVA_PKG_ENV}" || die; > echo "ENV_VARS=\"$(echo ${JAVA_PKG_EXTRA_ENV_VARS})\"" >> "${JAVA_PKG_ENV}" || die; > fi; > sed -e "s/=\":/=\"/" -e "s/:\"$/\"/" -i "${JAVA_PKG_ENV}" || die "Did you forget to call java_init ?" >} >java-pkg_doexamples () >{ > debug-print-function ${FUNCNAME} $*; > [[ ${#} -lt 1 ]] && die "At least one argument needed"; > java-pkg_check-phase install; > java-pkg_init_paths_; > local dest=/usr/share/doc/${PF}/examples; > if [[ ${1} == --subdir ]]; then > local dest=${dest}/${2}; > dodir ${dest}; > shift 2; > fi; > if [[ ${#} = 1 && -d ${1} ]]; then > ( insinto "${dest}"; > doins -r ${1}/* ); > else > ( insinto "${dest}"; > doins -r "$@" ); > fi; > dosym "${dest}" "${JAVA_PKG_SHAREPATH}/examples" || die >} >java-pkg_dohtml () >{ > debug-print-function ${FUNCNAME} $*; > [[ ${#} -lt 1 ]] && die "At least one argument required for ${FUNCNAME}"; > docinto html; > dodoc "$@"; > java-pkg_recordjavadoc >} >java-pkg_dojar () >{ > debug-print-function ${FUNCNAME} $*; > [[ ${#} -lt 1 ]] && die "At least one argument needed"; > java-pkg_check-phase install; > java-pkg_init_paths_; > dodir ${JAVA_PKG_JARDEST}; > local jar; > for jar in "${@}"; > do > local jar_basename=$(basename "${jar}"); > java-pkg_check-versioned-jar ${jar_basename}; > if [[ -e "${jar}" ]]; then > local dest="${ED}${JAVA_PKG_JARDEST}/${jar_basename}"; > if [[ -e "${dest}" ]]; then > ewarn "Overwriting ${dest}"; > fi; > if [[ ! -L "${jar}" ]]; then > is-java-strict && java-pkg_verify-classes "${jar}"; > ( insinto "${JAVA_PKG_JARDEST}"; > doins "${jar}" ); > java-pkg_append_ JAVA_PKG_CLASSPATH "${EPREFIX}${JAVA_PKG_JARDEST}/${jar_basename}"; > debug-print "installed ${jar} to ${ED}${JAVA_PKG_JARDEST}"; > else > ln -s "$(readlink "${jar}")" "${ED}${JAVA_PKG_JARDEST}/${jar_basename}"; > debug-print "${jar} is a symlink, linking accordingly"; > fi; > else > die "${jar} does not exist"; > fi; > done; > if [[ -n ${JAVA_PKG_DEBUG} ]]; then > einfo "Verbose logging for \"${FUNCNAME}\" function"; > einfo "Jar file(s) destination: ${JAVA_PKG_JARDEST}"; > einfo "Jar file(s) created: ${@}"; > einfo "Complete command:"; > einfo "${FUNCNAME} ${@}"; > fi; > java-pkg_do_write_ >} >java-pkg_dojavadoc () >{ > debug-print-function ${FUNCNAME} $*; > local symlink; > if [[ ${1} = --symlink ]]; then > symlink=${2}; > shift 2; > fi; > local dir="$1"; > local dest=/usr/share/doc/${PF}/html; > java-pkg_check-phase install; > java-pkg_init_paths_; > [[ -z "${dir}" ]] && die "Must specify a directory!"; > [[ ! -d "${dir}" ]] && die "${dir} does not exist, or isn't a directory!"; > if [[ ! -e "${dir}/index.html" ]]; then > local msg="No index.html in javadoc directory"; > ewarn "${msg}"; > is-java-strict && die "${msg}"; > fi; > if [[ -e ${D}/${dest}/api ]]; then > eerror "${dest} already exists. Will not overwrite."; > die "${dest}"; > fi; > local dir_to_install="${dir}"; > if [[ "$(basename "${dir}")" != "api" ]]; then > dir_to_install="${T}/api"; > cp -r "${dir}" "${dir_to_install}" || die "cp failed"; > fi; > java-pkg_dohtml -r "${dir_to_install}"; > dosym ${dest}/api "${JAVA_PKG_SHAREPATH}/api" || die; > if [[ -n ${symlink} ]]; then > debug-print "symlinking ${dest}/{api,${symlink}}"; > dosym ${dest}/{api,${symlink}} || die; > fi; > if [[ -n ${JAVA_PKG_DEBUG} ]]; then > einfo "Verbose logging for \"${FUNCNAME}\" function"; > einfo "Documentation destination: ${dest}"; > einfo "Directory to install: ${dir_to_install}"; > einfo "Complete command:"; > einfo "${FUNCNAME} ${@}"; > fi >} >java-pkg_dolauncher () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > java-pkg_init_paths_; > if [[ ${#} = 0 ]]; then > local name="${PN}"; > else > local name="${1}"; > shift; > fi; > local target="${T}/${name}"; > local var_tmp="${T}/launcher_variables_tmp"; > local target_dir pre; > while [[ -n "${1}" && -n "${2}" ]]; do > local var="${1}" value="${2}"; > if [[ "${var:0:2}" == "--" ]]; then > local var=${var:2}; > echo "gjl_${var}=\"${value}\"" >> "${var_tmp}"; > local gjl_${var}="${value}"; > else > if [[ "${var}" == "-into" ]]; then > target_dir="${value}"; > else > if [[ "${var}" == "-pre" ]]; then > pre="${value}"; > fi; > fi; > fi; > shift 2; > done; > if [[ -z "${gjl_jar}" && -z "${gjl_main}" ]]; then > local cp="${JAVA_PKG_CLASSPATH}"; > if [[ "${cp/:}" = "${cp}" && "${cp%.jar}" != "${cp}" ]]; then > echo "gjl_jar=\"${JAVA_PKG_CLASSPATH}\"" >> "${var_tmp}"; > else > local msg="Not enough information to create a launcher given."; > msg="${msg} Please give --jar or --main argument to ${FUNCNAME}."; > die "${msg}"; > fi; > fi; > echo "#!/bin/bash" > "${target}"; > if [[ -n "${pre}" ]]; then > if [[ -f "${pre}" ]]; then > cat "${pre}" >> "${target}"; > else > die "-pre specified file '${pre}' does not exist"; > fi; > fi; > echo "gjl_package=${JAVA_PKG_NAME}" >> "${target}"; > cat "${var_tmp}" >> "${target}"; > rm -f "${var_tmp}"; > echo "source ${EPREFIX}/usr/share/java-config-2/launcher/launcher.bash" >> "${target}"; > if [[ -n "${target_dir}" ]]; then > ( into "${target_dir}"; > dobin "${target}" ); > local ret=$?; > return ${ret}; > else > dobin "${target}"; > fi >} >java-pkg_doso () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} -lt 1 ]] && die "${FUNCNAME} requires at least one argument"; > java-pkg_init_paths_; > local lib; > for lib in "$@"; > do > if [[ -e "${lib}" ]]; then > if [[ ! -L "${lib}" ]]; then > ( insinto "${JAVA_PKG_LIBDEST}"; > insopts -m0755; > doins "${lib}" ); > java-pkg_append_ JAVA_PKG_LIBRARY "${JAVA_PKG_LIBDEST}"; > debug-print "Installing ${lib} to ${JAVA_PKG_LIBDEST}"; > else > dosym "$(readlink "${lib}")" "${JAVA_PKG_LIBDEST}/${lib##*/}"; > debug-print "${lib} is a symlink, linking accordantly"; > fi; > else > die "${lib} does not exist"; > fi; > done; > java-pkg_do_write_ >} >java-pkg_dosrc () >{ > debug-print-function ${FUNCNAME} $*; > [ ${#} -lt 1 ] && die "At least one argument needed"; > java-pkg_check-phase install; > [[ ${#} -lt 1 ]] && die "At least one argument needed"; > if ! [[ ${DEPEND} = *app-arch/zip* ]]; then > local msg="${FUNCNAME} called without app-arch/zip in DEPEND"; > java-pkg_announce-qa-violation ${msg}; > fi; > java-pkg_init_paths_; > local zip_name="${PN}-src.zip"; > local zip_path="${T}/${zip_name}"; > local dir; > for dir in "${@}"; > do > local dir_parent=$(dirname "${dir}"); > local dir_name=$(basename "${dir}"); > pushd ${dir_parent} > /dev/null || die "problem entering ${dir_parent}"; > zip -q -r ${zip_path} ${dir_name} -i '*.java'; > local result=$?; > if [[ ${result} != 12 && ${result} != 0 ]]; then > die "failed to zip ${dir_name}"; > fi; > popd > /dev/null || die; > done; > ( insinto "${JAVA_PKG_SOURCESPATH}"; > doins ${zip_path} ); > JAVA_SOURCES="${JAVA_PKG_SOURCESPATH}/${zip_name}"; > if [[ -n ${JAVA_PKG_DEBUG} ]]; then > einfo "Verbose logging for \"${FUNCNAME}\" function"; > einfo "Zip filename created: ${zip_name}"; > einfo "Zip file destination: ${JAVA_PKG_SOURCESPATH}"; > einfo "Directories zipped: ${@}"; > einfo "Complete command:"; > einfo "${FUNCNAME} ${@}"; > fi; > java-pkg_do_write_ >} >java-pkg_dowar () >{ > debug-print-function ${FUNCNAME} $*; > [[ ${#} -lt 1 ]] && die "At least one argument needed"; > java-pkg_check-phase install; > java-pkg_init_paths_; > local war; > for war in $*; > do > local warpath; > if [[ -L "${war}" ]]; then > cp "${war}" "${T}"; > warpath="${T}$(basename "${war}")"; > else > if [[ -d "${war}" ]]; then > echo "dowar: warning, skipping directory ${war}"; > continue; > else > warpath="${war}"; > fi; > fi; > ( insopts -m0644; > insinto "${JAVA_PKG_WARDEST}"; > doins ${warpath} ); > done >} >java-pkg_ensure-dep () >{ > debug-print-function ${FUNCNAME} $*; > local limit_to="${1}"; > local target_pkg="${2}"; > local dev_error=""; > local stripped_pkg=/$(sed -r 's/[-:]?([^-:]+)$/(\0(-[^:]+)?:0|(-[^:]+)?:\1)/' <<< "${target_pkg//./\\.}")\\b; > debug-print "Matching against: ${stripped_pkg}"; > if [[ ${limit_to} != runtime && ! ( "${DEPEND}" =~ $stripped_pkg ) ]]; then > dev_error="The ebuild is attempting to use ${target_pkg}, which is not "; > dev_error+="declared with a SLOT in DEPEND."; > eqawarn "QA Notice: java-pkg_ensure-dep: ${dev_error}"; > else > if [[ ${limit_to} != build && ! ( "${RDEPEND}${PDEPEND}" =~ ${stripped_pkg} ) ]]; then > dev_error="The ebuild is attempting to use ${target_pkg}, which is not "; > dev_error+="declared with a SLOT in [RP]DEPEND and --build-only wasn't given."; > eqawarn "QA Notice: java-pkg_ensure-dep: ${dev_error}"; > fi; > fi >} >java-pkg_ensure-no-bundled-jars () >{ > debug-print-function ${FUNCNAME} $*; > local bundled_jars=$(java-pkg_find-normal-jars); > if [[ -n ${bundled_jars} ]]; then > echo "Bundled jars found:"; > local jar; > for jar in ${bundled_jars}; > do > echo $(pwd)${jar/./}; > done; > die "Bundled jars found!"; > fi >} >java-pkg_ensure-vm-version-eq () >{ > debug-print-function ${FUNCNAME} $*; > if ! java-pkg_is-vm-version-eq $@; then > debug-print "VM is not suffient"; > eerror "This package requires a Java VM version = $@"; > einfo "Please use \"eselect java-vm set system\" to set the correct one"; > die "Active Java VM too old"; > fi >} >java-pkg_ensure-vm-version-ge () >{ > debug-print-function ${FUNCNAME} $*; > if ! java-pkg_is-vm-version-ge "$@"; then > debug-print "vm is not suffient"; > eerror "This package requires a Java VM version >= $@"; > einfo "Please use \"eselect java-vm set system\" to set the correct one"; > die "Active Java VM too old"; > fi >} >java-pkg_ensure-vm-version-sufficient () >{ > debug-print-function ${FUNCNAME} $*; > if ! java-pkg_is-vm-version-sufficient; then > debug-print "VM is not suffient"; > eerror "Current Java VM cannot build this package"; > einfo "Please use \"eselect java-vm set system\" to set the correct one"; > die "Active Java VM cannot build this package"; > fi >} >java-pkg_expand_dir_ () >{ > pushd "$(dirname "${1}")" > /dev/null 2>&1 || die; > pwd; > popd > /dev/null 2>&1 || die >} >java-pkg_filter-compiler () >{ > JAVA_PKG_FILTER_COMPILER="${JAVA_PKG_FILTER_COMPILER} $@" >} >java-pkg_find-normal-jars () >{ > local dir=$1; > [[ -n "${dir}" ]] || dir="${WORKDIR}"; > local found; > for jar in $(find "${dir}" -name "*.jar" -type f); > do > echo "${jar}"; > found="true"; > done; > [[ -n "${found}" ]]; > return $? >} >java-pkg_force-compiler () >{ > JAVA_PKG_FORCE_COMPILER="$@" >} >java-pkg_func-exists () >{ > declare -F ${1} > /dev/null >} >java-pkg_gen-cp () >{ > debug-print-function ${FUNCNAME} "$@"; > local atom; > for atom in ${CP_DEPEND}; > do > if [[ ${atom} =~ /(([[:alnum:]+_-]+)-[0-9]+(\.[0-9]+)*[a-z]?(_[[:alnum:]]+)*(-r[0-9]*)?|[[:alnum:]+_-]+):([[:alnum:]+_.-]+) ]]; then > atom=${BASH_REMATCH[2]:-${BASH_REMATCH[1]}}; > [[ ${BASH_REMATCH[6]} != 0 ]] && atom+=-${BASH_REMATCH[6]}; > local regex="(^|\s|,)${atom}($|\s|,)"; > [[ ${!1} =~ ${regex} ]] || declare -g ${1}+=${!1:+,}${atom}; > else > die "Invalid CP_DEPEND atom ${atom}, ensure a SLOT is included"; > fi; > done >} >java-pkg_get-bootclasspath () >{ > local version="${1}"; > local bcp; > case "${version}" in > auto) > bcp="$(java-config -g BOOTCLASSPATH)" > ;; > *) > eerror "unknown parameter of java-pkg_get-bootclasspath"; > die "unknown parameter of java-pkg_get-bootclasspath" > ;; > esac; > echo "${bcp}" >} >java-pkg_get-current-vm () >{ > java-config -f >} >java-pkg_get-javac () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_init-compiler_; > local compiler="${GENTOO_COMPILER}"; > local compiler_executable; > if [[ "${compiler}" = "javac" ]]; then > compiler_executable="javac"; > else > local compiler_env="/usr/share/java-config-2/compiler/${compiler}"; > if [[ -f ${compiler_env} ]]; then > local old_javac=${JAVAC}; > unset JAVAC; > compiler_executable="$(source ${compiler_env} > /dev/null 2>&1; echo ${JAVAC})"; > export JAVAC=${old_javac}; > if [[ -z ${compiler_executable} ]]; then > die "JAVAC is empty or undefined in ${compiler_env}"; > fi; > if [[ ! -x ${compiler_executable} ]]; then > die "${compiler_executable} doesn't exist, or isn't executable"; > fi; > else > die "Could not find environment file for ${compiler}"; > fi; > fi; > echo ${compiler_executable} >} >java-pkg_get-jni-cflags () >{ > local flags="-I${JAVA_HOME}/include"; > flags="${flags} -I${JAVA_HOME}/include/linux"; > echo ${flags} >} >java-pkg_get-source () >{ > echo ${JAVA_PKG_WANT_SOURCE:-$(depend-java-query --get-lowest "${DEPEND} ${RDEPEND}")} >} >java-pkg_get-target () >{ > echo ${JAVA_PKG_WANT_TARGET:-$(depend-java-query --get-lowest "${DEPEND} ${RDEPEND}")} >} >java-pkg_get-vm-vendor () >{ > debug-print-function ${FUNCNAME} $*; > local vm="$(java-pkg_get-current-vm)"; > vm="${vm/-*/}"; > echo "${vm}" >} >java-pkg_get-vm-version () >{ > debug-print-function ${FUNCNAME} $*; > java-config -g PROVIDES_VERSION >} >java-pkg_getjar () >{ > debug-print-function ${FUNCNAME} $*; > local build_only=""; > local virtual=""; > local record_jar=""; > [[ "${EBUILD_PHASE}" == "test" ]] && build_only="build"; > while [[ "${1}" == --* ]]; do > if [[ "${1}" = "--build-only" ]]; then > build_only="build"; > else > if [[ "${1}" == "--virtual" ]]; then > virtual="true"; > else > die "java-pkg_getjar called with unknown parameter: ${1}"; > fi; > fi; > shift; > done; > [[ ${#} -ne 2 ]] && die "${FUNCNAME} takes only two arguments besides --*"; > local pkg="${1}" target_jar="${2}" jar; > [[ -z ${pkg} ]] && die "Must specify package to get a jar from"; > [[ -z ${target_jar} ]] && die "Must specify jar to get"; > local error_msg="Could not find classpath for ${pkg}. Are you sure its installed?"; > local classpath; > classpath=$(java-config --classpath=${pkg}); > [[ $? != 0 ]] && die ${error_msg}; > java-pkg_ensure-dep "${build_only}" "${pkg}"; > if [[ -n "${virtual}" ]]; then > if [[ -z "${build_only}" ]]; then > java-pkg_record-jar_ "${pkg}"; > else > java-pkg_record-jar_ --build-only "${pkg}"; > fi; > record_jar="true"; > fi; > for jar in ${classpath//:/ }; > do > if [[ ! -f "${jar}" ]]; then > die "Installation problem with jar ${jar} in ${pkg} - is it installed?"; > fi; > if [[ "$(basename ${jar})" == "${target_jar}" ]]; then > if [[ -z "${record_jar}" ]]; then > if [[ -z "${build_only}" ]]; then > java-pkg_record-jar_ "${pkg}" "${jar}"; > else > java-pkg_record-jar_ --build-only "${pkg}" "${jar}"; > fi; > fi; > echo "${jar}"; > return 0; > fi; > done; > die "Could not find ${target_jar} in ${pkg}"; > return 1 >} >java-pkg_getjars () >{ > debug-print-function ${FUNCNAME} $*; > local dep_constraint; > local build_only=""; > local deep=""; > [[ "${EBUILD_PHASE}" == "test" ]] && build_only="build"; > while [[ "${1}" == --* ]]; do > if [[ "${1}" = "--build-only" ]]; then > build_only="build"; > dep_constraint="build"; > else > if [[ "${1}" = "--runtime-only" ]]; then > dep_constraint="runtime"; > else > if [[ "${1}" = "--with-dependencies" ]]; then > deep="--with-dependencies"; > else > die "java-pkg_jar-from called with unknown parameter: ${1}"; > fi; > fi; > fi; > shift; > done; > [[ ${#} -ne 1 ]] && die "${FUNCNAME} takes only one argument besides --*"; > local pkgs="${1}"; > jars="$(java-config ${deep} --classpath=${pkgs})"; > [[ $? != 0 ]] && die "java-config --classpath=${pkgs} failed"; > debug-print "${pkgs}:${jars}"; > for pkg in ${pkgs//,/ }; > do > java-pkg_ensure-dep "${dep_constraint}" "${pkg}"; > done; > for pkg in ${pkgs//,/ }; > do > if [[ -z "${build_only}" ]]; then > java-pkg_record-jar_ "${pkg}"; > else > java-pkg_record-jar_ --build-only "${pkg}"; > fi; > done; > echo "${jars}" >} >java-pkg_init () >{ > debug-print-function ${FUNCNAME} $*; > [[ "${MERGE_TYPE}" == "binary" ]] && return; > unset JAVAC; > unset JAVA_HOME; > java-config --help > /dev/null || { > eerror ""; > eerror "Can't run java-config --help"; > eerror "Have you upgraded Python recently but not completed a world upgrade yet?"; > die "Can't run java-config --help" > }; > local silence="${SILENCE_JAVA_OPTIONS_WARNING}"; > local accept="${I_WANT_GLOBAL_JAVA_OPTIONS}"; > if [[ -n ${_JAVA_OPTIONS} && -z ${accept} && -z ${silence} ]]; then > ewarn "_JAVA_OPTIONS changes what java -version outputs at least for"; > ewarn "sun-jdk vms and and as such break configure scripts that"; > ewarn "use it (for example app-office/openoffice) so we filter it out."; > ewarn "Use SILENCE_JAVA_OPTIONS_WARNING=true in the environment (use"; > ewarn "make.conf for example) to silence this warning or"; > ewarn "I_WANT_GLOBAL_JAVA_OPTIONS to not filter it."; > fi; > if [[ -z ${accept} ]]; then > unset _JAVA_OPTIONS; > I_WANT_GLOBAL_JAVA_OPTIONS="true"; > fi; > java-pkg_switch-vm; > PATH=${JAVA_HOME}/bin:${PATH}; > export CLASSPATH=; > export ANT_TASKS=; > export ANT_OPTS=; > export ANT_RESPECT_JAVA_HOME= >} >java-pkg_init-compiler_ () >{ > debug-print-function ${FUNCNAME} $*; > if [[ -n ${GENTOO_COMPILER} ]]; then > debug-print "GENTOO_COMPILER already set"; > return; > fi; > local compilers; > if [[ -z ${JAVA_PKG_FORCE_COMPILER} ]]; then > compilers="$(source ${JAVA_PKG_COMPILERS_CONF} > /dev/null 2>&1; echo ${COMPILERS})"; > else > compilers=${JAVA_PKG_FORCE_COMPILER}; > fi; > debug-print "Read \"${compilers}\" from ${JAVA_PKG_COMPILERS_CONF}"; > local compiler; > for compiler in ${compilers}; > do > debug-print "Checking ${compiler}..."; > if [[ ${compiler} = "javac" ]]; then > debug-print "Found javac... breaking"; > export GENTOO_COMPILER="javac"; > break; > fi; > if has ${compiler} ${JAVA_PKG_FILTER_COMPILER}; then > if [[ -z ${JAVA_PKG_FORCE_COMPILER} ]]; then > einfo "Filtering ${compiler}" 1>&2; > continue; > fi; > fi; > local compiler_env="${JAVA_PKG_COMPILER_DIR}/${compiler}"; > if [[ -f ${compiler_env} ]]; then > local desired_target="$(java-pkg_get-target)"; > local desired_source="$(java-pkg_get-source)"; > local supported_target=$(source ${compiler_env} > /dev/null 2>&1; echo ${SUPPORTED_TARGET}); > if ! has ${desired_target} ${supported_target}; then > ewarn "${compiler} does not support -target ${desired_target}, skipping"; > continue; > fi; > local supported_source=$(source ${compiler_env} > /dev/null 2>&1; echo ${SUPPORTED_SOURCE}); > if ! has ${desired_source} ${supported_source}; then > ewarn "${compiler} does not support -source ${desired_source}, skipping"; > continue; > fi; > export GENTOO_COMPILER="${compiler}"; > break; > else > ewarn "Could not find configuration for ${compiler}, skipping"; > ewarn "Perhaps it is not installed?"; > continue; > fi; > done; > if [[ -z ${GENTOO_COMPILER} ]]; then > if [[ -n ${compilers} ]]; then > einfo "No suitable compiler found: defaulting to JDK default for compilation" 1>&2; > else > :; > fi; > if java-config -g GENTOO_COMPILER 2> /dev/null; then > export GENTOO_COMPILER=$(java-config -g GENTOO_COMPILER); > else > export GENTOO_COMPILER=javac; > fi; > else > einfo "Using ${GENTOO_COMPILER} for compilation" 1>&2; > fi >} >java-pkg_init_paths_ () >{ > debug-print-function ${FUNCNAME} $*; > local pkg_name; > if [[ "${SLOT%/*}" == "0" ]]; then > JAVA_PKG_NAME="${PN}"; > else > JAVA_PKG_NAME="${PN}-${SLOT%/*}"; > fi; > JAVA_PKG_SHAREPATH="/usr/share/${JAVA_PKG_NAME}"; > JAVA_PKG_SOURCESPATH="${JAVA_PKG_SHAREPATH}/sources/"; > JAVA_PKG_ENV="${ED}${JAVA_PKG_SHAREPATH}/package.env"; > JAVA_PKG_VIRTUALS_PATH="/usr/share/java-config-2/virtuals"; > JAVA_PKG_VIRTUAL_PROVIDER="${ED}${JAVA_PKG_VIRTUALS_PATH}/${JAVA_PKG_NAME}"; > [[ -z "${JAVA_PKG_JARDEST}" ]] && JAVA_PKG_JARDEST="${JAVA_PKG_SHAREPATH}/lib"; > [[ -z "${JAVA_PKG_LIBDEST}" ]] && JAVA_PKG_LIBDEST="/usr/$(get_libdir)/${JAVA_PKG_NAME}"; > [[ -z "${JAVA_PKG_WARDEST}" ]] && JAVA_PKG_WARDEST="${JAVA_PKG_SHAREPATH}/webapps"; > debug-print "JAVA_PKG_SHAREPATH: ${JAVA_PKG_SHAREPATH}"; > debug-print "JAVA_PKG_ENV: ${JAVA_PKG_ENV}"; > debug-print "JAVA_PKG_JARDEST: ${JAVA_PKG_JARDEST}"; > debug-print "JAVA_PKG_LIBDEST: ${JAVA_PKG_LIBDEST}"; > debug-print "JAVA_PKG_WARDEST: ${JAVA_PKG_WARDEST}" >} >java-pkg_is-vm-version-eq () >{ > debug-print-function ${FUNCNAME} $*; > local needed_version="$@"; > [[ -z "${needed_version}" ]] && die "need an argument"; > local vm_version="$(java-pkg_get-vm-version)"; > vm_version="$(ver_cut 1-2 "${vm_version}")"; > needed_version="$(ver_cut 1-2 "${needed_version}")"; > if [[ -z "${vm_version}" ]]; then > debug-print "Could not get JDK version from DEPEND"; > return 1; > else > if [[ "${vm_version}" == "${needed_version}" ]]; then > debug-print "Detected a JDK(${vm_version}) = ${needed_version}"; > return 0; > else > debug-print "Detected a JDK(${vm_version}) != ${needed_version}"; > return 1; > fi; > fi >} >java-pkg_is-vm-version-ge () >{ > debug-print-function ${FUNCNAME} $*; > local needed_version=$@; > local vm_version=$(java-pkg_get-vm-version); > if [[ -z "${vm_version}" ]]; then > debug-print "Could not get JDK version from DEPEND"; > return 1; > else > if ver_test "${vm_version}" -ge "${needed_version}"; then > debug-print "Detected a JDK(${vm_version}) >= ${needed_version}"; > return 0; > else > debug-print "Detected a JDK(${vm_version}) < ${needed_version}"; > return 1; > fi; > fi >} >java-pkg_is-vm-version-sufficient () >{ > debug-print-function ${FUNCNAME} $*; > depend-java-query --is-sufficient "${DEPEND}" > /dev/null; > return $? >} >java-pkg_jar-from () >{ > debug-print-function ${FUNCNAME} $*; > local build_only=""; > local destdir="."; > local deep=""; > local virtual=""; > local record_jar=""; > [[ "${EBUILD_PHASE}" == "test" ]] && build_only="build"; > while [[ "${1}" == --* ]]; do > if [[ "${1}" = "--build-only" ]]; then > build_only="build"; > else > if [[ "${1}" = "--with-dependencies" ]]; then > deep="--with-dependencies"; > else > if [[ "${1}" = "--virtual" ]]; then > virtual="true"; > else > if [[ "${1}" = "--into" ]]; then > destdir="${2}"; > shift; > else > die "java-pkg_jar-from called with unknown parameter: ${1}"; > fi; > fi; > fi; > fi; > shift; > done; > local target_pkg="${1}" target_jar="${2}" destjar="${3}"; > [[ -z ${target_pkg} ]] && die "Must specify a package"; > [[ -z "${destjar}" ]] && destjar="${target_jar}"; > local error_msg="There was a problem getting the classpath for ${target_pkg}."; > local classpath; > classpath="$(java-config ${deep} --classpath=${target_pkg})"; > [[ $? != 0 ]] && die ${error_msg}; > if [[ ${target_pkg} = *,* ]]; then > for pkg in ${target_pkg//,/ }; > do > java-pkg_ensure-dep "${build_only}" "${pkg}"; > [[ -z "${build_only}" ]] && java-pkg_record-jar_ "${pkg}"; > done; > record_jar="true"; > else > java-pkg_ensure-dep "${build_only}" "${target_pkg}"; > fi; > if [[ -z "${build_only}" && -n "${virtual}" ]]; then > java-pkg_record-jar_ "${target_pkg}"; > record_jar="true"; > fi; > pushd ${destdir} > /dev/null || die "failed to change directory to ${destdir}"; > local jar; > for jar in ${classpath//:/ }; > do > local jar_name=$(basename "${jar}"); > if [[ ! -f "${jar}" ]]; then > debug-print "${jar} from ${target_pkg} does not exist"; > die "Installation problems with jars in ${target_pkg} - is it installed?"; > fi; > if [[ -z "${target_jar}" ]]; then > [[ -f "${target_jar}" ]] && rm "${target_jar}"; > ln -snf "${jar}" || die "Failed to make symlink from ${jar} to ${jar_name}"; > if [[ -z "${record_jar}" ]]; then > if [[ -z "${build_only}" ]]; then > java-pkg_record-jar_ "${target_pkg}" "${jar}"; > else > java-pkg_record-jar_ --build-only "${target_pkg}" "${jar}"; > fi; > fi; > else > if [[ "${jar_name}" == "${target_jar}" ]]; then > [[ -f "${destjar}" ]] && rm "${destjar}"; > ln -snf "${jar}" "${destjar}" || die "Failed to make symlink from ${jar} to ${destjar}"; > if [[ -z "${record_jar}" ]]; then > if [[ -z "${build_only}" ]]; then > java-pkg_record-jar_ "${target_pkg}" "${jar}"; > else > java-pkg_record-jar_ --build-only "${target_pkg}" "${jar}"; > fi; > fi; > popd > /dev/null || die; > return 0; > fi; > fi; > done; > popd > /dev/null || die; > if [[ -z "${target_jar}" ]]; then > return 0; > else > die "Failed to find ${target_jar:-jar} in ${target_pkg}"; > fi >} >java-pkg_jarfrom () >{ > java-pkg_jar-from "$@" >} >java-pkg_jarinto () >{ > debug-print-function ${FUNCNAME} $*; > JAVA_PKG_JARDEST="${1}" >} >java-pkg_javac-args () >{ > debug-print-function ${FUNCNAME} $*; > local want_source="$(java-pkg_get-source)"; > local want_target="$(java-pkg_get-target)"; > local source_str="-source ${want_source}"; > local target_str="-target ${want_target}"; > debug-print "want source: ${want_source}"; > debug-print "want target: ${want_target}"; > if [[ -z "${want_source}" || -z "${want_target}" ]]; then > die "Could not find valid -source/-target values for javac"; > else > echo "${source_str} ${target_str}"; > fi >} >java-pkg_needs-vm () >{ > debug-print-function ${FUNCNAME} $*; > if [[ -n "$(echo ${JAVA_PKG_NV_DEPEND:-${DEPEND}} | sed -e '\:virtual/jdk:!d')" ]]; then > return 0; > fi; > [[ -n "${JAVA_PKG_WANT_BUILD_VM}" ]] && return 0; > return 1 >} >java-pkg_newjar () >{ > debug-print-function ${FUNCNAME} $*; > local original_jar="${1}"; > local new_jar="${2:-${PN}.jar}"; > local new_jar_dest="${T}/${new_jar}"; > [[ -z ${original_jar} ]] && die "Must specify a jar to install"; > [[ ! -f ${original_jar} ]] && die "${original_jar} does not exist or is not a file!"; > rm -f "${new_jar_dest}" || die "Failed to remove ${new_jar_dest}"; > cp "${original_jar}" "${new_jar_dest}" || die "Failed to copy ${original_jar} to ${new_jar_dest}"; > java-pkg_dojar "${new_jar_dest}" >} >java-pkg_record-jar_ () >{ > debug-print-function ${FUNCNAME} $*; > local depend_file="${JAVA_PKG_DEPEND_FILE}"; > case "${1}" in > "--optional") > depend_file="${JAVA_PKG_OPTIONAL_DEPEND_FILE}"; > shift > ;; > "--build-only") > depend_file="${JAVA_PKG_BUILD_DEPEND_FILE}"; > shift > ;; > esac; > local pkg=${1} jar=${2} append; > if [[ -z "${jar}" ]]; then > append="${pkg}"; > else > append="$(basename ${jar})@${pkg}"; > fi; > echo "${append}" >> "${depend_file}" >} >java-pkg_recordjavadoc () >{ > debug-print-function ${FUNCNAME} $*; > JAVADOC_PATH="$(find "${D}"/usr/share/doc/ -name allclasses-frame.html -printf '%h:')"; > JAVADOC_PATH="${JAVADOC_PATH//${D}}"; > if [[ -n "${JAVADOC_PATH}" ]]; then > debug-print "javadocs found in ${JAVADOC_PATH%:}"; > java-pkg_do_write_; > else > debug-print "No javadocs found"; > fi >} >java-pkg_register-ant-task () >{ > local TASKS_DIR="tasks"; > while [[ -n "${1}" && -n "${2}" ]]; do > local var="${1#--}"; > local val="${2}"; > if [[ "${var}" == "version" ]]; then > TASKS_DIR="tasks-${val}"; > else > die "Unknown parameter passed to java-pkg_register-ant-tasks: ${1} ${2}"; > fi; > shift 2; > done; > local TASK_NAME="${1:-${JAVA_PKG_NAME}}"; > dodir /usr/share/ant/${TASKS_DIR}; > touch "${ED}/usr/share/ant/${TASKS_DIR}/${TASK_NAME}" >} >java-pkg_register-dependency () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} -gt 2 ]] && die "${FUNCNAME} takes at most two arguments"; > local pkgs="${1}"; > local jar="${2}"; > [[ -z "${pkgs}" ]] && die "${FUNCNAME} called with no package(s) specified"; > if [[ -z "${jar}" ]]; then > for pkg in ${pkgs//,/ }; > do > java-pkg_ensure-dep runtime "${pkg}"; > java-pkg_record-jar_ "${pkg}"; > done; > else > [[ ${pkgs} == *,* ]] && die "${FUNCNAME} called with both package list and jar name"; > java-pkg_ensure-dep runtime "${pkgs}"; > java-pkg_record-jar_ "${pkgs}" "${jar}"; > fi; > java-pkg_do_write_ >} >java-pkg_register-environment-variable () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} != 2 ]] && die "${FUNCNAME} takes two arguments"; > echo "${1}=\"${2}\"" >> ${JAVA_PKG_EXTRA_ENV}; > JAVA_PKG_EXTRA_ENV_VARS="${JAVA_PKG_EXTRA_ENV_VARS} ${1}"; > java-pkg_do_write_ >} >java-pkg_register-optional-dependency () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} -gt 2 ]] && die "${FUNCNAME} takes at most two arguments"; > local pkgs="${1}"; > local jar="${2}"; > [[ -z "${pkgs}" ]] && die "${FUNCNAME} called with no package(s) specified"; > if [[ -z "${jar}" ]]; then > for pkg in ${pkgs//,/ }; > do > java-pkg_record-jar_ --optional "${pkg}"; > done; > else > [[ ${pkgs} == *,* ]] && die "${FUNCNAME} called with both package list and jar name"; > java-pkg_record-jar_ --optional "${pkgs}" "${jar}"; > fi; > java-pkg_do_write_ >} >java-pkg_regjar () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} -lt 1 ]] && die "at least one argument needed"; > java-pkg_init_paths_; > local jar jar_dir jar_file; > for jar in "${@}"; > do > if [[ -e "${jar}" || -e "${D}${jar}" ]]; then > [[ -d "${jar}" || -d "${D}${jar}" ]] && die "Called ${FUNCNAME} on a directory $*"; > is-java-strict && java-pkg_verify-classes "${jar}"; > java-pkg_append_ JAVA_PKG_CLASSPATH "${jar#${D}}"; > else > if [[ ${jar} = *\** ]]; then > eerror "The argument ${jar} to ${FUNCNAME}"; > eerror "has * in it. If you want it to glob in"; > eerror '${D} add ${D} to the argument.'; > fi; > debug-print "${jar} or ${D}${jar} not found"; > die "${jar} does not exist"; > fi; > done; > java-pkg_do_write_ >} >java-pkg_regso () >{ > debug-print-function ${FUNCNAME} $*; > java-pkg_check-phase install; > [[ ${#} -lt 1 ]] && die "${FUNCNAME} requires at least one argument"; > java-pkg_init_paths_; > local lib target_dir; > for lib in "$@"; > do > if [[ -e "${lib}" ]]; then > target_dir="$(java-pkg_expand_dir_ ${lib})"; > java-pkg_append_ JAVA_PKG_LIBRARY "/${target_dir#${D}}"; > else > if [[ -e "${D}${lib}" ]]; then > target_dir="$(java-pkg_expand_dir_ "${D}${lib}")"; > java-pkg_append_ JAVA_PKG_LIBRARY "${target_dir}"; > else > die "${lib} does not exist"; > fi; > fi; > done; > java-pkg_do_write_ >} >java-pkg_rm_files () >{ > debug-print-function ${FUNCNAME} $*; > local IFS="\n"; > for filename in "$@"; > do > [[ ! -f "${filename}" ]] && die "${filename} is not a regular file. Aborting."; > einfo "Removing unneeded file ${filename}"; > rm -f "${S}/${filename}" || die "cannot remove ${filename}"; > done >} >java-pkg_setup-vm () >{ > debug-print-function ${FUNCNAME} $*; > local vendor="$(java-pkg_get-vm-vendor)"; > if [[ "${vendor}" == icedtea* ]] && java-pkg_is-vm-version-ge "1.8"; then > addpredict "/dev/random"; > addpredict "/proc/self/coredump_filter"; > fi >} >java-pkg_sointo () >{ > debug-print-function ${FUNCNAME} $*; > JAVA_PKG_LIBDEST="${1}" >} >java-pkg_switch-vm () >{ > debug-print-function ${FUNCNAME} $*; > if java-pkg_needs-vm; then > if [[ -n "${JAVA_PKG_FORCE_VM}" ]]; then > debug-print "JAVA_PKG_FORCE_VM used: ${JAVA_PKG_FORCE_VM}"; > export GENTOO_VM="${JAVA_PKG_FORCE_VM}"; > else > if [[ "${JAVA_PKG_ALLOW_VM_CHANGE}" == "yes" ]]; then > if [[ -n "${JAVA_PKG_WANT_BUILD_VM}" ]]; then > debug-print "JAVA_PKG_WANT_BUILD_VM used: ${JAVA_PKG_WANT_BUILD_VM}"; > GENTOO_VM=$(java-pkg_build-vm-from-handle); > if [[ $? != 0 ]]; then > eerror "${FUNCNAME}: No VM found for handles: ${JAVA_PKG_WANT_BUILD_VM}"; > die "${FUNCNAME}: Failed to determine VM for building"; > fi; > if [[ -z "${JAVA_PKG_WANT_SOURCE}" ]]; then > eerror "JAVA_PKG_WANT_BUILD_VM specified but not JAVA_PKG_WANT_SOURCE"; > die "Specify JAVA_PKG_WANT_SOURCE"; > fi; > if [[ -z "${JAVA_PKG_WANT_TARGET}" ]]; then > eerror "JAVA_PKG_WANT_BUILD_VM specified but not JAVA_PKG_WANT_TARGET"; > die "Specify JAVA_PKG_WANT_TARGET"; > fi; > else > debug-print "depend-java-query: NV_DEPEND: ${JAVA_PKG_NV_DEPEND:-${DEPEND}}"; > GENTOO_VM="$(depend-java-query --get-vm "${JAVA_PKG_NV_DEPEND:-${DEPEND}}")"; > if [[ -z "${GENTOO_VM}" || "${GENTOO_VM}" == "None" ]]; then > eerror "Unable to determine VM for building from dependencies:"; > echo "NV_DEPEND: ${JAVA_PKG_NV_DEPEND:-${DEPEND}}"; > die "Failed to determine VM for building."; > fi; > fi; > export GENTOO_VM; > else > java-pkg_ensure-vm-version-sufficient; > fi; > fi; > debug-print "Using: $(java-config -f)"; > java-pkg_setup-vm; > export JAVA=$(java-config --java); > export JAVAC=$(java-config --javac); > JAVACFLAGS="$(java-pkg_javac-args)"; > [[ -n ${JAVACFLAGS_EXTRA} ]] && JAVACFLAGS="${JAVACFLAGS_EXTRA} ${JAVACFLAGS}"; > export JAVACFLAGS; > export JAVA_HOME="$(java-config -g JAVA_HOME)"; > export JDK_HOME=${JAVA_HOME}; > java-pkg_append_ LD_LIBRARY_PATH "$(java-config -g LDPATH)"; > local tann="${T}/announced-vm"; > if [[ -n "${JAVA_PKG_DEBUG}" ]] || [[ ! -f "${tann}" ]]; then > einfo "Using: $(java-config -f)"; > [[ ! -f "${tann}" ]] && touch "${tann}"; > fi; > else > [[ -n "${JAVA_PKG_DEBUG}" ]] && ewarn "!!! This package inherits java-pkg but doesn't depend on a JDK. -bin or broken dependency!!!"; > fi >} >java-pkg_verify-classes () >{ > local version_verify_1="${EPREFIX}/usr/$(get_libdir)/javatoolkit/bin/class-version-verify.py"; > local version_verify_2="${EPREFIX}/usr/libexec/javatoolkit/class-version-verify.py"; > if [[ -x "${version_verify_1}" ]]; then > local version_verify=${version_verify_1}; > else > local version_verify=${version_verify_2}; > fi; > if [[ ! -x "${version_verify}" ]]; then > ewarn "Unable to perform class version checks as"; > ewarn "class-version-verify.py is unavailable"; > ewarn "Please install dev-java/javatoolkit."; > return; > fi; > local target=$(java-pkg_get-target); > local result; > local log="${T}/class-version-verify.log"; > if [[ -n "${1}" ]]; then > ${version_verify} -v -t ${target} "${1}" > "${log}"; > result=$?; > else > ebegin "Verifying java class versions (target: ${target})"; > ${version_verify} -v -t ${target} -r "${D}" > "${log}"; > result=$?; > eend ${result}; > fi; > [[ -n ${JAVA_PKG_DEBUG} ]] && cat "${log}"; > if [[ ${result} != 0 ]]; then > eerror "Incorrect bytecode version found"; > [[ -n "${1}" ]] && eerror "in file: ${1}"; > eerror "See ${log} for more details."; > die "Incorrect bytecode found"; > fi >} >java-utils-2_pkg_preinst () >{ > if is-java-strict; then > if [[ ! -e "${JAVA_PKG_ENV}" ]] || has ant-tasks ${INHERITED}; then > return; > fi; > if has_version dev-java/java-dep-check; then > local output=$(GENTOO_VM= java-dep-check --image "${D}" "${JAVA_PKG_ENV}"); > [[ -n ${output} ]] && ewarn "${output}"; > else > eerror "Install dev-java/java-dep-check for dependency checking"; > fi; > fi >} >java-utils-2_src_prepare () >{ > case ${EAPI} in > [78]) > eapply_user > ;; > *) > default_src_prepare > ;; > esac; > if [[ -n ${JAVA_RM_FILES[@]} ]]; then > debug-print "$FUNCNAME: removing unneeded files"; > java-pkg_rm_files "${JAVA_RM_FILES[@]}"; > fi; > if is-java-strict; then > echo "Searching for bundled jars:"; > java-pkg_find-normal-jars || echo "None found."; > echo "Searching for bundled classes (no output if none found):"; > find "${WORKDIR}" -name "*.class"; > echo "Search done."; > fi >} >make_desktop_entry () >{ > [[ -z $1 ]] && die "make_desktop_entry: You must specify the executable"; > local exec=${1}; > local name=${2:-${PN}}; > local icon=${3:-${PN}}; > local type=${4}; > local fields=${5}; > if [[ -z ${type} ]]; then > local catmaj=${CATEGORY%%-*}; > local catmin=${CATEGORY##*-}; > case ${catmaj} in > app) > case ${catmin} in > accessibility) > type="Utility;Accessibility" > ;; > admin) > type=System > ;; > antivirus) > type=System > ;; > arch) > type="Utility;Archiving" > ;; > backup) > type="Utility;Archiving" > ;; > cdr) > type="AudioVideo;DiscBurning" > ;; > dicts) > type="Office;Dictionary" > ;; > doc) > type=Documentation > ;; > editors) > type="Utility;TextEditor" > ;; > emacs) > type="Development;TextEditor" > ;; > emulation) > type="System;Emulator" > ;; > laptop) > type="Settings;HardwareSettings" > ;; > office) > type=Office > ;; > pda) > type="Office;PDA" > ;; > vim) > type="Development;TextEditor" > ;; > xemacs) > type="Development;TextEditor" > ;; > esac > ;; > dev) > type="Development" > ;; > games) > case ${catmin} in > action | fps) > type=ActionGame > ;; > arcade) > type=ArcadeGame > ;; > board) > type=BoardGame > ;; > emulation) > type=Emulator > ;; > kids) > type=KidsGame > ;; > puzzle) > type=LogicGame > ;; > roguelike) > type=RolePlaying > ;; > rpg) > type=RolePlaying > ;; > simulation) > type=Simulation > ;; > sports) > type=SportsGame > ;; > strategy) > type=StrategyGame > ;; > esac; > type="Game;${type}" > ;; > gnome) > type="Gnome;GTK" > ;; > kde) > type="KDE;Qt" > ;; > mail) > type="Network;Email" > ;; > media) > case ${catmin} in > gfx) > type=Graphics > ;; > *) > case ${catmin} in > radio) > type=Tuner > ;; > sound) > type=Audio > ;; > tv) > type=TV > ;; > video) > type=Video > ;; > esac; > type="AudioVideo;${type}" > ;; > esac > ;; > net) > case ${catmin} in > dialup) > type=Dialup > ;; > ftp) > type=FileTransfer > ;; > im) > type=InstantMessaging > ;; > irc) > type=IRCClient > ;; > mail) > type=Email > ;; > news) > type=News > ;; > nntp) > type=News > ;; > p2p) > type=FileTransfer > ;; > voip) > type=Telephony > ;; > esac; > type="Network;${type}" > ;; > sci) > case ${catmin} in > astro*) > type=Astronomy > ;; > bio*) > type=Biology > ;; > calc*) > type=Calculator > ;; > chem*) > type=Chemistry > ;; > elec*) > type=Electronics > ;; > geo*) > type=Geology > ;; > math*) > type=Math > ;; > physics) > type=Physics > ;; > visual*) > type=DataVisualization > ;; > esac; > type="Education;Science;${type}" > ;; > sys) > type="System" > ;; > www) > case ${catmin} in > client) > type=WebBrowser > ;; > esac; > type="Network;${type}" > ;; > *) > type= > ;; > esac; > fi; > local desktop_exec="${exec%%[[:space:]]*}"; > desktop_exec="${desktop_exec##*/}"; > local desktop_suffix="-${PN}"; > [[ ${SLOT%/*} != 0 ]] && desktop_suffix+="-${SLOT%/*}"; > [[ ${desktop_suffix#-} == "${desktop_exec}" ]] && desktop_suffix=""; > local desktop="${desktop_exec}${desktop_suffix}" count=0; > while [[ -e ${ED}/usr/share/applications/${desktop}.desktop ]]; do > desktop="${desktop_exec}-$((++count))${desktop_suffix}"; > done; > desktop="${T}/${desktop}.desktop"; > type=${type%;}${type:+;}; > if [[ -n ${icon} && ${icon} != /* ]] && [[ ${icon} == *.xpm || ${icon} == *.png || ${icon} == *.svg ]]; then > ewarn "As described in the Icon Theme Specification, icon file extensions are not"; > ewarn "allowed in .desktop files if the value is not an absolute path."; > icon=${icon%.*}; > fi; > cat <<-EOF > "${desktop}" || >[Desktop Entry] >Name=${name} >Type=Application >Comment=${DESCRIPTION} >Exec=${exec} >TryExec=${exec%% *} >Icon=${icon} >Categories=${type} >EOF > die > if [[ ${fields:-=} != *=* ]]; then > ewarn "make_desktop_entry: update your 5th arg to read Path=${fields}"; > fields="Path=${fields}"; > fi; > if [[ -n ${fields} ]]; then > printf '%b\n' "${fields}" >> "${desktop}" || die; > fi; > ( insopts -m 0644; > insinto /usr/share/applications; > doins "${desktop}" ) >} >make_session_desktop () >{ > [[ -z $1 ]] && eerror "$0: You must specify the title" && return 1; > [[ -z $2 ]] && eerror "$0: You must specify the command" && return 1; > local title=$1; > local command=$2; > local desktop=${T}/${wm:-${PN}}.desktop; > shift 2; > cat <<-EOF > "${desktop}" || >[Desktop Entry] >Name=${title} >Comment=This session logs you into ${title} >Exec=${command} $* >TryExec=${command} >Type=XSession >EOF > die > ( insopts -m 0644; > insinto /usr/share/xsessions; > doins "${desktop}" ) >} >newicon () >{ > _iconins ${FUNCNAME} "$@" >} >newmenu () >{ > ( insopts -m 0644; > insinto /usr/share/applications; > newins "$@" ) >} >pipestatus () >{ > local status=("${PIPESTATUS[@]}"); > local s ret=0 verbose=""; > [[ ${1} == -v ]] && { > verbose=1; > shift > }; > [[ $# -ne 0 ]] && die "usage: ${FUNCNAME} [-v]"; > for s in "${status[@]}"; > do > [[ ${s} -ne 0 ]] && ret=${s}; > done; > [[ -n ${verbose} ]] && echo "${status[@]}"; > return "${ret}" >} >pkg_nofetch () >{ > default >} >pkg_postinst () >{ > xdg_desktop_database_update; > xdg_icon_cache_update >} >pkg_postrm () >{ > xdg_desktop_database_update; > xdg_icon_cache_update >} >pkg_preinst () >{ > java-pkg-2_pkg_preinst "$@" >} >pkg_setup () >{ > java-pkg-2_pkg_setup "$@" >} >post_src_install () >{ > ( if grep -q 'internal compiler error' "${WORKDIR}"/*/config.log &> /dev/null; then > echo "${CATEGORY}/${PF}: Found ICE in config.log?!"; > fi; > if [[ -f "${S}"/meson.build ]] && ! grep -q "dev-build/meson" <<< "${BDEPEND}"; then > echo "${CATEGORY}/${PF}: meson.build found but ebuild doesn't use meson?"; > fi; > if grep -r -q "dejagnu" "${S}" &> /dev/null && ! grep -q "dejagnu" <<< "${BDEPEND}"; then > echo "${CATEGORY}/${PF}: Missing dejagnu tests?"; > fi; > if grep -r -q "test" "${S}/meson_options.txt" &> /dev/null && ! grep -q "test" <<< "${IUSE}"; then > echo "${CATEGORY}/${PF}: Missing test option wiring for meson?"; > fi; > if grep -E -r -q -- "(disable|enable|with(out)?)-(unit)?test(s?)" configure.ac &> /dev/null && ! grep -q "test" <<< "${IUSE}"; then > echo "${CATEGORY}/${PF}: Missing test option wiring for autoconf?"; > fi; > if grep -E -r -q -- "(disable|enable)-valgrind" configure.ac &> /dev/null && ! grep -q "valgrind" <<< "${IUSE}"; then > echo "${CATEGORY}/${PF}: Missing valgrind option wiring for autoconf?"; > fi; > if grep -r -q "valgrind" "${S}/meson_options.txt" &> /dev/null && ! grep -q "valgrind" <<< "${IUSE}"; then > echo "${CATEGORY}/${PF}: Missing valgrind option wiring for meson?"; > fi; > if grep -E -r -q -- "(disable|enable)-fuzz" configure.ac &> /dev/null && ! grep -q "fuzz" <<< "${EBUILD}"; then > echo "${CATEGORY}/${PF}: Missing fuzz option wiring for autoconf?"; > fi; > if grep -r -q "fuzz" "${S}/meson_options.txt" &> /dev/null && ! grep -q "fuzz" <<< "${EBUILD}"; then > echo "${CATEGORY}/${PF}: Missing fuzz option wiring for meson?"; > fi ) &>> /var/tmp/sam.txt >} >source_profile () >{ > set +u; > source /etc/profile; > set -u >} >declare -fx source_profile >src_compile () >{ > local module; > for module in "${BATIK_MODULES[@]}"; > do > einfo "Compiling ${module}"; > JAVA_JAR_FILENAME="${module}.jar"; > JAVA_MAIN_CLASS=""; > JAVA_RESOURCE_DIRS=""; > JAVA_SRC_DIR=""; > if [[ -d "${module}/src/main/resources" ]]; then > JAVA_RESOURCE_DIRS="${module}/src/main/resources"; > fi; > JAVA_MAIN_CLASS=$(sed -n 's:.*<mainClass>\(.*\)</mainClass>:\1:p' "${module}/pom.xml"); > if [[ -d "${module}/src/main/java/org" ]]; then > JAVA_SRC_DIR="${module}/src/main/java"; > java-pkg-simple_src_compile; > else > if [[ -d "${module}/src/main/resources/org" ]]; then > jar -cfe "${module}.jar" "${JAVA_MAIN_CLASS}" -C "${module}/src/main/resources" . || die; > else > jar -cfe "${module}.jar" "${JAVA_MAIN_CLASS}" -C . README || die; > zip -d "${module}.jar" "README" || die; > fi; > fi; > JAVA_GENTOO_CLASSPATH_EXTRA+=":${module}.jar"; > rm -fr target || die; > done; > if use doc; then > JAVA_SRC_DIR=""; > JAVA_JAR_FILENAME="ignoreme.jar"; > for module in "${BATIK_MODULES[@]}"; > do > if [[ -d "${module}/src/main/java/org" ]]; then > JAVA_SRC_DIR+=("${module}/src/main/java"); > fi; > done; > java-pkg-simple_src_compile; > fi >} >src_configure () >{ > default >} >src_install () >{ > einstalldocs; > domenu "batik-squiggle-${SLOT}.desktop"; > newicon -s scalable batik-svgbrowser/src/main/resources/org/apache/batik/apps/svgbrowser/resources/init.svg squiggle-${SLOT}.svg; > for module in "${BATIK_MODULES[@]}"; > do > JAVA_MAIN_CLASS=$(sed -n 's:.*<mainClass>\(.*\)</mainClass>:\1:p' "${module}/pom.xml"); > java-pkg_dojar "${module}.jar"; > if [[ -n "${JAVA_MAIN_CLASS}" ]]; then > java-pkg_dolauncher "${module}-${SLOT}" --main "${JAVA_MAIN_CLASS}"; > fi; > if [[ -d "${module}/src/main/java/org" ]]; then > if use source; then > java-pkg_dosrc "${module}/src/main/java/*"; > fi; > fi; > done; > local java_policy_file="${JAVA_PKG_SHAREPATH}/etc/${PN}.policy"; > insinto "$(dirname "${java_policy_file}")"; > newins - "$(basename "${java_policy_file}")" <<-_EOF_ >grant codeBase "file:${EPREFIX}${JAVA_PKG_JARDEST}/-" { >permission java.security.AllPermission; >}; >_EOF_ > > java-pkg_register-environment-variable gjl_java_args "\$gjl_java_args -Djava.security.policy=file:${EPREFIX}${java_policy_file}"; > if use doc; then > java-pkg_dojavadoc target/api; > fi >} >src_prepare () >{ > java-pkg_clean; > java-pkg-2_src_prepare; > rm batik-script/src/main/java/org/apache/batik/script/jpython/JPythonInterpreter.java || die; > rm batik-script/src/main/java/org/apache/batik/script/jpython/JPythonInterpreterFactory.java || die; > cat > "batik-squiggle-${SLOT}.desktop" <<-EOF || >[Desktop Entry] >Name=Squiggle >Comment=SVG browser >Exec=batik-squiggle-${SLOT} >Icon=init >Terminal=false >Type=Application >Categories=Graphics;VectorGraphics; >MimeType=image/svg+xml >EOF > die >} >src_test () >{ > JAVA_TEST_GENTOO_CLASSPATH="junit-4"; > for module in "${BATIK_MODULES[@]}"; > do > einfo "Testing ${module}"; > JAVA_TEST_SRC_DIR=""; > JAVA_TEST_RESOURCE_DIRS=""; > JAVA_TEST_RUN_ONLY=""; > if [[ -d "${module}/src/test/resources" ]]; then > JAVA_TEST_RESOURCE_DIRS="${module}/src/test/resources"; > fi; > if [[ "${module}" == batik-util ]]; then > JAVA_TEST_RUN_ONLY="org.apache.batik.util.Base64TestCases"; > fi; > if [[ -d "${module}/src/test/java/org" ]]; then > JAVA_TEST_SRC_DIR="${module}/src/test/java"; > java-pkg-simple_src_test; > fi; > done >} >src_unpack () >{ > verify-sig_src_unpack "$@" >} >syncRepo () >{ > cd /var/db/repos/gentoo; > local synclog=/var/tmp/tb/sync.log; > local curr_time=$EPOCHSECONDS; > if ! emaint sync --auto &> $synclog; then > if grep -q -e 'git fetch error' -e ': Failed to connect to ' -e ': SSL connection timeout' -e ': Connection timed out' -e 'The requested URL returned error:' $synclog; then > return 0; > else > if ! emaint merges --fix &>> $synclog; then > ReachedEOL "repo sync failure, unable to fix" $synclog; > fi; > fi; > fi; > if grep -q -F '* An update to portage is available.' $synclog; then > add2backlog "sys-apps/portage"; > fi; > if ! grep -B 1 '=== Sync completed for gentoo' $synclog | grep -q 'Already up to date.'; then > git diff --diff-filter="ACM" --name-only "@{ $((EPOCHSECONDS - last_sync + 2 * 3600)) second ago }..@{ 2 hour ago }" 2> /dev/null | grep -F -e '/files/' -e '.ebuild' -e 'Manifest' | cut -f 1-2 -d '/' -s | grep -v -f /mnt/tb/data/IGNORE_PACKAGES | sort -u > /tmp/syncRepo.upd; > if [[ -s /tmp/syncRepo.upd ]]; then > sort -u /tmp/syncRepo.upd /var/tmp/tb/backlog.upd | shuf > /tmp/backlog.upd; > cp /tmp/backlog.upd /var/tmp/tb/backlog.upd; > fi; > fi; > last_sync=$curr_time; > cd - > /dev/null >} >declare -fx syncRepo >verify-sig_src_unpack () >{ > if use verify-sig; then > local f suffix found; > local distfiles=() signatures=() nosigfound=() straysigs=(); > for f in ${A}; > do > found=; > for suffix in .asc .sig .minisig .sigstore; > do > if [[ ${f} == *${suffix} ]]; then > signatures+=("${f}"); > found=sig; > break; > else > if has "${f}${suffix}" ${A}; then > distfiles+=("${f}"); > found=dist+sig; > break; > fi; > fi; > done; > if [[ ! -n ${found} ]]; then > nosigfound+=("${f}"); > fi; > done; > if [[ ${#nosigfound[@]} -gt 0 ]]; then > eerror "The following distfiles lack detached signatures:"; > for f in "${nosigfound[@]}"; > do > eerror " ${f}"; > done; > die "Unsigned distfiles found"; > fi; > for f in "${signatures[@]}"; > do > if ! has "${f%.*}" "${distfiles[@]}"; then > straysigs+=("${f}"); > fi; > done; > if [[ ${#straysigs[@]} -gt 0 ]]; then > eerror "The following signatures do not match any distfiles:"; > for f in "${straysigs[@]}"; > do > eerror " ${f}"; > done; > die "Unused signatures found"; > fi; > for f in "${signatures[@]}"; > do > verify-sig_verify_detached "${DISTDIR}/${f%.*}" "${DISTDIR}/${f}"; > done; > fi; > default_src_unpack >} >verify-sig_uncompress_verify_unpack () >{ > local file=${1}; > local unpacker; > case ${file} in > *.tar.xz) > unpacker=(xz -cd) > ;; > *) > die "${FUNCNAME}: only .tar.xz archives are supported at the moment" > ;; > esac; > einfo "Unpacking ${file} ..."; > verify-sig_verify_detached - "${@:2}" < <("${unpacker[@]}" "${file}" | tee >(tar -xf - || die) >pipestatus || die) >} >verify-sig_verify_detached () >{ > local file=${1}; > local sig=${2}; > local key=${3}; > if [[ ${VERIFY_SIG_METHOD} == sigstore ]]; then > if [[ -n ${key:-${VERIFY_SIG_OPENPGP_KEY_PATH}} ]]; then > die "${FUNCNAME}: key unexpectedly specified for sigstore"; > fi; > if [[ -z ${VERIFY_SIG_CERT_IDENTITY} ]]; then > die "${FUNCNAME}: VERIFY_SIG_CERT_IDENTITY must be specified for sigstore"; > fi; > if [[ -z ${VERIFY_SIG_CERT_OIDC_ISSUER} ]]; then > die "${FUNCNAME}: VERIFY_SIG_CERT_OIDC_ISSUER must be specified for sigstore"; > fi; > else > if [[ -z ${key} ]]; then > if [[ -z ${VERIFY_SIG_OPENPGP_KEY_PATH} ]]; then > die "${FUNCNAME}: no key passed and VERIFY_SIG_OPENPGP_KEY_PATH unset"; > else > key="${BROOT}${VERIFY_SIG_OPENPGP_KEY_PATH}"; > fi; > fi; > fi; > local extra_args=(); > if [[ -n ${VERIFY_SIG_OPENPGP_KEYSERVER+1} ]]; then > [[ ${VERIFY_SIG_METHOD} == openpgp ]] || die "${FUNCNAME}: VERIFY_SIG_OPENPGP_KEYSERVER is not supported"; > extra_args+=(--keyserver "${VERIFY_SIG_OPENPGP_KEYSERVER}"); > fi; > addpredict /run/user; > local filename=${file##*/}; > [[ ${file} == - ]] && filename='(stdin)'; > einfo "Verifying ${filename} ..."; > case ${VERIFY_SIG_METHOD} in > minisig) > minisign "${extra_args[@]}" -V -P "$(< "${key}")" -x "${sig}" -m "${file}" || die "minisig signature verification failed" > ;; > openpgp) > if [[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} != yes ]]; then > extra_args+=(-R); > fi; > local -x TMPDIR=/tmp; > gemato openpgp-verify-detached -K "${key}" "${extra_args[@]}" --no-require-all-good "${sig}" "${file}" || die "PGP signature verification failed" > ;; > signify) > signify "${extra_args[@]}" -V -p "${key}" -m "${file}" -x "${sig}" || die "Signify signature verification failed" > ;; > sigstore) > if [[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} != yes ]]; then > extra_args+=(--offline); > fi; > cp -r "${BROOT}"/usr/share/sigstore-gentoo/{.cache,.local} "${HOME}"/ || die; > sigstore verify identity "${extra_args[@]}" --bundle "${sig}" --cert-identity "${VERIFY_SIG_CERT_IDENTITY}" --cert-oidc-issuer "${VERIFY_SIG_CERT_OIDC_ISSUER}" "${file}" || die "Sigstore signature verification failed" > ;; > *) > die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}" > ;; > esac >} >verify-sig_verify_message () >{ > local file=${1}; > local output_file=${2}; > local key=${3}; > if [[ -z ${key} ]]; then > if [[ -z ${VERIFY_SIG_OPENPGP_KEY_PATH} ]]; then > die "${FUNCNAME}: no key passed and VERIFY_SIG_OPENPGP_KEY_PATH unset"; > else > key="${BROOT}${VERIFY_SIG_OPENPGP_KEY_PATH}"; > fi; > fi; > local extra_args=(); > [[ ${VERIFY_SIG_OPENPGP_KEY_REFRESH} == yes ]] || extra_args+=(-R); > if [[ -n ${VERIFY_SIG_OPENPGP_KEYSERVER+1} ]]; then > [[ ${VERIFY_SIG_METHOD} == openpgp ]] || die "${FUNCNAME}: VERIFY_SIG_OPENPGP_KEYSERVER is not supported"; > extra_args+=(--keyserver "${VERIFY_SIG_OPENPGP_KEYSERVER}"); > fi; > addpredict /run/user; > local filename=${file##*/}; > [[ ${file} == - ]] && filename='(stdin)'; > einfo "Verifying ${filename} ..."; > case ${VERIFY_SIG_METHOD} in > minisig) > minisign -V -P "$(< "${key}")" -x "${sig}" -o "${output_file}" -m "${file}" || die "minisig signature verification failed" > ;; > openpgp) > local -x TMPDIR=/tmp; > gemato gpg-wrap -K "${key}" "${extra_args[@]}" -- gpg --verify --output="${output_file}" "${file}" || die "PGP signature verification failed" > ;; > signify) > signify -V -e -p "${key}" -m "${output_file}" -x "${file}" || die "Signify signature verification failed" > ;; > *) > die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}" > ;; > esac >} >verify-sig_verify_signed_checksums () >{ > local checksum_file=${1}; > local algo=${2}; > local files=(); > read -r -d '' -a files <<< "${3}"; > local key=${4}; > if [[ -z ${key} ]]; then > if [[ -z ${VERIFY_SIG_OPENPGP_KEY_PATH} ]]; then > die "${FUNCNAME}: no key passed and VERIFY_SIG_OPENPGP_KEY_PATH unset"; > else > key="${BROOT}${VERIFY_SIG_OPENPGP_KEY_PATH}"; > fi; > fi; > case ${VERIFY_SIG_METHOD} in > openpgp) > _gpg_verify_signed_checksums "${checksum_file}" "${algo}" "${files[@]}" "${key}" > ;; > signify) > signify -C -p "${key}" -x "${checksum_file}" "${files[@]}" || die "Signify signature verification failed" > ;; > *) > die "${FUNCNAME} not supported with ${VERIFY_SIG_METHOD}" > ;; > esac >} >verify-sig_verify_unsigned_checksums () >{ > local checksum_file=${1}; > local format=${2}; > local files=(); > read -r -d '' -a files <<< "${3}"; > local chksum_prog chksum_len algo=${format}; > case ${format} in > sha256) > chksum_len=64 > ;; > openssl-dgst) > > ;; > *) > die "${FUNCNAME}: unknown checksum format ${format}" > ;; > esac; > [[ ${checksum_file} == - ]] && checksum_file=/dev/stdin; > local line checksum filename junk ret=0 count=0; > local -A verified; > while read -r line; do > if [[ ${line} == "-----BEGIN"* ]]; then > die "${FUNCNAME}: PGP armor found, use verify-sig_verify_signed_checksums instead"; > fi; > case ${format} in > sha256) > read -r checksum filename junk <<< "${line}"; > [[ ${#checksum} -ne ${chksum_len} ]] && continue; > [[ -n ${checksum//[0-9a-f]} ]] && continue; > [[ -n ${junk} ]] && continue > ;; > openssl-dgst) > [[ ${line} != *"("*")="* ]] && continue; > checksum=${line##*)=}; > algo=${line%%(*}; > filename=${line#*(}; > filename=${filename%)=*} > ;; > esac; > if ! has "${filename}" "${files[@]}"; then > continue; > fi; > if "${algo,,}sum" -c --strict - <<< "${checksum} ${filename}"; then > verified["${filename}"]=1; > else > ret=1; > fi; > done < "${checksum_file}"; > [[ ${ret} -eq 0 ]] || die "${FUNCNAME}: at least one file did not verify successfully"; > [[ ${#verified[@]} -eq ${#files[@]} ]] || die "${FUNCNAME}: checksums for some of the specified files were missing" >} >xdg_desktop_database_update () >{ > if [[ ${EBUILD_PHASE} != post* ]]; then > die "xdg_desktop_database_update must be used in pkg_post* phases."; > fi; > if ! type update-desktop-database &> /dev/null; then > debug-print "update-desktop-database is not found"; > return; > fi; > ebegin "Updating .desktop files database"; > update-desktop-database -q "${EROOT}${DESKTOP_DATABASE_DIR}"; > eend $? >} >xdg_environment_reset () >{ > export XDG_DATA_HOME="${HOME}/.local/share"; > export XDG_CONFIG_HOME="${HOME}/.config"; > export XDG_CACHE_HOME="${HOME}/.cache"; > export XDG_STATE_HOME="${HOME}/.local/state"; > export XDG_RUNTIME_DIR="${T}/run"; > mkdir -p "${XDG_DATA_HOME}" "${XDG_CONFIG_HOME}" "${XDG_CACHE_HOME}" "${XDG_STATE_HOME}" "${XDG_RUNTIME_DIR}" || die; > chmod 0700 "${XDG_RUNTIME_DIR}" || die; > unset DBUS_SESSION_BUS_ADDRESS >} >xdg_icon_cache_update () >{ > if [[ ${EBUILD_PHASE} != post* ]]; then > die "xdg_icon_cache_update must be used in pkg_post* phases."; > fi; > if ! type gtk-update-icon-cache &> /dev/null; then > debug-print "gtk-update-icon-cache is not found"; > return; > fi; > ebegin "Updating icons cache"; > local dir retval=0; > local fails=(); > for dir in "${EROOT}"/usr/share/icons/*; > do > if [[ -f ${dir}/index.theme ]]; then > if ! gtk-update-icon-cache -qf "${dir}"; then > debug-print "Updating cache failed on ${dir}"; > fails+=("${dir}"); > retval=2; > fi; > else > if [[ $(ls "${dir}") = icon-theme.cache ]]; then > rm "${dir}/icon-theme.cache"; > fi; > fi; > if [[ -z $(ls "${dir}") ]]; then > rmdir "${dir}"; > fi; > done; > eend ${retval}; > for dir in "${fails[@]}"; > do > eerror "Failed to update cache with icon ${dir}"; > done >} >xdg_mimeinfo_database_update () >{ > if [[ ${EBUILD_PHASE} != post* ]]; then > die "xdg_mimeinfo_database_update must be used in pkg_post* phases."; > fi; > if ! type update-mime-database &> /dev/null; then > debug-print "update-mime-database is not found"; > return; > fi; > local -x PKGSYSTEM_ENABLE_FSYNC=0; > ebegin "Updating shared mime info database"; > update-mime-database "${EROOT}${MIMEINFO_DATABASE_DIR}"; > eend $? >}
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Raw
Actions:
View
Attachments on
bug 950479
:
920143
|
920144
|
920145
| 920146 |
920147
|
920148
|
920149
|
920150
|
920151