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

org.htmlparser.lexer.Cursor Maven / Gradle / Ivy

// HTMLParser Library $Name: v1_5 $ - A java-based parser for HTML
// http://sourceforge.org/projects/htmlparser
// Copyright (C) 2004 Derrick Oswald
//
// Revision Control Information
//
// $Source: /cvsroot/htmlparser/htmlparser/src/org/htmlparser/lexer/Cursor.java,v $
// $Author: derrickoswald $
// $Date: 2005/05/15 11:49:04 $
// $Revision: 1.20 $
//
// 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
//

package org.htmlparser.lexer;

import org.htmlparser.util.sort.Ordered;

import java.io.Serializable;

/**
 * A bookmark in a page.
 * This class remembers the page it came from and its position within the page.
 */
public class Cursor
    implements
        Serializable,
        Ordered,
        Cloneable
{
    /**
     * This cursor's position.
     */
    protected int mPosition;

    /**
     * This cursor's page.
     */
    protected Page mPage;

    /**
     * Construct a Cursor from the page and position given.
     * @param page The page this cursor is on.
     * @param offset The character offset within the page.
     */
    public Cursor (Page page, int offset)
    {
        mPage = page;
        mPosition = offset;
    }

    /**
     * Get this cursor's page.
     * @return The page associated with this cursor.
     */
    public Page getPage ()
    {
        return (mPage);
    }

    /**
     * Get the position of this cursor.
     * @return The cursor position.
     */
    public int getPosition ()
    {
        return (mPosition);
    }

    /**
     * Set the position of this cursor.
     * @param position The new cursor position.
     */
    public void setPosition (int position)
    {
        mPosition = position;
    }

    /**
     * Move the cursor position ahead one character.
     */
    public void advance ()
    {
        mPosition++;
    }

    /**
     * Move the cursor position back one character.
     */
    public void retreat ()
    {
        mPosition--;
        if (0 > mPosition)
            mPosition = 0;
    }

    /**
     * Make a new cursor just like this one.
     * @return The new cursor positioned where this one is,
     * and referring to the same page.
     */
    public Cursor dup ()
    {
        try
        {
            return ((Cursor)clone ());
        }
        catch (CloneNotSupportedException cnse)
        {
            return (new Cursor (getPage (), getPosition ()));
        }
    }

    /**
     * Return a string representation of this cursor
     * @return A string of the form "n[r,c]", where n is the character position,
     * r is the row (zero based) and c is the column (zero based) on the page.
     */
    public String toString ()
    {
        StringBuilder ret;

        ret = new StringBuilder (9 * 3 + 3); // three ints and delimiters
        ret.append (getPosition ());
        ret.append ("[");
        if (null != mPage)
            ret.append (mPage.row (this));
        else
            ret.append ("?");
        ret.append (",");
        if (null != mPage)
            ret.append (mPage.column (this));
        else
            ret.append ("?");
        ret.append ("]");

        return (ret.toString ());
    }

    //
    // Ordered interface
    //

    /**
     * Compare one reference to another.
     * @param that The object to compare this to.
     * @return A negative integer, zero, or a positive
     * integer as this object is less than, equal to,
     * or greater than that object.
     * @see org.htmlparser.util.sort.Ordered
     */
    public int compare (Object that)
    {
        Cursor r = (Cursor)that;
        return (getPosition () - r.getPosition ());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy