⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 compositecollection.java

📁 rule engine drools-2.0-beta-18
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
     * the specified collection.     *     * @param coll     *            the collection to check for     * @return true if all elements contained     */    public boolean containsAll(Collection coll)    {        for ( Iterator it = coll.iterator( ); it.hasNext( ); )        {            if ( this.contains( it.next( ) ) == false )            {                return false;            }        }        return true;    }    /**     * Adds a collection of elements to this collection, throwing     * UnsupportedOperationException unless a CollectionMutator strategy is     * specified.     *     * @param coll     *            the collection to add     * @return true if the collection was modified     * @throws UnsupportedOperationException     *             if CollectionMutator hasn't been set     * @throws UnsupportedOperationException     *             if add is unsupported     * @throws ClassCastException     *             if the object cannot be added due to its type     * @throws NullPointerException     *             if the object cannot be added because its null     * @throws IllegalArgumentException     *             if the object cannot be added     */    public boolean addAll(Collection coll)    {        if ( this.mutator == null )        {            throw new UnsupportedOperationException( "addAll() is not supported on CompositeCollection without a CollectionMutator strategy" );        }        return this.mutator.addAll( this,                                    this.all,                                    coll );    }    /**     * Removes the elements in the specified collection from this composite     * collection.     * <p>     * This implementation calls <code>removeAll</code> on each collection.     *     * @param coll     *            the collection to remove     * @return true if the collection was modified     * @throws UnsupportedOperationException     *             if removeAll is unsupported     */    public boolean removeAll(Collection coll)    {        if ( coll.isEmpty( ) )        {            return false;        }                boolean changed = false;        for ( int i = this.all.length - 1; i >= 0; i-- )        {            changed |= this.all[i].removeAll( coll );        }        return changed;    }    /**     * Retains all the elements in the specified collection in this composite     * collection, removing all others.     * <p>     * This implementation calls <code>retainAll()</code> on each collection.     *     * @param coll     *            the collection to remove     * @return true if the collection was modified     * @throws UnsupportedOperationException     *             if retainAll is unsupported     */    public boolean retainAll(final Collection coll)    {        boolean changed = false;        for ( int i = this.all.length - 1; i >= 0; i-- )        {            changed = (this.all[i].retainAll( coll ) || changed);        }        return changed;    }    /**     * Removes all of the elements from this collection .     * <p>     * This implementation calls <code>clear()</code> on each collection.     *     * @throws UnsupportedOperationException     *             if clear is unsupported     */    public void clear()    {        for ( int i = 0; i < this.all.length; ++i )        {            this.all[i].clear( );        }    }    // -----------------------------------------------------------------------    /**     * Specify a CollectionMutator strategy instance to handle changes.     *     * @param mutator     *            the mutator to use     */    public void setMutator(CollectionMutator mutator)    {        this.mutator = mutator;    }    /**     * Add these Collections to the list of collections in this composite     *     * @param comps     *            Collections to be appended to the composite     */    public void addComposited(Collection[] comps)    {        ArrayList list = new ArrayList( Arrays.asList( this.all ) );        list.addAll( Arrays.asList( comps ) );        all = (Collection[]) list.toArray( new Collection[list.size( )] );    }    /**     * Add an additional collection to this composite.     *     * @param c     *            the collection to add     */    public void addComposited(Collection c)    {        this.addComposited( new Collection[]{c} );    }    /**     * Add two additional collections to this composite.     *     * @param c     *            the first collection to add     * @param d     *            the second collection to add     */    public void addComposited(Collection c,                              Collection d)    {        this.addComposited( new Collection[]{c, d} );    }    /**     * Removes a collection from the those being decorated in this composite.     *     * @param coll     *            collection to be removed     */    public void removeComposited(Collection coll)    {        ArrayList list = new ArrayList( this.all.length );        list.addAll( Arrays.asList( this.all ) );        list.remove( coll );        this.all = (Collection[]) list.toArray( new Collection[list.size( )] );    }    /**     * Returns a new collection containing all of the elements     *     * @return A new ArrayList containing all of the elements in this composite.     *         The new collection is <i>not </i> backed by this composite.     */    public Collection toCollection()    {        return new ArrayList( this );    }    /**     * Gets the collections being decorated.     *     * @return Unmodifiable collection of all collections in this composite.     */    public Collection getCollections()    {        return Collections.unmodifiableList( Arrays.asList( this.all ) );    }    // -----------------------------------------------------------------------    /**     * Pluggable strategy to handle changes to the composite.     */    public interface CollectionMutator    {        /**         * Called when an object is to be added to the composite.         *         * @param composite         *            the CompositeCollection being changed         * @param collections         *            all of the Collection instances in this         *            CompositeCollection         * @param obj         *            the object being added         * @return true if the collection is changed         * @throws UnsupportedOperationException         *             if add is unsupported         * @throws ClassCastException         *             if the object cannot be added due to its type         * @throws NullPointerException         *             if the object cannot be added because its null         * @throws IllegalArgumentException         *             if the object cannot be added         */        public boolean add(CompositeCollection composite,                           Collection[] collections,                           Object obj);        /**         * Called when a collection is to be added to the composite.         *         * @param composite         *            the CompositeCollection being changed         * @param collections         *            all of the Collection instances in this         *            CompositeCollection         * @param coll         *            the collection being added         * @return true if the collection is changed         * @throws UnsupportedOperationException         *             if add is unsupported         * @throws ClassCastException         *             if the object cannot be added due to its type         * @throws NullPointerException         *             if the object cannot be added because its null         * @throws IllegalArgumentException         *             if the object cannot be added         */        public boolean addAll(CompositeCollection composite,                              Collection[] collections,                              Collection coll);        /**         * Called when an object is to be removed to the composite.         *         * @param composite         *            the CompositeCollection being changed         * @param collections         *            all of the Collection instances in this         *            CompositeCollection         * @param obj         *            the object being removed         * @return true if the collection is changed         * @throws UnsupportedOperationException         *             if removed is unsupported         * @throws ClassCastException         *             if the object cannot be removed due to its type         * @throws NullPointerException         *             if the object cannot be removed because its null         * @throws IllegalArgumentException         *             if the object cannot be removed         */        public boolean remove(CompositeCollection composite,                              Collection[] collections,                              Object obj);    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -