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

com.io7m.jstructural.annotated.SAFormalItemsByKind Maven / Gradle / Ivy

There is a newer version: 5.0.0
Show newest version
/*
 * Copyright © 2014  http://io7m.com
 * 
 * Permission to use, copy, modify, and/or distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
 * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
 * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

package com.io7m.jstructural.annotated;

import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.SortedMap;
import java.util.TreeMap;

import com.io7m.jlog.LogLevel;
import com.io7m.jlog.LogUsableType;
import com.io7m.jnull.NullCheck;

/**
 * The set of formal items organized by kind.
 */

public final class SAFormalItemsByKind implements
  SAFormalItemsByKindReadable,
  SAFormalItemsByKindWritable
{
  private static final SortedMap EMPTY;
  static {
    final SortedMap um =
      Collections
        .unmodifiableSortedMap(new TreeMap());
    assert um != null;
    EMPTY = um;
  }

  private final LogUsableType                                      log;
  private final Map>                     map;

  /**
   * Construct a new empty map.
   * 
   * @param in_log
   *          A log handle
   */

  public SAFormalItemsByKind(
    final LogUsableType in_log)
  {
    this.log = NullCheck.notNull(in_log, "Log").with("formal-items");
    this.map = new HashMap>();
  }

  @Override public SortedMap get(
    final String kind)
  {
    final Set set;
    if (this.map.containsKey(kind)) {
      set = this.map.get(kind);
    } else {
      return SAFormalItemsByKind.EMPTY;
    }

    final SortedMap r =
      new TreeMap();
    for (final SAFormalItem f : set) {
      r.put(f.getNumber(), f);
    }

    final SortedMap rm =
      Collections.unmodifiableSortedMap(r);
    assert rm != null;
    return rm;
  }

  @Override public void put(
    final String kind,
    final SAFormalItem item)
  {
    if (this.log.wouldLog(LogLevel.LOG_DEBUG)) {
      final StringBuilder b = new StringBuilder();
      b.append("new: ");
      b.append(item.getNumber().formalItemNumberFormat());
      b.append(" ");
      b.append(item.getTitle().getActual());
      b.append(" (kind ");
      b.append(item.getKind());
      b.append(")");
      final String r = b.toString();
      assert r != null;
      this.log.debug(r);
    }

    Set set = null;
    if (this.map.containsKey(kind)) {
      set = this.map.get(kind);
    } else {
      set = new HashSet();
    }

    if (set.contains(item)) {
      throw new IllegalArgumentException("Item already added to set");
    }

    set.add(item);
    this.map.put(kind, set);
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy