| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- /*
- Copyright 2007-2012 Christian Henning, Andreas Pokorny, Lubomir Bourdev
- Use, modification and distribution are subject to the Boost Software License,
- Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
- http://www.boost.org/LICENSE_1_0.txt).
- */
- /*************************************************************************************************/
- #ifndef BOOST_GIL_IO_READ_IMAGE_INFO_HPP
- #define BOOST_GIL_IO_READ_IMAGE_INFO_HPP
- ////////////////////////////////////////////////////////////////////////////////////////
- /// \file
- /// \brief
- /// \author Christian Henning, Andreas Pokorny, Lubomir Bourdev \n
- ///
- /// \date 2007-2012 \n
- ///
- ////////////////////////////////////////////////////////////////////////////////////////
- #include <boost/type_traits/is_base_and_derived.hpp>
- #include <boost/mpl/and.hpp>
- #include <boost/utility/enable_if.hpp>
- #include <boost/gil/io/base.hpp>
- #include <boost/gil/io/device.hpp>
- #include <boost/gil/io/path_spec.hpp>
- namespace boost{ namespace gil {
- /// \ingroup IO
- /// \brief Returns the image format backend. Backend is format specific.
- /// \param file It's a device. Must satisfy is_adaptable_input_device metafunction.
- /// \param settings Specifies read settings depending on the image format.
- /// \return image_read_info object dependent on the image format.
- /// \throw std::ios_base::failure
- template< typename Device
- , typename FormatTag
- >
- inline
- typename get_reader_backend< Device
- , FormatTag
- >::type
- read_image_info( Device& file
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< detail::is_adaptable_input_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- return make_reader_backend( file, settings );
- }
- /// \brief Returns the image format backend. Backend is format specific.
- /// \param file It's a device. Must satisfy is_adaptable_input_device metafunction.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \return image_read_info object dependent on the image format.
- /// \throw std::ios_base::failure
- template< typename Device
- , typename FormatTag
- >
- inline
- typename get_reader_backend< Device
- , FormatTag
- >::type
- read_image_info( Device& file
- , const FormatTag&
- , typename enable_if< mpl::and_< detail::is_adaptable_input_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- return read_image_info( file
- , image_read_settings< FormatTag >()
- );
- }
- /// \brief Returns the image format backend. Backend is format specific.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param settings Specifies read settings depending on the image format.
- /// \return image_read_info object dependent on the image format.
- /// \throw std::ios_base::failure
- template< typename String
- , typename FormatTag
- >
- inline
- typename get_reader_backend< String
- , FormatTag
- >::type
- read_image_info( const String& file_name
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< is_format_tag< FormatTag >
- , detail::is_supported_path_spec< String >
- >
- >::type* /* ptr */ = 0
- )
- {
- return make_reader_backend( file_name, settings );
- }
- /// \brief Returns the image format backend. Backend is format specific.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \return image_read_info object dependent on the image format.
- /// \throw std::ios_base::failure
- template< typename String
- , typename FormatTag
- >
- inline
- typename get_reader_backend< String
- , FormatTag
- >::type
- read_image_info( const String& file_name
- , const FormatTag&
- , typename enable_if< mpl::and_< is_format_tag< FormatTag >
- , detail::is_supported_path_spec< String >
- >
- >::type* /* ptr */ = 0
- )
- {
- return read_image_info( file_name
- , image_read_settings< FormatTag >()
- );
- }
- } // namespace gil
- } // namespace boost
- #endif
|