VariantParser make readahead optional

It turns out some areas are independently moving / reading filepointers outside of the VariantParser, which can cause the readahead caching to get out of sync.

This PR makes the VariantParser readahead to be optional to allow for these use cases.
This commit is contained in:
lawnjelly 2022-12-12 15:44:39 +00:00 committed by Relintai
parent b1c99f29e3
commit 25c3232a77
3 changed files with 31 additions and 5 deletions

View File

@ -42,7 +42,7 @@ CharType VariantParser::Stream::get_char() {
} }
// attempt to readahead // attempt to readahead
readahead_filled = _read_buffer(readahead_buffer, READAHEAD_SIZE); readahead_filled = _read_buffer(readahead_buffer, readahead_enabled ? READAHEAD_SIZE : 1);
if (readahead_filled) { if (readahead_filled) {
readahead_pointer = 0; readahead_pointer = 0;
} else { } else {
@ -54,6 +54,13 @@ CharType VariantParser::Stream::get_char() {
return get_char(); return get_char();
} }
bool VariantParser::Stream::is_eof() const {
if (readahead_enabled) {
return eof;
}
return _is_eof();
}
uint32_t VariantParser::StreamFile::_read_buffer(CharType *p_buffer, uint32_t p_num_chars) { uint32_t VariantParser::StreamFile::_read_buffer(CharType *p_buffer, uint32_t p_num_chars) {
// The buffer is assumed to include at least one character (for null terminator) // The buffer is assumed to include at least one character (for null terminator)
ERR_FAIL_COND_V(!p_num_chars, 0); ERR_FAIL_COND_V(!p_num_chars, 0);
@ -75,6 +82,10 @@ bool VariantParser::StreamFile::is_utf8() const {
return true; return true;
} }
bool VariantParser::StreamFile::_is_eof() const {
return f->eof_reached();
}
uint32_t VariantParser::StreamString::_read_buffer(CharType *p_buffer, uint32_t p_num_chars) { uint32_t VariantParser::StreamString::_read_buffer(CharType *p_buffer, uint32_t p_num_chars) {
// The buffer is assumed to include at least one character (for null terminator) // The buffer is assumed to include at least one character (for null terminator)
ERR_FAIL_COND_V(!p_num_chars, 0); ERR_FAIL_COND_V(!p_num_chars, 0);
@ -107,6 +118,10 @@ bool VariantParser::StreamString::is_utf8() const {
return false; return false;
} }
bool VariantParser::StreamString::_is_eof() const {
return pos > s.length();
}
///////////////////////////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////////////////////////
const char *VariantParser::tk_name[TK_MAX] = { const char *VariantParser::tk_name[TK_MAX] = {

View File

@ -45,14 +45,16 @@ public:
bool eof = false; bool eof = false;
protected: protected:
bool readahead_enabled = true;
virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars) = 0; virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars) = 0;
virtual bool _is_eof() const = 0;
public: public:
CharType saved; CharType saved;
CharType get_char(); CharType get_char();
virtual bool is_utf8() const = 0; virtual bool is_utf8() const = 0;
bool is_eof() const { return eof; } bool is_eof() const;
Stream() : Stream() :
saved(0) {} saved(0) {}
@ -62,12 +64,16 @@ public:
struct StreamFile : public Stream { struct StreamFile : public Stream {
protected: protected:
virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars); virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars);
virtual bool _is_eof() const;
public: public:
FileAccess *f; FileAccess *f;
virtual bool is_utf8() const; virtual bool is_utf8() const;
StreamFile() { f = nullptr; } StreamFile(bool p_readahead_enabled = true) {
f = nullptr;
readahead_enabled = p_readahead_enabled;
}
}; };
struct StreamString : public Stream { struct StreamString : public Stream {
@ -76,12 +82,16 @@ public:
protected: protected:
virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars); virtual uint32_t _read_buffer(CharType *p_buffer, uint32_t p_num_chars);
virtual bool _is_eof() const;
public: public:
String s; String s;
virtual bool is_utf8() const; virtual bool is_utf8() const;
StreamString() { pos = 0; } StreamString(bool p_readahead_enabled = true) {
pos = 0;
readahead_enabled = p_readahead_enabled;
}
}; };
typedef Error (*ParseResourceFunc)(void *p_self, Stream *p_stream, Ref<Resource> &r_res, int &line, String &r_err_str); typedef Error (*ParseResourceFunc)(void *p_self, Stream *p_stream, Ref<Resource> &r_res, int &line, String &r_err_str);

View File

@ -629,7 +629,8 @@ void ResourceInteractiveLoaderText::set_translation_remapped(bool p_remapped) {
translation_remapped = p_remapped; translation_remapped = p_remapped;
} }
ResourceInteractiveLoaderText::ResourceInteractiveLoaderText() { ResourceInteractiveLoaderText::ResourceInteractiveLoaderText() :
stream(false) {
translation_remapped = false; translation_remapped = false;
} }