mirror of
https://github.com/melonDS-emu/melonDS.git
synced 2025-06-28 09:59:41 -06:00
358 lines
7.0 KiB
C++
Vendored
358 lines
7.0 KiB
C++
Vendored
#ifndef TOML11_SYNTAX_FWD_HPP
|
|
#define TOML11_SYNTAX_FWD_HPP
|
|
|
|
#include "../scanner.hpp"
|
|
#include "../spec.hpp"
|
|
|
|
namespace toml
|
|
{
|
|
namespace detail
|
|
{
|
|
namespace syntax
|
|
{
|
|
|
|
using char_type = location::char_type;
|
|
|
|
// ===========================================================================
|
|
// UTF-8
|
|
|
|
// avoid redundant representation and out-of-unicode sequence
|
|
|
|
character_in_range utf8_1byte (const spec&);
|
|
sequence utf8_2bytes(const spec&);
|
|
sequence utf8_3bytes(const spec&);
|
|
sequence utf8_4bytes(const spec&);
|
|
|
|
class non_ascii final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
public:
|
|
|
|
explicit non_ascii(const spec& s) noexcept;
|
|
~non_ascii() override = default;
|
|
|
|
region scan(location& loc) const override
|
|
{
|
|
return scanner_.scan(loc);
|
|
}
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "non-ascii utf-8 bytes";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new non_ascii(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "non_ascii";
|
|
}
|
|
|
|
private:
|
|
|
|
either scanner_;
|
|
};
|
|
|
|
// ===========================================================================
|
|
// Whitespace
|
|
|
|
character_either wschar(const spec&);
|
|
|
|
repeat_at_least ws(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Newline
|
|
|
|
either newline(const spec&);
|
|
|
|
// ===========================================================================
|
|
// Comments
|
|
|
|
either allowed_comment_char(const spec& s);
|
|
|
|
// XXX Note that it does not take newline
|
|
sequence comment(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Boolean
|
|
|
|
either boolean(const spec&);
|
|
|
|
// ===========================================================================
|
|
// Integer
|
|
|
|
class digit final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
public:
|
|
|
|
explicit digit(const spec&) noexcept;
|
|
~digit() override = default;
|
|
|
|
region scan(location& loc) const override
|
|
{
|
|
return scanner_.scan(loc);
|
|
}
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "digit [0-9]";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new digit(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "digit";
|
|
}
|
|
|
|
private:
|
|
|
|
character_in_range scanner_;
|
|
};
|
|
|
|
class alpha final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
public:
|
|
|
|
explicit alpha(const spec&) noexcept;
|
|
~alpha() override = default;
|
|
|
|
region scan(location& loc) const override
|
|
{
|
|
return scanner_.scan(loc);
|
|
}
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "alpha [a-zA-Z]";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new alpha(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "alpha";
|
|
}
|
|
|
|
private:
|
|
|
|
either scanner_;
|
|
};
|
|
|
|
class hexdig final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
public:
|
|
|
|
explicit hexdig(const spec& s) noexcept;
|
|
~hexdig() override = default;
|
|
|
|
region scan(location& loc) const override
|
|
{
|
|
return scanner_.scan(loc);
|
|
}
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "hex [0-9a-fA-F]";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new hexdig(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "hexdig";
|
|
}
|
|
|
|
private:
|
|
|
|
either scanner_;
|
|
};
|
|
|
|
sequence num_suffix(const spec& s);
|
|
|
|
sequence dec_int(const spec& s);
|
|
sequence hex_int(const spec& s);
|
|
sequence oct_int(const spec&);
|
|
sequence bin_int(const spec&);
|
|
either integer(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Floating
|
|
|
|
sequence zero_prefixable_int(const spec& s);
|
|
sequence fractional_part(const spec& s);
|
|
sequence exponent_part(const spec& s);
|
|
sequence hex_floating(const spec& s);
|
|
either floating(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Datetime
|
|
|
|
sequence local_date(const spec& s);
|
|
sequence local_time(const spec& s);
|
|
either time_offset(const spec& s);
|
|
sequence full_time(const spec& s);
|
|
character_either time_delim(const spec&);
|
|
sequence local_datetime(const spec& s);
|
|
sequence offset_datetime(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// String
|
|
|
|
sequence escaped(const spec& s);
|
|
|
|
either basic_char(const spec& s);
|
|
|
|
sequence basic_string(const spec& s);
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// multiline string
|
|
|
|
sequence escaped_newline(const spec& s);
|
|
sequence ml_basic_string(const spec& s);
|
|
|
|
// ---------------------------------------------------------------------------
|
|
// literal string
|
|
|
|
either literal_char(const spec& s);
|
|
sequence literal_string(const spec& s);
|
|
|
|
sequence ml_literal_string(const spec& s);
|
|
|
|
either string(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Keys
|
|
|
|
// to keep `expected_chars` simple
|
|
class non_ascii_key_char final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
private:
|
|
|
|
using in_range = character_in_range; // make definition short
|
|
|
|
public:
|
|
|
|
explicit non_ascii_key_char(const spec& s) noexcept;
|
|
~non_ascii_key_char() override = default;
|
|
|
|
region scan(location& loc) const override;
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "bare key non-ASCII script";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new non_ascii_key_char(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "non-ASCII bare key";
|
|
}
|
|
|
|
private:
|
|
|
|
std::uint32_t read_utf8(location& loc) const;
|
|
};
|
|
|
|
|
|
repeat_at_least unquoted_key(const spec& s);
|
|
|
|
either quoted_key(const spec& s);
|
|
|
|
either simple_key(const spec& s);
|
|
|
|
sequence dot_sep(const spec& s);
|
|
|
|
sequence dotted_key(const spec& s);
|
|
|
|
|
|
class key final : public scanner_base
|
|
{
|
|
public:
|
|
|
|
using char_type = location::char_type;
|
|
|
|
public:
|
|
|
|
explicit key(const spec& s) noexcept;
|
|
~key() override = default;
|
|
|
|
region scan(location& loc) const override
|
|
{
|
|
return scanner_.scan(loc);
|
|
}
|
|
|
|
std::string expected_chars(location&) const override
|
|
{
|
|
return "basic key([a-zA-Z0-9_-]) or quoted key(\" or ')";
|
|
}
|
|
|
|
scanner_base* clone() const override
|
|
{
|
|
return new key(*this);
|
|
}
|
|
|
|
std::string name() const override
|
|
{
|
|
return "key";
|
|
}
|
|
|
|
private:
|
|
|
|
either scanner_;
|
|
};
|
|
|
|
sequence keyval_sep(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// Table key
|
|
|
|
sequence std_table(const spec& s);
|
|
|
|
sequence array_table(const spec& s);
|
|
|
|
// ===========================================================================
|
|
// extension: null
|
|
|
|
literal null_value(const spec&);
|
|
|
|
} // namespace syntax
|
|
} // namespace detail
|
|
} // namespace toml
|
|
#endif // TOML11_SYNTAX_FWD_HPP
|