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

eu.hansolo.toolbox.Partition Maven / Gradle / Ivy

Go to download

Toolbox contains a collection of useful tools incl. events, properties, helper classes etc.

There is a newer version: 21.0.17
Show newest version
/*
 * SPDX-License-Identifier: Apache-2.0
 *
 * Copyright 2022 Gerrit Grunwald.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package eu.hansolo.toolbox;

import java.util.AbstractList;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;


public final class Partition extends AbstractList> {
    private final List list;
    private final int     chunkSize;


    // ******************** Constructors **************************************
    public Partition(final Collection list, final int chunkSize) {
        this.list      = new ArrayList<>(list);
        this.chunkSize = chunkSize;
    }


    // ******************** Methods *******************************************
    public static  Partition ofSize(List list, int chunkSize) { return new Partition<>(list, chunkSize); }


    @Override public List get(final int index) {
        final int start = index * chunkSize;
        final int end   = Math.min(start + chunkSize, list.size());

        if (start > end) { throw new IndexOutOfBoundsException("Index " + index + " is out of the list range <0," + (size() - 1) + ">"); }

        return new ArrayList<>(list.subList(start, end));
    }

    @Override public int size() { return (int) Math.ceil((double) list.size() / (double) chunkSize); }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy