From e16c81e9223f1706775885c07bc8ec9ebe55cf56 Mon Sep 17 00:00:00 2001 From: Jacob Perron Date: Tue, 22 Oct 2019 09:33:46 -0700 Subject: [PATCH] Add environment hook for CLASSPATH Signed-off-by: Jacob Perron --- colcon_gradle/task/gradle/build.py | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/colcon_gradle/task/gradle/build.py b/colcon_gradle/task/gradle/build.py index 887e64a..90a1d89 100644 --- a/colcon_gradle/task/gradle/build.py +++ b/colcon_gradle/task/gradle/build.py @@ -4,11 +4,13 @@ from distutils import dir_util import glob import os +from pathlib import Path import shutil from colcon_core.environment import create_environment_scripts from colcon_core.logging import colcon_logger from colcon_core.plugin_system import satisfies_version +from colcon_core.shell import create_environment_hook from colcon_core.shell import get_command_environment from colcon_core.task import run from colcon_core.task import TaskExtensionPoint @@ -62,6 +64,20 @@ async def build( # noqa: D102 logger.info( "Building Gradle package in '{args.path}'".format_map(locals())) + if additional_hooks is None: + additional_hooks = [] + + # add jars and classes to CLASSPATH with wildcards + # https://docs.oracle.com/javase/8/docs/technotes/tools/windows/classpath.html#A1100762 + additional_hooks += create_environment_hook( + 'classpath_jars', Path(args.install_base), pkg.name, + 'CLASSPATH', os.path.join('share', pkg.name, 'java', '*'), + mode='prepend') + additional_hooks += create_environment_hook( + 'classpath_classes', Path(args.install_base), pkg.name, + 'CLASSPATH', os.path.join('share', pkg.name, 'java'), + mode='prepend') + try: env = await get_command_environment( 'build', args.build_base, self.context.dependencies)