All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.gridgain.grid.spi.deployment.uri.GridUriDeploymentDiscovery Maven / Gradle / Ivy

Go to download

Java-based middleware for in-memory processing of big data in a distributed environment.

There is a newer version: 6.6.9-p1
Show newest version
/* 
 Copyright (C) GridGain Systems. All Rights Reserved.
 
 Licensed under the Apache License, Version 2.0 (the "License");
 you may not use this file except in compliance with the License.
 You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0
 
 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
 */

/*  _________        _____ __________________        _____
 *  __  ____/___________(_)______  /__  ____/______ ____(_)_______
 *  _  / __  __  ___/__  / _  __  / _  / __  _  __ `/__  / __  __ \
 *  / /_/ /  _  /    _  /  / /_/ /  / /_/ /  / /_/ / _  /  _  / / /
 *  \____/   /_/     /_/   \_,__/   \____/   \__,_/  /_/   /_/ /_/
 */

package org.gridgain.grid.spi.deployment.uri;

import org.gridgain.grid.compute.*;
import org.gridgain.grid.spi.*;
import org.gridgain.grid.util.typedef.internal.*;
import java.io.*;
import java.util.*;
import java.util.jar.*;

/**
 * Helper that loads classes either from directory or from JAR file.
 * 

* If loading from directory is used, helper scans given directory * and all subdirectories recursively and loads all files * with ".class" extension by given class loader. If class could not * be loaded it will be ignored. *

* If JAR file loading is used helper scans JAR file and tries to * load all {@link JarEntry} assuming it's a file name. * If at least one of them could not be loaded helper fails. */ final class GridUriDeploymentDiscovery { /** * Enforces singleton. */ private GridUriDeploymentDiscovery() { // No-op. } /** * Load classes from given file. File could be either directory or JAR file. * * @param clsLdr Class loader to load files. * @param file Either directory or JAR file which contains classes or * references to them. * @return Set of found and loaded classes or empty set if file does not * exist. * @throws GridSpiException Thrown if given JAR file references to none * existed class or IOException occurred during processing. */ static Set>> getClasses(ClassLoader clsLdr, File file) throws GridSpiException { Set>> rsrcs = new HashSet<>(); if (file.exists() == false) return rsrcs; GridUriDeploymentFileResourceLoader fileRsrcLdr = new GridUriDeploymentFileResourceLoader(clsLdr, file); if (file.isDirectory()) findResourcesInDirectory(fileRsrcLdr, file, rsrcs); else { try { for (JarEntry entry : U.asIterable(new JarFile(file.getAbsolutePath()).entries())) { Class> rsrc = fileRsrcLdr.createResource(entry.getName(), false); if (rsrc != null) rsrcs.add(rsrc); } } catch (IOException e) { throw new GridSpiException("Failed to discover classes in file: " + file.getAbsolutePath(), e); } } return rsrcs; } /** * Recursively scans given directory and load all found files by loader. * * @param clsLdr Loader that could load class from given file. * @param dir Directory which should be scanned. * @param rsrcs Set which will be filled in. */ @SuppressWarnings({"UnusedCatchParameter"}) private static void findResourcesInDirectory(GridUriDeploymentFileResourceLoader clsLdr, File dir, Set>> rsrcs) { assert dir.isDirectory() == true; for (File file : dir.listFiles()) { if (file.isDirectory()) { // Recurse down into directories. findResourcesInDirectory(clsLdr, file, rsrcs); } else { Class> rsrc = null; try { rsrc = clsLdr.createResource(file.getAbsolutePath(), true); } catch (GridSpiException e) { // Must never happen because we use 'ignoreUnknownRsrc=true'. assert false; } if (rsrc != null) rsrcs.add(rsrc); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy