Java tutorial
/** * This file is part of aion-lightning <aion-lightning.org>. * * aion-lightning is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * aion-lightning is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with aion-lightning. If not, see <http://www.gnu.org/licenses/>. */ package com.aionlightning.commons.utils; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.util.Collection; import java.util.Properties; import org.apache.commons.io.FileUtils; /** * This class is designed to simplify routine job with properties * * @author SoulKeeper */ public class PropertiesUtils { /** * Loads properties by given file * * @param file * filename * @return loaded properties * @throws java.io.IOException * if can't load file */ public static Properties load(String file) throws IOException { return load(new File(file)); } /** * Loads properties by given file * * @param file * filename * @return loaded properties * @throws java.io.IOException * if can't load file */ public static Properties load(File file) throws IOException { FileInputStream fis = new FileInputStream(file); Properties p = new Properties(); p.load(fis); fis.close(); return p; } /** * Loades properties from given files * * @param files * list of string that represents files * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] load(String... files) throws IOException { Properties[] result = new Properties[files.length]; for (int i = 0; i < result.length; i++) { result[i] = load(files[i]); } return result; } /** * Loades properties from given files * * @param files * list of files * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] load(File... files) throws IOException { Properties[] result = new Properties[files.length]; for (int i = 0; i < result.length; i++) { result[i] = load(files[i]); } return result; } /** * Loads non-recursively all .property files form directory * * @param dir * string that represents directory * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] loadAllFromDirectory(String dir) throws IOException { return loadAllFromDirectory(new File(dir), false); } /** * Loads non-recursively all .property files form directory * * @param dir * directory * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] loadAllFromDirectory(File dir) throws IOException { return loadAllFromDirectory(dir, false); } /** * Loads all .property files form directory * * @param dir * string that represents directory * @param recursive * parse subdirectories or not * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] loadAllFromDirectory(String dir, boolean recursive) throws IOException { return loadAllFromDirectory(new File(dir), recursive); } /** * Loads all .property files form directory * * @param dir * directory * @param recursive * parse subdirectories or not * @return array of loaded properties * @throws IOException * if was unable to read properties */ public static Properties[] loadAllFromDirectory(File dir, boolean recursive) throws IOException { Collection<File> files = FileUtils.listFiles(dir, new String[] { "properties" }, recursive); return load(files.toArray(new File[files.size()])); } /** * All initial properties will be overriden with properties supplied as second argument * * @param initialProperties * to be overriden * @param properties * @return merged properties */ public static Properties[] overrideProperties(Properties[] initialProperties, Properties[] properties) { if (properties != null) { for (Properties props : properties) { overrideProperties(initialProperties, props); } } return initialProperties; } /** * All initial properties will be overriden with properties supplied as second argument * * @param initialProperties * @param properties * @return */ public static Properties[] overrideProperties(Properties[] initialProperties, Properties properties) { if (properties != null) { for (Properties initialProps : initialProperties) { initialProps.putAll(properties); } } return initialProperties; } }