|  | /*
  ==============================================================================
   This file is part of the JUCE library - "Jules' Utility Class Extensions"
   Copyright 2004-11 by Raw Material Software Ltd.
  ------------------------------------------------------------------------------
   JUCE can be redistributed and/or modified under the terms of the GNU General
   Public License (Version 2), as published by the Free Software Foundation.
   A copy of the license is included in the JUCE distribution, or can be found
   online at www.gnu.org/licenses.
   JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
   WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
   A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
  ------------------------------------------------------------------------------
   To release a closed-source product which uses JUCE, commercial licenses are
   available: visit www.rawmaterialsoftware.com/juce for more information.
  ==============================================================================
*/
#ifndef __JUCE_INPUTSOURCE_JUCEHEADER__
#define __JUCE_INPUTSOURCE_JUCEHEADER__
#include "juce_InputStream.h"
//==============================================================================
/**
    A lightweight object that can create a stream to read some kind of resource.
    This may be used to refer to a file, or some other kind of source, allowing a
    caller to create an input stream that can read from it when required.
    @see FileInputSource
*/
class JUCE_API  InputSource
{
public:
    //==============================================================================
    InputSource() noexcept      {}
    /** Destructor. */
    virtual ~InputSource()      {}
    //==============================================================================
    /** Returns a new InputStream to read this item.
        @returns            an inputstream that the caller will delete, or nullptr if
                            the filename isn't found.
    */
    virtual InputStream* createInputStream() = 0;
    /** Returns a new InputStream to read an item, relative.
        @param relatedItemPath  the relative pathname of the resource that is required
        @returns            an inputstream that the caller will delete, or nullptr if
                            the item isn't found.
    */
    virtual InputStream* createInputStreamFor (const String& relatedItemPath) = 0;
    /** Returns a hash code that uniquely represents this item.
    */
    virtual int64 hashCode() const = 0;
private:
    //==============================================================================
    JUCE_LEAK_DETECTOR (InputSource)
};
#endif   // __JUCE_INPUTSOURCE_JUCEHEADER__
 |