//Copyright (c) 2017 Facebook Inc. (Soumith Chintala), //All rights reserved. #include "paddlespeech/audio/src/pybind/sox/io.h" #include "paddlespeech/audio/src/pybind/sox/utils.h" using namespace paddleaudio::sox_utils; namespace paddleaudio { namespace sox_io { auto get_info_file(const std::string &path, const std::string &format) -> std::tuple { SoxFormat sf(sox_open_read(path.data(), /*signal=*/nullptr, /*encoding=*/nullptr, /*filetype=*/format.empty() ? nullptr : format.data())); validate_input_file(sf, path); return std::make_tuple( static_cast(sf->signal.rate), static_cast(sf->signal.length / sf->signal.channels), static_cast(sf->signal.channels), static_cast(sf->encoding.bits_per_sample), get_encoding(sf->encoding.encoding)); } auto get_info_fileobj(py::object fileobj, const std::string &format) -> std::tuple { const auto capacity = [&]() { const auto bufsiz = get_buffer_size(); const int64_t kDefaultCapacityInBytes = 4096; return (bufsiz > kDefaultCapacityInBytes) ? bufsiz : kDefaultCapacityInBytes; }(); std::string buffer(capacity, '\0'); auto *buf = const_cast(buffer.data()); auto num_read = read_fileobj(&fileobj, capacity, buf); // If the file is shorter than 256, then libsox cannot read the header. auto buf_size = (num_read > 256) ? num_read : 256; SoxFormat sf(sox_open_mem_read(buf, buf_size, /*signal=*/nullptr, /*encoding=*/nullptr, /*filetype=*/format.empty() ? nullptr : format.data())); // In case of streamed data, length can be 0 validate_input_memfile(sf); return std::make_tuple( static_cast(sf->signal.rate), static_cast(sf->signal.length / sf->signal.channels), static_cast(sf->signal.channels), static_cast(sf->encoding.bits_per_sample), get_encoding(sf->encoding.encoding)); } } // namespace paddleaudio } // namespace sox_io