Веб-сайт самохостера Lotigara

summaryrefslogtreecommitdiff
path: root/source/base/StarAssets.cpp
diff options
context:
space:
mode:
authorKae <80987908+Novaenia@users.noreply.github.com>2023-06-24 01:30:55 +1000
committerKae <80987908+Novaenia@users.noreply.github.com>2023-06-24 01:30:55 +1000
commit2798d4bf668d74028b5c1f88ae5b7b25cd08de2d (patch)
tree4a4df7c000c2e7d8be953dcf0724aa8f4b0d2b24 /source/base/StarAssets.cpp
parent6832c10ed5482530b4a423a78700b279fc73212a (diff)
what the fuck it's 1:30 AM. god
Diffstat (limited to 'source/base/StarAssets.cpp')
-rw-r--r--source/base/StarAssets.cpp164
1 files changed, 1 insertions, 163 deletions
diff --git a/source/base/StarAssets.cpp b/source/base/StarAssets.cpp
index aab4468..d0b77f5 100644
--- a/source/base/StarAssets.cpp
+++ b/source/base/StarAssets.cpp
@@ -1,4 +1,5 @@
#include "StarAssets.hpp"
+#include "StarAssetPath.hpp"
#include "StarFile.hpp"
#include "StarTime.hpp"
#include "StarDirectoryAssetSource.hpp"
@@ -59,169 +60,6 @@ static void validatePath(AssetPath const& components, bool canContainSubPath, bo
throw AssetException::format("Path '%s' cannot contain directives", components);
}
-// The filename is everything after the last slash (excluding directives) and
-// up to the first directive marker.
-static Maybe<pair<size_t, size_t>> findFilenameRange(std::string const& pathUtf8) {
- size_t firstDirectiveOrSubPath = pathUtf8.find_first_of(":?");
- size_t filenameStart = 0;
- while (true) {
- size_t find = pathUtf8.find('/', filenameStart);
- if (find >= firstDirectiveOrSubPath)
- break;
- filenameStart = find + 1;
- }
-
- if (filenameStart == NPos) {
- return {};
- } else if (firstDirectiveOrSubPath == NPos) {
- return {{filenameStart, pathUtf8.size()}};
- } else {
- return {{filenameStart, firstDirectiveOrSubPath}};
- }
-}
-
-AssetPath AssetPath::split(String const& path) {
- auto i = path.begin();
- auto end = path.end();
-
- AssetPath components;
-
- // base paths cannot have any ':' or '?' characters, stop at the first one.
- while (i != end) {
- String::Char c = *i;
- if (c == ':' || c == '?')
- break;
-
- components.basePath += c;
- ++i;
- }
-
- // Sub-paths must immediately follow base paths and must start with a ':',
- // after this point any further ':' characters are not special.
- if (i != end && *i == ':') {
- ++i;
- while (i != end) {
- String::Char c = *i;
- if (c == '?')
- break;
-
- if (!components.subPath)
- components.subPath.emplace();
-
- *components.subPath += c;
- ++i;
- }
- }
-
- // Directives must follow the base path and optional sub-path, and each
- // directive is separated by one or more '?' characters.
- while (i != end && *i == '?') {
- ++i;
- String directive;
- while (i != end) {
- String::Char c = *i;
- if (c == '?')
- break;
-
- directive += c;
- ++i;
- }
- if (!directive.empty())
- components.directives.append(move(directive));
- }
-
- starAssert(i == end);
-
- return components;
-}
-
-String AssetPath::join(AssetPath const& components) {
- return toString(components);
-}
-
-String AssetPath::setSubPath(String const& path, String const& subPath) {
- auto components = split(path);
- components.subPath = subPath;
- return join(components);
-}
-
-String AssetPath::removeSubPath(String const& path) {
- auto components = split(path);
- components.subPath.reset();
- return join(components);
-}
-
-String AssetPath::getDirectives(String const& path) {
- size_t firstDirective = path.find('?');
- if (firstDirective == NPos)
- return {};
- return path.substr(firstDirective + 1);
-}
-
-String AssetPath::addDirectives(String const& path, String const& directives) {
- return String::joinWith("?", path, directives);
-}
-
-String AssetPath::removeDirectives(String const& path) {
- size_t firstDirective = path.find('?');
- if (firstDirective == NPos)
- return path;
- return path.substr(0, firstDirective);
-}
-
-String AssetPath::directory(String const& path) {
- if (auto p = findFilenameRange(path.utf8())) {
- return String(path.utf8().substr(0, p->first));
- } else {
- return String();
- }
-}
-
-String AssetPath::filename(String const& path) {
- if (auto p = findFilenameRange(path.utf8())) {
- return String(path.utf8().substr(p->first, p->second));
- } else {
- return String();
- }
-}
-
-String AssetPath::extension(String const& path) {
- auto file = filename(path);
- auto lastDot = file.findLast(".");
- if (lastDot == NPos)
- return "";
-
- return file.substr(lastDot + 1);
-}
-
-String AssetPath::relativeTo(String const& sourcePath, String const& givenPath) {
- if (!givenPath.empty() && givenPath[0] == '/')
- return givenPath;
-
- auto path = directory(sourcePath);
- path.append(givenPath);
- return path;
-}
-
-bool AssetPath::operator==(AssetPath const& rhs) const {
- return tie(basePath, subPath, directives) == tie(rhs.basePath, rhs.subPath, rhs.directives);
-}
-
-std::ostream& operator<<(std::ostream& os, AssetPath const& rhs) {
- os << rhs.basePath;
- if (rhs.subPath) {
- os << ":";
- os << *rhs.subPath;
- }
-
- for (auto const& directive : rhs.directives) {
- os << "?";
- os << directive;
- }
-
- return os;
-}
-
Maybe<RectU> FramesSpecification::getRect(String const& frame) const {
if (auto alias = aliases.ptr(frame)) {
return frames.get(*alias);