// Copyright (c) 2008, Rodrigo Braz Monteiro // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are met: // // * Redistributions of source code must retain the above copyright notice, // this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above copyright notice, // this list of conditions and the following disclaimer in the documentation // and/or other materials provided with the distribution. // * Neither the name of the Aegisub Group nor the names of its contributors // may be used to endorse or promote products derived from this software // without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE // POSSIBILITY OF SUCH DAMAGE. // // ----------------------------------------------------------------------------- // // AEGISUB/ATHENASUB // // Website: http://www.aegisub.net // Contact: mailto:amz@aegisub.net // #include "format_manager.h" #include "formats/format_ass.h" #include "reader.h" #include "text_reader.h" #include using namespace Athenasub; //////// // List std::vector FormatManager::formats; //////////////// // Add a format void FormatManager::AddFormat(const Format format) { formats.push_back(format); } /////////////////////////////////// // Initialize all built-in formats void FormatManager::InitializeFormats() { AddFormat(Format(new FormatASS())); AddFormat(Format(new FormatSSA())); AddFormat(Format(new FormatASS2())); } /////////////////////// // Removes all formats void FormatManager::ClearFormats() { formats.clear(); } ///////////////////// // Number of formats int FormatManager::GetFormatCount() { return (int) formats.size(); } //////////// // By index Format FormatManager::GetFormatByIndex(const int index) { try { return formats.at(index); } catch (std::out_of_range &e) { (void) e; return Format(); } } /////////////// // By filename Format FormatManager::GetFormatFromFilename(const String &filename,bool read) { size_t len = formats.size(); for (size_t i=0;iGetReadExtensions(); else exts = formats[i]->GetWriteExtensions(); size_t extn = exts.size(); for (size_t j=0;jGetName()) return formats[i]; } return Format(); } /////////////////////////////////////////////////////// // Get a list of all formats compatible with this file std::vector FormatManager::GetCompatibleFormatList(Reader &reader) { // Find all compatible formats and store them with their certainty std::vector > results; size_t len = formats.size(); for (size_t i=0;iCanReadFile(reader); if (certainty > 0.0f) { results.push_back(std::pair(certainty,formats[i])); } } // Functor to sort them struct Comp { bool operator() (const std::pair &p1,const std::pair &p2) { return p1.first > p2.first; } }; // Sort results and store them sort(results.begin(),results.end(),Comp()); len = results.size(); std::vector finalResults; for (size_t i=0;i