// // Copyright 2007-2012 Christian Henning, Andreas Pokorny, Lubomir Bourdev // // Distributed under 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 #include #include #include #include #include #include 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 inline auto read_image_info(Device& file, image_read_settings const& settings, typename std::enable_if < mp11::mp_and < detail::is_adaptable_input_device, is_format_tag >::value >::type* /*dummy*/ = nullptr) -> typename get_reader_backend::type { 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 inline auto read_image_info(Device& file, FormatTag const&, typename std::enable_if < mp11::mp_and < detail::is_adaptable_input_device, is_format_tag >::value >::type* /*dummy*/ = nullptr) -> typename get_reader_backend::type { return read_image_info(file, image_read_settings()); } /// \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 inline auto read_image_info( String const& file_name, image_read_settings const& settings, typename std::enable_if < mp11::mp_and < is_format_tag, detail::is_supported_path_spec >::value >::type* /*dummy*/ = nullptr) -> typename get_reader_backend::type { 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 inline auto read_image_info(String const& file_name, FormatTag const&, typename std::enable_if < mp11::mp_and < is_format_tag, detail::is_supported_path_spec >::value >::type* /*dummy*/ = nullptr) -> typename get_reader_backend::type { return read_image_info(file_name, image_read_settings()); } }} // namespace boost::gil #endif