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

classycle.util.Text Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2003-2008, Franz-Josef Elmer, All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 * 
 * - Redistributions of source code must retain the above copyright notice, 
 *   this list of conditions and the following disclaimer.
 * - Redistributions in binary form must reproduce the above copyright notice, 
 *   this list of conditions and the following disclaimer in the documentation 
 *   and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 
 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 
 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, 
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */
package classycle.util;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;

/**
 * Collection of useful static method concerning string manipulation.
 *  
 * @author  Franz-Josef Elmer
 */
public class Text
{
  private static final String ESCAPE_CHARACTERS = "<>&\"'";
  private static final String[] ESCAPE_SEQUENCES = new String[] {
          "<", ">", "&", """, "'"};
  private Text() {}
  
  /**
   * Escapes special XML characters in the specified text.
   * @param text Text to be escaped. Must be not null.
   * @return copy of the text where the special XML characters has been
   *         replaced by the escape sequences.
   */
  public static String excapeForXML(String text)
  {
    StringBuffer buffer = new StringBuffer();
    for (int i = 0, n = text.length(); i < n; i++)
    {
      char c = text.charAt(i);
      int index = ESCAPE_CHARACTERS.indexOf(c);
      if (index < 0)
      {
        buffer.append(c);
      } else
      {
        buffer.append(ESCAPE_SEQUENCES[index]);
      }
    }
    return new String(buffer);
  }

  /**
   * Reads multi-line text from the specified file.
   * @param file Text file.
   * @return read text file with standard Java newline characters.
   * @throws IOException if some reading error occurs.
   */
  public static String readTextFile(File file) throws IOException
  {
    StringBuffer buffer = new StringBuffer();
    BufferedReader reader 
        = new BufferedReader(new FileReader(file));
    String line;
    while ((line = reader.readLine()) != null)
    {
      buffer.append(line).append('\n');
    }
    String result = new String(buffer);
    return result;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy