001/*
002 *  Licensed to the Apache Software Foundation (ASF) under one or more
003 *  contributor license agreements.  See the NOTICE file distributed with
004 *  this work for additional information regarding copyright ownership.
005 *  The ASF licenses this file to You under the Apache License, Version 2.0
006 *  (the "License"); you may not use this file except in compliance with
007 *  the License.  You may obtain a copy of the License at
008 *
009 *      http://www.apache.org/licenses/LICENSE-2.0
010 *
011 *  Unless required by applicable law or agreed to in writing, software
012 *  distributed under the License is distributed on an "AS IS" BASIS,
013 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 *  See the License for the specific language governing permissions and
015 *  limitations under the License.
016 *
017 */
018package org.apache.commons.compress.archivers.zip;
019
020/**
021 * Supplies {@link ZipArchiveEntryRequest}.
022 *
023 * Implementations are required to support thread-handover. While an instance will
024 * not be accessed concurrently by multiple threads, it will be called by
025 * a different thread than it was created on.
026 *
027 * @since 1.13
028 */
029public interface ZipArchiveEntryRequestSupplier {
030
031    /**
032     * Supply a {@link ZipArchiveEntryRequest} to be added to a parallel archive.
033     * @return The {@link ZipArchiveEntryRequest} instance. Should never be null.
034     */
035    ZipArchiveEntryRequest get();
036}