Package logformat.slog2.input

Source Code of logformat.slog2.input.TreeFloorList$ItrOfDrawables

/*
*  (C) 2001 by Argonne National Laboratory
*      See COPYRIGHT in top-level directory.
*/

/*
*  @author  Anthony Chan
*/

package logformat.slog2.input;

import java.util.Iterator;
import java.util.TreeMap;
import java.util.NoSuchElementException;

import base.drawable.TimeBoundingBox;
import base.drawable.Drawable;
import base.drawable.Shadow;
import logformat.slog2.*;
/*
    The leaf TreeNodes are always at depth = 0, or at TreeFloor[ idx = 0 ].
*/
public class TreeFloorList
{
    private static final short               NULL_DEPTH = -1;

    private TreeFloor[]          floors;
    private Drawable.Order       dobj_order;
    private BufForObjects.Order  buf4objs_order;
    private short                lowest_depth;

    public TreeFloorList( final Drawable.Order in_dobj_order )
    {
        // For checking of consistence when used with IteratorOfXXXDrawables()
        dobj_order      = in_dobj_order;
        buf4objs_order  = dobj_order.isIncreasingTimeOrdered() ?
                          BufForObjects.INCRE_INDEX_ORDER :
                          BufForObjects.DECRE_INDEX_ORDER;
        lowest_depth    = NULL_DEPTH;
        floors          = null;
    }

    protected void init( short depth_max )
    {
        floors = new TreeFloor[ depth_max + 1 ];
        for ( int idx = floors.length-1; idx >= 0; idx-- )
            floors[ idx ] = new TreeFloor( (short) idx, buf4objs_order );
        lowest_depth = depth_max;
    }

    public BufForObjects getRoot()
    {
        // If InputLog.readTreeNode( InputLog.getFileBlockPtrToTreeRoot() )
        // returns null, above init( short depth_max ) won't be called.
        // floors[] remain uninitialized. floors[] needs to be checked for null.
        if ( floors != null )
            return (BufForObjects) floors[ floors.length-1 ].firstKey();
        else
            return null;
    }

    /*
        add() guarantees that BufForObjects of same depth are added to
    */
    public void put( final BufForObjects nodestub, final BufForObjects node )
    {
        short  node_depth = nodestub.getTreeNodeID().depth;
        floors[ node_depth ].put( nodestub, node );
        if ( node_depth < lowest_depth )
            lowest_depth = node_depth;
    }

    public TreeNode get( final BufForObjects nodestub )
    {
        short  node_depth = nodestub.getTreeNodeID().depth;
        if ( floors[ node_depth ].size() == 0 )
            return null;
        else
            return (TreeNode) floors[ node_depth ].get( nodestub );
    }

    public boolean contains( final BufForObjects nodestub )
    {
        short  node_depth = nodestub.getTreeNodeID().depth;
        if ( floors[ node_depth ].size() == 0 )
            return false;
        else
            return floors[ node_depth ].containsKey( nodestub );
    }

    // Invoking remove() may require calling updateLowestDepth(), recommended.
    public void remove( final BufForObjects nodestub )
    {
        short  node_depth = nodestub.getTreeNodeID().depth;
        if ( floors[ node_depth ].size() > 0 ) {
            floors[ node_depth ].remove( nodestub );
        }
    }

    // updateLowestDepth() is needed after a series of remove()'s
    public void updateLowestDepth()
    {
        for ( short idx = 0; idx < floors.length; idx++ )
            if ( floors[ idx ].size() > 0 ) {
                lowest_depth = idx;
                break;
            }
    }

    /*  For informational service purpose only */
    public short getLowestDepth()
    {
        return lowest_depth;
    }

    /*
       removeAllChildFloorsBelow() guarantees lowest_depth be set correctly,
       no need to call updateLowestDepth().
    */
    public void removeAllChildFloorsBelow( short floor_depth )
    {
        for ( short idepth = 0; idepth < floor_depth; idepth++ ) {
            if ( floors[ idepth ].size() > 0 )
                floors[ idepth ].clear();
        }
        lowest_depth = floor_depth;
    }

    public TreeFloor getLowestFloor()
    {
        return floors[ lowest_depth ];
    }

    /*
       For Zoom-out/Scrolling, i.e. enlargement/moving of the Time View.
       Assumption: | tframe( time_frame ) | >= | floors[ lowest_depth ] |
       Caller is required to check for the assumption before invoking the fn.
       Returned the lowest TreeFloor __totally__ covers tframe
       If not found, return the top TreeFloor
    */
    public TreeFloor getCoveringFloor( final TimeBoundingBox tframe )
    {
        for ( int idepth = lowest_depth; idepth < floors.length; idepth++ ) {
            if ( floors[ idepth ].covers( tframe ) )
                return floors[ idepth ];
        }
        return floors[ floors.length - 1 ];
    }

    /*
       For Zoom-In, i.e. contraction of Time View
       Assumption: | tframe( time_frame ) | <= | floors[ lowest_depth ] |
       Caller is required to check for the assumption before invoking the fn.
       Returned the lowest TreeFloor __barely__ covers tframe
       If not found, return the top TreeFloor
    */
    public TreeFloor pruneToBarelyCoveringFloor( final TimeBoundingBox tframe )
    {
        for ( int idepth = lowest_depth; idepth < floors.length; idepth++ ) {
            if ( floors[ idepth ].coversBarely( tframe ) )
                return floors[ idepth ];
            else
                floors[ idepth ].pruneToBarelyCovering( tframe );
        }
        return floors[ floors.length - 1 ];
    }

    public Iterator iteratorOfAllDrawables( final TimeBoundingBox  tframe,
                                            final Drawable.Order   itrOrder,
                                                  boolean          isComposite,
                                                  boolean          isNestable )
    {
        if ( itrOrder.isStartTimeOrdered() == dobj_order.isStartTimeOrdered() )
            return new ItrOfDrawables( tframe, itrOrder, isComposite,
                                       isNestable, true );
        else {
            System.err.println( "TreeFloorList.iteratorOfAllDrawables(): "
                              + "Inconsistent Start/Final TimeOrder!\n"
                              + "TreeFloor is created with " + dobj_order +"\n"
                              + "but iteratorOfAllDrawables() is "
                              + "invoked with " + itrOrder + ".");
            return null;
        }
    }

    public Iterator iteratorOfRealDrawables( final TimeBoundingBox  tframe,
                                             final Drawable.Order   itrOrder,
                                                   boolean          isComposite,
                                                   boolean          isNestable )
    {
        if ( itrOrder.isStartTimeOrdered() == dobj_order.isStartTimeOrdered() )
            return new ItrOfDrawables( tframe, itrOrder, isComposite,
                                       isNestable, false );
        else {
            System.err.println( "TreeFloorList.iteratorOfRealDrawables(): "
                              + "Inconsistent Start/Final Time Order!\n"
                              + "TreeFloor is created with " + dobj_order +"\n"
                              + "but iteratorOfRealDrawables() is "
                              + "invoked with " + itrOrder + ".");
            return null;
        }
    }

    public Iterator iteratorOfLowestFloorShadows( final TimeBoundingBox tframe,
                                                  final Drawable.Order itrOrder,
                                                        boolean  isNestable )
    {
        if ( itrOrder.isStartTimeOrdered() == dobj_order.isStartTimeOrdered() )
            return floors[ lowest_depth ].iteratorOfShadows( tframe,
                                                             itrOrder,
                                                             isNestable );
        else {
            System.err.println( "TreeFloorList.iteratorOfLowestFloorShadows(): "
                              + "Inconsistent Start/Final TimeOrder!\n"
                              + "TreeFloor is created with " + dobj_order +"\n"
                              + "but iteratorOfLowestFloorShadows() is "
                              + "invoked with " + itrOrder + ".");
            return null;
        }
    }

    public String toStubString()
    {
        StringBuffer rep = new StringBuffer();
        for ( int idx = floors.length-1; idx >= 0; idx-- )
             rep.append( floors[ idx ].toStubString() + "\n" );
        return rep.toString();
    }

    public String toString()
    {
        StringBuffer rep = new StringBuffer();
        for ( int idx = floors.length-1; idx >= 0; idx-- ) {
             rep.append( "\n" + floors[ idx ].toStubString() + "\n" );
             rep.append( floors[ idx ].toString() + "\n" );
        }
        return rep.toString();
    }

    public String toString( final TimeBoundingBox tframe )
    {
        Drawable.Order  dobj_order  = Drawable.INCRE_STARTTIME_ORDER;
        boolean         isComposite = true;
        // boolean         isNestable  = true;
        StringBuffer rep = new StringBuffer();
        Iterator dobjs, sobjs;
        int idx;
        dobjs = this.iteratorOfRealDrawables( tframe, dobj_order,
                                              isComposite, true );
        for ( idx = 1; dobjs.hasNext(); idx++ )
            rep.append( idx + ", " + dobjs.next() + "\n" );
        dobjs = this.iteratorOfRealDrawables( tframe, dobj_order,
                                              isComposite, false );
        for ( ; dobjs.hasNext(); idx++ )
            rep.append( idx + ", " + dobjs.next() + "\n" );
        sobjs = this.iteratorOfLowestFloorShadows( tframe, dobj_order, true );
        for ( idx = 1; sobjs.hasNext(); idx++ )
            rep.append( idx + ", " + sobjs.next() + "\n" );
        sobjs = this.iteratorOfLowestFloorShadows( tframe, dobj_order, false );
        for ( ; sobjs.hasNext(); idx++ )
            rep.append( idx + ", " + sobjs.next() + "\n" );
        return rep.toString();
    }

    public String toFloorString( final TimeBoundingBox timeframe )
    {
        Drawable.Order  dobj_order  = Drawable.INCRE_STARTTIME_ORDER;
        boolean         isComposite = true;
        boolean         isNestable  = true;
        StringBuffer rep = new StringBuffer();
        Iterator dobjs;
        for ( int flr = floors.length-1; flr >= 0; flr-- ) {
            rep.append( "\n" + floors[ flr ].toStubString() + "\n" );
            dobjs = floors[ flr ].iteratorOfDrawables( timeframe, dobj_order,
                                                       isComposite,
                                                       isNestable );
            for ( int idx = 1; dobjs.hasNext(); idx++ )
                 rep.append( "    " + idx + ", " + dobjs.next() + "\n" );
        }
        return rep.toString();
    }



    /*
        ItrOfDrawables returns Drawables in specific Drawable.Order
     */
    private class ItrOfDrawables implements Iterator
    {
        /*
           map_obj2itr is a backstore for Iterator of each floor.
           The key of map_obj2itr is the current leading drawable
           to be pulled from the Iterator.
         */
        private TreeMap      map_obj2itr;
        private Drawable     this_floor_obj;
        private Iterator     this_floor_itr;
        private Drawable     next_floor_obj;
        private double       next_floor_bordertime;
        private boolean      isIncreTimeOrdered;
        private boolean      isStartTimeOrdered;

        public ItrOfDrawables( final TimeBoundingBox  tframe,
                               final Drawable.Order   dobj_order,
                                     boolean          isComposite,
                                     boolean          isNestable,
                                     boolean          withShadows )
        {
            isIncreTimeOrdered  = dobj_order.isIncreasingTimeOrdered();
            isStartTimeOrdered  = dobj_order.isStartTimeOrdered();

            // map_obj2itr has Drawables arranged in the given Drawable.Order.
            map_obj2itr = new TreeMap( dobj_order );
            for ( int idx = floors.length-1; idx >= lowest_depth; idx-- ) {
                this_floor_itr = floors[ idx ].iteratorOfDrawables(
                                               tframe, dobj_order,
                                               isComposite, isNestable );
                if ( this_floor_itr.hasNext() ) {
                    this_floor_obj = (Drawable) this_floor_itr.next();
                    map_obj2itr.put( this_floor_obj, this_floor_itr );
                }
            }
            if ( withShadows ) {
                this_floor_itr = floors[ lowest_depth ].iteratorOfShadows(
                                                        tframe, dobj_order,
                                                        isNestable );
                if ( this_floor_itr.hasNext() ) {
                    this_floor_obj = (Shadow) this_floor_itr.next();
                    map_obj2itr.put( this_floor_obj, this_floor_itr );
                }
            }

            try {
                this_floor_obj  = (Drawable) map_obj2itr.firstKey();
                this_floor_itr  = (Iterator)
                                  map_obj2itr.remove( this_floor_obj );
            } catch ( NoSuchElementException err ) {
                // when map_obj2itr is empty, next_floor_obj is null
                this_floor_obj  = null;
                this_floor_itr  = null;
                next_floor_obj  = null;
                next_floor_bordertime = isIncreTimeOrdered ?
                                        Double.POSITIVE_INFINITY :
                                        Double.NEGATIVE_INFINITY;
            }

            // Initialize next_floor_starttime
            try {
                next_floor_obj  = (Drawable) map_obj2itr.firstKey();
                next_floor_bordertime
                = next_floor_obj.getBorderTime( isStartTimeOrdered );
            } catch ( NoSuchElementException err ) {
                // when map_obj2itr is empty, next_floor_obj is null
                next_floor_obj  = null;
                next_floor_bordertime = isIncreTimeOrdered ?
                                        Double.POSITIVE_INFINITY :
                                        Double.NEGATIVE_INFINITY;
            }
        }

        public boolean hasNext()
        {
            return this_floor_obj != null;
        }

        public Object next()
        {
            Drawable     next_drawable;
            Iterator     next_floor_itr;
            boolean      isFore, isOK;

            next_drawable  = this_floor_obj;
            this_floor_obj = null;

            try {
                if ( this_floor_itr.hasNext() ) {
                    this_floor_obj = (Drawable) this_floor_itr.next();
                    isFore = next_floor_bordertime
                           < this_floor_obj.getBorderTime( isStartTimeOrdered );
                    isOK = isIncreTimeOrdered ? isFore : !isFore ;
                    if ( isOK ) {
                        /*
                          pull next_floor_itr out from map_obj2itr
                          deposit this_floor_itr back to map_obj2itr
                          update next_floor_bordertime from map_obj2itr
                        */
                        next_floor_itr = (Iterator)
                                         map_obj2itr.remove( next_floor_obj );
                        map_obj2itr.put( this_floor_obj, this_floor_itr );
                        this_floor_obj = next_floor_obj;
                        this_floor_itr = next_floor_itr;
                        next_floor_obj = (Drawable) map_obj2itr.firstKey();
                        next_floor_bordertime
                        = next_floor_obj.getBorderTime( isStartTimeOrdered );
                    }
                }
                else {
                    /*
                      update this_floor_obj from next_floor_obj
                      update next_floor_bordertime from map_obj2itr
                    */
                    this_floor_obj = next_floor_obj;
                    if ( this_floor_obj != null ) {
                        this_floor_itr = (Iterator)
                                         map_obj2itr.remove( this_floor_obj );
                        next_floor_obj = (Drawable) map_obj2itr.firstKey();
                        next_floor_bordertime
                        = next_floor_obj.getBorderTime( isStartTimeOrdered );
                    }
                }
            } catch ( NoSuchElementException err ) {
                // when map_obj2itr is empty, next_floor_obj is null
                next_floor_obj     = null;
                next_floor_bordertime = isIncreTimeOrdered ?
                                        Double.POSITIVE_INFINITY :
                                        Double.NEGATIVE_INFINITY;
            }

            return next_drawable;
        }

        public void remove() {}
    }   // private class ItrOfDrawables

}
TOP

Related Classes of logformat.slog2.input.TreeFloorList$ItrOfDrawables

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.