fileAPI.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // zlib open source license
  2. //
  3. // Copyright (c) 2020 to 2022 David Forsgren Piuva
  4. //
  5. // This software is provided 'as-is', without any express or implied
  6. // warranty. In no event will the authors be held liable for any damages
  7. // arising from the use of this software.
  8. //
  9. // Permission is granted to anyone to use this software for any purpose,
  10. // including commercial applications, and to alter it and redistribute it
  11. // freely, subject to the following restrictions:
  12. //
  13. // 1. The origin of this software must not be misrepresented; you must not
  14. // claim that you wrote the original software. If you use this software
  15. // in a product, an acknowledgment in the product documentation would be
  16. // appreciated but is not required.
  17. //
  18. // 2. Altered source versions must be plainly marked as such, and must not be
  19. // misrepresented as being the original software.
  20. //
  21. // 3. This notice may not be removed or altered from any source
  22. // distribution.
  23. #ifndef DFPSR_API_FILE
  24. #define DFPSR_API_FILE
  25. #include "../api/stringAPI.h"
  26. #include "bufferAPI.h"
  27. // A module for file access that exists to prevent cyclic dependencies between strings and buffers.
  28. // Buffers need a filename to be saved or loaded while strings use buffers to store their characters.
  29. namespace dsr {
  30. // Post-condition:
  31. // Returns the content of the file referred to be filename.
  32. // If mustExist is true, then failure to load will throw an exception.
  33. // If mustExist is false, then failure to load will return an empty handle (returning false for buffer_exists).
  34. Buffer file_loadBuffer(const ReadableString& filename, bool mustExist = true);
  35. // Side-effect: Saves buffer to filename as a binary file.
  36. // Pre-condition: buffer exists
  37. void file_saveBuffer(const ReadableString& filename, Buffer buffer);
  38. // Get a path separator for the target operating system.
  39. // Can be used to construct a file path that works for both forward and backward slash separators.
  40. const char32_t* file_separator();
  41. }
  42. #endif