summaryrefslogtreecommitdiffhomepage
path: root/loader
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2023-03-18 21:18:37 +0100
committerStanislaw Halik <sthalik@misaki.pl>2023-03-18 21:18:37 +0100
commit98fb8aec8d1ba98342488096d1a2fcb3d58d9462 (patch)
tree7e787a230a5abf8a43e584c960a006cc2bedb5ff /loader
parent6aaa28ef62e0ebc2b4c2ced4d457c91d36e8a311 (diff)
loader: less alloca(3), more FILENAME_MAX
Diffstat (limited to 'loader')
-rw-r--r--loader/atlas.cpp7
-rw-r--r--loader/texture.cpp10
2 files changed, 9 insertions, 8 deletions
diff --git a/loader/atlas.cpp b/loader/atlas.cpp
index 9057746f..be8a2d23 100644
--- a/loader/atlas.cpp
+++ b/loader/atlas.cpp
@@ -4,6 +4,7 @@
#include "src/emplacer.hpp"
#include "src/tile-atlas.hpp"
#include "src/anim-atlas.hpp"
+#include <cstdio>
#include <algorithm>
#include <Corrade/Containers/ArrayViewStl.h>
#include <Corrade/Containers/Pair.h>
@@ -43,10 +44,10 @@ ArrayView<String> loader_impl::anim_atlas_list()
std::shared_ptr<anim_atlas> loader_impl::anim_atlas(StringView name, StringView dir) noexcept(false)
{
- constexpr std::size_t bufsiz = PATH_MAX;
- char path_buf[PATH_MAX];
+ fm_assert(dir && dir[dir.size()-1] == '/');
+ char path_buf[FILENAME_MAX];
name = Path::splitExtension(name).first();
- fm_assert(dir.size() + name.size() + 1 < bufsiz);
+ fm_assert(dir.size() + name.size() + 1 + 1 < FILENAME_MAX);
std::memcpy(path_buf, dir.data(), dir.size());
path_buf[dir.size()] = '/';
std::memcpy(&path_buf[dir.size() + 1], name.data(), name.size());
diff --git a/loader/texture.cpp b/loader/texture.cpp
index 6ffcc5d8..e14d0f34 100644
--- a/loader/texture.cpp
+++ b/loader/texture.cpp
@@ -2,8 +2,8 @@
#include "compat/assert.hpp"
#include "compat/exception.hpp"
#include "compat/defs.hpp"
-#include "compat/alloca.hpp"
#include <cstring>
+#include <cstdio>
#include <Corrade/Containers/StringStlView.h>
#include <Corrade/Utility/Path.h>
#include <Magnum/Trade/ImageData.h>
@@ -15,18 +15,18 @@ Trade::ImageData2D loader_impl::texture(StringView prefix, StringView filename_)
{
ensure_plugins();
+ constexpr std::size_t max_extension_length = 16;
const auto N = prefix.size();
if (N > 0)
fm_assert(prefix[N-1] == '/');
- fm_soft_assert(filename_.size() < 512);
+ fm_soft_assert(filename_.size() + prefix.size() + max_extension_length + 1 < FILENAME_MAX);
fm_soft_assert(check_atlas_name(filename_));
fm_soft_assert(tga_importer);
- constexpr std::size_t max_extension_length = 16;
- char* const filename = (char*)alloca(filename_.size() + N + 1 + max_extension_length);
+ char filename[FILENAME_MAX];
if (N > 0)
std::memcpy(filename, prefix.data(), N);
- std::memcpy(filename + N, filename_.cbegin(), filename_.size());
+ std::memcpy(filename + N, filename_.data(), filename_.size());
std::size_t len = filename_.size() + N;
for (const auto& extension : std::initializer_list<StringView>{ ".tga", ".png", ".webp", })