/* Python-rgbcx Texture Compression Library Copyright (C) 2021 Andrew Cassidy Partially derived from rgbcx.h written by Richard Geldreich and licenced under the public domain This program is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this program. If not, see . */ #include #include #include #include "../../BlockDecoder.h" #include "../../BlockEncoder.h" #include "BC5Decoder.h" #include "BC5Encoder.h" namespace py = pybind11; namespace quicktex::bindings { using namespace quicktex::s3tc; using namespace quicktex::s3tc; void InitBC5(py::module_ &s3tc) { auto bc5 = s3tc.def_submodule("_bc5", "internal bc5 module"); auto block_encoder = py::type::of(); auto block_decoder = py::type::of(); py::options options; options.disable_function_signatures(); // BC5Encoder py::class_ bc5_encoder(bc5, "BC5Encoder", block_encoder, R"doc( Base: :py:class:`~quicktex.BlockEncoder` Encodes dual-channel textures to BC5. )doc"); bc5_encoder.def(py::init(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc( __init__(chan0 : int = 0, chan1 : int = 1) -> None Create a new BC5 encoder with the specified channels :param int chan0: the first channel that will be read from. 0 to 3 inclusive. Default: 0 (red). :param int chan1: the second channel that will be read from. 0 to 3 inclusive. Default: 1 (green). )doc"); bc5_encoder.def_property_readonly("channels", &BC5Encoder::GetChannels, "A 2-tuple of channels that will be read from. 0 to 3 inclusive. Readonly."); bc5_encoder.def_property_readonly("bc4_encoders", &BC5Encoder::GetBC4Encoders, "2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Encoder` s used for each channel. Readonly."); // BC5Decoder py::class_ bc5_decoder(bc5, "BC5Decoder", block_decoder, R"doc( Base: :py:class:`~quicktex.BlockDecoder` Decodes BC4 textures to two channels. )doc"); bc5_decoder.def(py::init(), py::arg("chan0") = 0, py::arg("chan1") = 1, R"doc( __init__(chan0 : int = 0, chan1 : int = 1) -> None Create a new BC5 decoder with the specified channels :param int chan0: the first channel that will be written to. 0 to 3 inclusive. Default: 0 (red). :param int chan1: the second channel that will be written to. 0 to 3 inclusive. Default: 1 (green). )doc"); bc5_decoder.def_property_readonly("channels", &BC5Decoder::GetChannels, "A 2-tuple of channels that will be written to. 0 to 3 inclusive. Readonly."); bc5_decoder.def_property_readonly("bc4_decoders", &BC5Decoder::GetBC4Decoders, "2-tuple of internal :py:class:`~quicktex.s3tc.bc4.BC4Decoder` s used for each channel. Readonly."); } } // namespace quicktex::bindings