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

edu.isi.nlp.symbols.SymbolUtils Maven / Gradle / Ivy

The newest version!
package edu.isi.nlp.symbols;

import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.annotations.Beta;
import com.google.common.base.Function;
import com.google.common.collect.FluentIterable;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Ordering;
import edu.isi.nlp.converters.StringConverter;
import java.util.Map;

/**
 * Utility methods for {link Symbol}s
 *
 * @author rgabbard
 * @author clignos
 */
@Beta
public class SymbolUtils {

  private SymbolUtils() {
    throw new UnsupportedOperationException();
  }

  private static final Ordering symbolStringOrdering =
      Ordering.natural().onResultOf(desymbolizeFunction());

  /**
   * An ordering which compares Symbols by the Strings used to create
   * them.
   */
  public static Ordering byStringOrdering() {
    return symbolStringOrdering;
  }

  public static StringConverter StringToSymbol() {
    return StringToSymbolConverter.INSTANCE;
  }

  private enum StringToSymbolConverter implements StringConverter {
    INSTANCE;

    @Override
    public Symbol decode(final String s) {
      return Symbol.from(s);
    }
  }

  /**
   * Returns a function that transforms a {@link Symbol} into a {@link String} using {@link
   * Symbol#asString()}.
   */
  public static Function desymbolizeFunction() {
    return DesymbolizeFunction.INSTANCE;
  }

  private enum DesymbolizeFunction implements Function {
    INSTANCE;

    @Override
    public String apply(final Symbol s) {
      return s.asString();
    }
  }

  /**
   * Returns a function that transforms a {@link String} into a {@link Symbol} using {@link
   * Symbol#from(String)}.
   */
  public static Function symbolizeFunction() {
    return SymbolizeFunction.INSTANCE;
  }

  private enum SymbolizeFunction implements Function {
    INSTANCE;

    @Override
    public Symbol apply(final String s) {
      return Symbol.from(s);
    }
  }

  /**
   * Creates a Set of Symbols from some strings. The returned Set is
   * immutable.
   *
   * @param strings No string may be null.
   */
  public static ImmutableSet setFrom(final Iterable strings) {
    checkNotNull(strings);

    return FluentIterable.from(strings).transform(symbolizeFunction()).toSet();
  }

  /**
   * Creates a List of Symbols from some strings. The returned List is
   * immutable.
   *
   * @param strings No string may be null.
   */
  public static ImmutableList listFrom(final Iterable strings) {
    checkNotNull(strings);
    return FluentIterable.from(strings).transform(symbolizeFunction()).toList();
  }

  public static ImmutableSet toStringSet(final Iterable syms) {
    final ImmutableSet.Builder ret = ImmutableSet.builder();

    for (final Symbol sym : syms) {
      ret.add(sym.toString());
    }

    return ret.build();
  }

  public static ImmutableSet setFrom(final String... strings) {
    final ImmutableSet.Builder ret = ImmutableSet.builder();
    for (final String s : strings) {
      ret.add(Symbol.from(s));
    }
    return ret.build();
  }

  /**
   * Returns a lowercased version of the specified symbol, where lowercasing is done by {@link
   * String#toLowerCase()}.
   */
  public static Symbol lowercaseSymbol(Symbol s) {
    return Symbol.from(s.toString().toLowerCase());
  }

  /**
   * Creates a map of {@link Symbol}s from a map of {@link String}s. No keys or values may be null.
   */
  public static ImmutableMap mapFrom(Map stringMap) {
    final ImmutableMap.Builder ret = ImmutableMap.builder();

    for (Map.Entry stringEntry : stringMap.entrySet()) {
      ret.put(Symbol.from(stringEntry.getKey()), Symbol.from(stringEntry.getValue()));
    }

    return ret.build();
  }

  public static Symbol concat(Symbol x, Symbol y) {
    return Symbol.from(x.asString() + y.asString());
  }

  public static Symbol concat(String x, Symbol y) {
    return Symbol.from(Symbol.from(x) + y.asString());
  }

  public static Symbol concat(Symbol x, String y) {
    return Symbol.from(x.asString() + y);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy