// Copyright 2022, FOSS-VG Developers and Contributers // // Author(s): // BodgeMaster, Shwoomple // // This program is free software: you can redistribute it and/or modify it // under the terms of the GNU Affero General Public License as published // by the Free Software Foundation, version 3. // // 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 Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // version 3 along with this program. // If not, see https://www.gnu.org/licenses/agpl-3.0.en.html #include #include #include #include #include #include "error.hpp" class File { private: //TODO: add other necessary internals to this section as needed char mode; std::fstream fileStream; //TODO: add other necessary details to the constructor as needed // For example, the fstream (or whatever mechanism is used) needs // to be handed over from File::open() to the File object. // // Remember to add a destructor to the public section if pointers // are to be used. File(std::string path, char mode, uint64_t cursorPosition); public: bool isOpen; bool eof; std::string path; uint64_t cursorPosition; // may be error if not a regular file or size cannot be determined ErrorOr size; File() = default; File(const File& file); File& operator=(const File& file); void open(); void close(); char getMode() const; // only applicable to read and edit modes // moves the cursor to the right of the read section ErrorOr readByte(); ErrorOr> read(uint64_t bytes); // @SodaFountain (or whoever ends up implementing this): // Tiny-UTF8 uses UTF-32 internally IIRC. // There is a constructor for it that takes std::string and // converts it to the internal format. //TODO: remove this comment when it served its purpose ErrorOr readString(uint64_t bytes); // only applicable to write, modify, append, and edit modes // in modify and edit modes, overwrite whatever is at the // cursor position if there is anything there // moves the cursor to the right of the written section ErrorOrVoid writeByte(uint8_t byte); ErrorOrVoid write(std::vector data); ErrorOrVoid writeString(tiny_utf8::string string); // only applicable to modify and edit modes // insert at cursor position and move other contents to the right // moves the cursor to the right of the inserted section ErrorOrVoid insertByte(uint8_t byte); ErrorOrVoid insert(std::vector data); ErrorOrVoid insertString(tiny_utf8::string string); // only applicable to edit mode // return the cut section, remove cut section from file // moves the cursor to the right of where it happened ErrorOr cutByte(); ErrorOr> cut(uint64_t length); ErrorOr cutString(uint64_t length); // modes: // r (read) // w (write: overwrite file deleting its previous contents) // a (append: write to end of file) // m (modify: write to file modifying its previous contents) // e (edit: like read+modify) // // A startPosition of 0xFFFFFFFF is considered to be the end of // the file whatever its size. static ErrorOr open(std::string path, char mode, uint64_t startPosition=0); };