/* * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.controller.yang2sources.plugin; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Collection; import java.util.Enumeration; import java.util.List; import java.util.Map; import java.util.zip.ZipEntry; import java.util.zip.ZipException; import java.util.zip.ZipFile; import org.apache.commons.io.FileUtils; import org.apache.maven.artifact.DependencyResolutionRequiredException; import org.apache.maven.project.MavenProject; import com.google.common.base.Function; import com.google.common.collect.Collections2; import com.google.common.collect.Lists; import com.google.common.collect.Maps; final class Util { static final String YANG_SUFFIX = "yang"; // Cache for listed directories and found yang files. Typically yang files // are utilized twice. First: code is generated during generate-sources // phase Second: yang files are copied as resources during // generate-resources phase. This cache ensures that yang files are listed // only once. private static Map> cache = Maps .newHashMapWithExpectedSize(10); /** * List files recursively and return as array of String paths. Use cache of * size 1. */ static Collection listFiles(String rootDir) throws FileNotFoundException { if (cache.get(rootDir) != null) return cache.get(rootDir); File file = new File(rootDir); if(!file.exists()) { throw new FileNotFoundException(rootDir); } Collection yangFiles = FileUtils.listFiles(new File(rootDir), new String[] { YANG_SUFFIX }, true); toCache(rootDir, yangFiles); return yangFiles; } static Collection listFilesAsStream(String rootDir) throws FileNotFoundException { Collection is = new ArrayList(); Collection files = listFiles(rootDir); for(File f : files) { is.add(new FileInputStream(f)); } return is; } static String[] listFilesAsArrayOfPaths(String rootDir) throws FileNotFoundException { String[] filesArray = new String[] {}; Collection yangFiles = listFiles(rootDir); // If collection is empty, return empty array [] rather then [null] // array, that is created by default return yangFiles.isEmpty() ? filesArray : Collections2.transform( yangFiles, new Function() { @Override public String apply(File input) { return input.getPath(); } }).toArray(filesArray); } private static void toCache(final String rootDir, final Collection yangFiles) { cache.put(rootDir, yangFiles); } /** * Instantiate object from fully qualified class name */ static T getInstance(String codeGeneratorClass, Class baseType) throws ClassNotFoundException, InstantiationException, IllegalAccessException { return baseType.cast(resolveClass(codeGeneratorClass, baseType) .newInstance()); } private static Class resolveClass(String codeGeneratorClass, Class baseType) throws ClassNotFoundException { Class clazz = Class.forName(codeGeneratorClass); if (!isImplemented(baseType, clazz)) throw new IllegalArgumentException("Code generator " + clazz + " has to implement " + baseType); return clazz; } private static boolean isImplemented(Class expectedIface, Class byClazz) { for (Class iface : byClazz.getInterfaces()) { if (iface.equals(expectedIface)) return true; } return false; } static String message(String message, String logPrefix, Object... args) { String innerMessage = String.format(message, args); return String.format("%s %s", logPrefix, innerMessage); } public static List getClassPath(MavenProject project) throws DependencyResolutionRequiredException { List dependencies = Lists.newArrayList(); try { for (Object element : project.getCompileClasspathElements()) { File asFile = new File((String) element); if (isJar(asFile)) { dependencies.add(asFile); } } } catch (DependencyResolutionRequiredException e) { throw e; } return dependencies; } private static final String JAR_SUFFIX = ".jar"; private static boolean isJar(File element) { return (element.isFile() && element.getName().endsWith(JAR_SUFFIX)) ? true : false; } public static Collection getFilesFromClasspath( List jarsOnClasspath, List classPathFilter) throws ZipException, IOException { List yangs = Lists.newArrayList(); for (File file : jarsOnClasspath) { ZipFile zip = new ZipFile(file); Enumeration entries = zip.entries(); while (entries.hasMoreElements()) { ZipEntry entry = entries.nextElement(); if (entry.getName().endsWith(YANG_SUFFIX)) { InputStream stream = zip.getInputStream(entry); } } } return yangs; } public static boolean acceptedFilter(String name, List filter) { for(String f : filter) { if(name.endsWith(f)) { return true; } } return false; } }