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

org.languagetool.rules.UnsyncStack Maven / Gradle / Ivy

Go to download

LanguageTool is an Open Source proofreading software for English, French, German, Polish, Romanian, and more than 20 other languages. It finds many errors that a simple spell checker cannot detect like mixing up there/their and it detects some grammar problems.

There is a newer version: 6.5
Show newest version
/* LanguageTool, a natural language style checker 
 * Copyright (C) 2009 Daniel Naber (http://www.danielnaber.de)
 * 
 * This library 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 2.1 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301
 * USA
 */

package org.languagetool.rules;

import java.util.ArrayList;
import java.util.EmptyStackException;

/**
 * Implements unsynchronized stack (contrary to default Java {@link java.util.Stack},
 * this one is based on ArrayList). Usage is the same as the java.util.Stack.
 * 
 * @author Marcin Miłkowski.
 */
public class UnsyncStack extends ArrayList {
  
  /** Generated automatically. */
  private static final long serialVersionUID = -4984830372178073605L;

  UnsyncStack() {
  }

  /**
   * Pushes an item onto the top of this stack. This has exactly the same effect
   * as: {@code add(item)}
   * 
   * @param item the item to be pushed onto this stack.
   * @return the item argument.
   * @see ArrayList#add
   */
  public E push(E item) {
    add(item);
    return item;
  }

  /**
   * Removes the object at the top of this stack and returns that object as the
   * value of this function.
   * 
   * @return The object at the top of this stack (the last item of the
   *         ArrayList object).
   * @exception EmptyStackException if this stack is empty.
   */
  public E pop() {
    E obj;
    int len = size();
    obj = peek();
    remove(len - 1);
    return obj;
  }

  /**
   * Looks at the object at the top of this stack without removing it from the
   * stack.
   * 
   * @return the object at the top of this stack (the last item of the
   *         ArrayList object).
   * @exception EmptyStackException if this stack is empty.
   */
  public E peek() {
    int len = size();
    if (len == 0) {
      throw new EmptyStackException();
    }
    return get(len - 1);
  }

  /**
   * Tests if this stack is empty.
   * 
   * @return true if and only if this stack contains no items;
   *         false otherwise.
   */
  public boolean empty() {
    return size() == 0;
  }

  /**
   * Returns the 1-based position where an object is on this stack. If the
   * object o occurs as an item in this stack, this method returns the
   * distance from the top of the stack of the occurrence nearest the top of the
   * stack; the topmost item on the stack is considered to be at distance
   * 1. The equals method is used to compare o to the
   * items in this stack.
   * 
   * @param o
   *          the desired object.
   * @return the 1-based position from the top of the stack where the object is
   *         located; the return value -1 indicates that the object
   *         is not on the stack.
   */
  public int search(Object o) {
    int i = lastIndexOf(o);
    if (i >= 0) {
      return size() - i;
    }
    return -1;
  }
  
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy