/*
 * Java-Gnome Bindings Library
 *
 * Copyright 1998-2004 the Java-Gnome Team, all rights reserved.
 *
 * The Java-Gnome bindings library is free software distributed under
 * the terms of the GNU Library General Public License version 2.
 */

package org.gnu.pango;
import org.gnu.glib.GObject;
import org.gnu.glib.Handle;
/**
 * The PangoAttrList structure represents a list of attributes that apply to a
 * section of text. The attributes are, in general, allowed to overlap in an
 * arbitrary fashion, however, if the attributes are manipulated only through
 * pango_attr_list_change(), the overlap between properties will meet stricter
 * criteria.
 *
 * <p>Since the PangoAttrList structure is stored as a linear list, it is not
 * suitable for storing attributes for large amounts of text. In general, you
 * should not use a single PangoAttrList for more than one paragraph of text.
 */
public class AttrList extends GObject 
{

    /**
     * Create a new AttrList that is a copyof the provided list.
     * @param list
     */
    public AttrList(AttrList list) {
        super(pango_attr_list_copy(list.getHandle()));
    }
    
    protected AttrList(Handle handle){
		super(handle);
	}
	
	/**
	 * Construct a new AttrList.
	 */
	public AttrList() {
		super(pango_attr_list_new());
	}
	
	/**
	 * Insert the given attribute into the list.  It will be inserted after all
	 * other attributes with a matching <i>start_index</i>.
	 */
	public void insert(Attribute attr) {
		pango_attr_list_insert(getHandle(), attr.getHandle());
	}
	
	/**
	 * Insert the given attribute into the list.  It will be inserted before all
	 * other attributes with a matching <i>start_index</i>.
	 */
	public void insertBefore(Attribute attr) {
		pango_attr_list_insert_before(getHandle(), attr.getHandle());
	}
	
	/**	
	 * Insert the given attribute into the list.  It will replace any attribute
	 * of the same type on that segment and be merged with any adjoining attributes
	 * that are identical.
	 */
	public void change(Attribute attr) {
		pango_attr_list_change(getHandle(), attr.getHandle());
	}
	
	/**
	 * Splice on list into another.
	 * 
	 * @param other The other AttrList to splice in the current one.
	 * @param pos The position at which to insert.
	 * @param len The length of the spliced segment.
	 */
	public void splice(AttrList other, int pos, int len) {
		pango_attr_list_splice(getHandle(), other.getHandle(), pos, len);
	}
	
	/**
	 * Create an iterator pointing at the beginning of the list.
	 */
	public AttrIterator getIterator() {
		return new AttrIterator(pango_attr_list_get_iterator(getHandle()));
	}

    native static final protected int pango_attr_list_get_type ();
    native static final protected Handle pango_attr_list_new ();
    native static final protected void pango_attr_list_ref (Handle list);
    native static final protected void pango_attr_list_unref (Handle list);
    native static final protected Handle pango_attr_list_copy (Handle list);
    native static final protected void pango_attr_list_insert (Handle list, Handle attr);
    native static final protected void pango_attr_list_insert_before (Handle list, Handle attr);
    native static final protected void pango_attr_list_change (Handle list, Handle attr);
    native static final protected void pango_attr_list_splice (Handle list, Handle other, int pos, int len);
    native static final protected Handle pango_attr_list_get_iterator (Handle list);

}

