/* * Copyright © 2008, 2012 Pedro Agulló Soliveres. * * This file is part of DirectJNgine. * * DirectJNgine is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License. * * Commercial use is permitted to the extent that the code/component(s) * do NOT become part of another Open Source or Commercially developed * licensed development library or toolkit without explicit permission. * * DirectJNgine 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with DirectJNgine. If not, see <http://www.gnu.org/licenses/>. * * This software uses the ExtJs library (http://extjs.com), which is * distributed under the GPL v3 license (see http://extjs.com/license). */ package com.softwarementors.extjs.djn; import java.util.ArrayList; import java.util.List; import java.util.Locale; public final class StringUtils { private StringUtils() { // Disallow instantiation } public static boolean isEmpty( String value ) { return value == null || value.equals( ""); } public static String concatWithSeparator(List<String> missingParameters, String separator) { assert missingParameters != null; assert separator != null; if( missingParameters.isEmpty() ) { return ""; } StringBuilder result = new StringBuilder(); for( int i = 0; i < missingParameters.size() - 1; i++) { result.append( missingParameters.get(i)); result.append( separator ); } result.append( missingParameters.get( missingParameters.size() - 1)); return result.toString(); } // Returns a list of strings form a 'delimiter' separated string. // It removes whitespace from every value, and ignores empty strings public static List<String> getNonBlankValues( String delimitedValues, String delimiter ) { assert !StringUtils.isEmpty( delimitedValues ); assert !StringUtils.isEmpty(delimiter); List<String> result = new ArrayList<String>(); String[] values = delimitedValues.split( delimiter); for( String value : values ) { value = value.trim(); if( !value.equals( "")) { result.add( value ); } } return result; } public static boolean startsWithCaseInsensitive( String s1, String s2) { assert s2 != null; if( s1 == null ) { return false; } String s1lower = s1.toLowerCase(Locale.getDefault()); String s2lower = s2.toLowerCase(Locale.getDefault()); return s1lower.startsWith(s2lower); } }