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

org.hortonmachine.gears.utils.StringUtilities Maven / Gradle / Ivy

There is a newer version: 0.10.8
Show newest version
/*
 * JGrass - Free Open Source Java GIS http://www.jgrass.org 
 * (C) HydroloGIS - www.hydrologis.com 
 * 
 * This library is free software; you can redistribute it and/or modify it under
 * the terms of the GNU Library General Public License as published by the Free
 * Software Foundation; either version 2 of the License, or (at your option) any
 * later version.
 * 
 * This library 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 Library General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU Library General Public License
 * along with this library; if not, write to the Free Foundation, Inc., 59
 * Temple Place, Suite 330, Boston, MA 02111-1307 USA
 */
package org.hortonmachine.gears.utils;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
import java.util.regex.Pattern;

/**
 * An utilities class for handling strings and similar.
 * 
 * @author Andrea Antonello (www.hydrologis.com)
 * @since 0.7.0
 */
public class StringUtilities {

    public static final Pattern REGEX_PATTER_DOT = Pattern.compile("\\.");

    /**
     * Checks if the list of strings supplied contains the supplied string.
     *
     * 

If the string is contained it changes the name by adding a number. *

The spaces are trimmed away before performing name equality. * * @param strings the list of existing strings. * @param string the proposed new string, to be changed if colliding. * @return the new non-colliding name for the string. */ public static String checkSameName( List strings, String string ) { int index = 1; for( int i = 0; i < strings.size(); i++ ) { if (index == 10000) { // something odd is going on throw new RuntimeException(); } String existingString = strings.get(i); existingString = existingString.trim(); if (existingString.trim().equals(string.trim())) { // name exists, change the name of the entering if (string.endsWith(")")) { string = string.trim().replaceFirst("\\([0-9]+\\)$", "(" + (index++) + ")"); } else { string = string + " (" + (index++) + ")"; } // start again i = 0; } } return string; } /** * Join strings through {@link StringBuilder}. * * @param separator separator to use or null. * @param strings strings to join. * @return the joined string. */ public static String joinStrings( String separator, String... strings ) { if (separator == null) { separator = ""; } StringBuilder sb = new StringBuilder(); for( int i = 0; i < strings.length; i++ ) { sb.append(strings[i]); if (i < strings.length - 1) { sb.append(separator); } } return sb.toString(); } /** * Splits a string by char limit, not breaking works. * * @param string the string to split. * @param limit the char limit. * @return the list of split words. */ public static List splitString( String string, int limit ) { List list = new ArrayList(); char[] chars = string.toCharArray(); boolean endOfString = false; int start = 0; int end = start; while( start < chars.length - 1 ) { int charCount = 0; int lastSpace = 0; while( charCount < limit ) { if (chars[charCount + start] == ' ') { lastSpace = charCount; } charCount++; if (charCount + start == string.length()) { endOfString = true; break; } } end = endOfString ? string.length() : (lastSpace > 0) ? lastSpace + start : charCount + start; list.add(string.substring(start, end)); start = end + 1; } return list; } public static String trimToCount( String string, int count ) { if (string.length() <= count) { return string; } return string.substring(0, count); } /** * Get scanner from input stream. * * Note: the scanner needs to be closed after use. * * @param stream the stream to read. * @param delimiter the delimiter to use. * @return the scanner. */ @SuppressWarnings("resource") public static Scanner streamToScanner( InputStream stream, String delimiter ) { java.util.Scanner s = new java.util.Scanner(stream).useDelimiter(delimiter); return s; } /** * Extract strings form a stream. * * @param stream the stream. * @param delimiter the delimiter used to split. If null, newline is used. * @return the list of string pieces. */ public static List streamToStringList( InputStream stream, String delimiter ) { if (delimiter == null) { delimiter = "\n"; } Scanner scanner = StringUtilities.streamToScanner(stream, delimiter); List pieces = new ArrayList<>(); while( scanner.hasNext() ) { pieces.add(scanner.next()); } return pieces; } /** * Convert a string containing a list of numbers into its array. * * @param string the string containing numbers. * @param separator the number separator. * @return the array of values. */ public static double[] stringToDoubleArray( String string, String separator ) { if (separator == null) { separator = ","; } String[] stringSplit = string.trim().split(separator); double[] array = new double[stringSplit.length]; for( int i = 0; i < array.length; i++ ) { array[i] = Double.parseDouble(stringSplit[i].trim()); } return array; } public static String[] parseCommand(String command) { Pattern parsingPattern = Pattern.compile("[^\"\\s]+|\"(\\.|[^\\\"])*\""); List params = null; params = new ArrayList(); String token = null; Scanner scanner = new Scanner(command); while( (token = scanner.findInLine(parsingPattern)) != null ) { params.add(token); } scanner.close(); return (String[]) params.toArray(new String[params.size()]); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy