variant_parser.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #ifndef VARIANT_PARSER_H
  2. #define VARIANT_PARSER_H
  3. #include "variant.h"
  4. #include "os/file_access.h"
  5. #include "resource.h"
  6. class VariantParser {
  7. public:
  8. struct Stream {
  9. virtual CharType get_char()=0;
  10. virtual bool is_utf8() const=0;
  11. virtual bool is_eof() const=0;
  12. CharType saved;
  13. Stream() { saved=0; }
  14. virtual ~Stream() {}
  15. };
  16. struct StreamFile : public Stream {
  17. FileAccess *f;
  18. virtual CharType get_char();
  19. virtual bool is_utf8() const;
  20. virtual bool is_eof() const;
  21. StreamFile() { f=NULL; }
  22. };
  23. struct StreamString : public Stream {
  24. String s;
  25. int pos;
  26. virtual CharType get_char();
  27. virtual bool is_utf8() const;
  28. virtual bool is_eof() const;
  29. StreamString() { pos=0; }
  30. };
  31. typedef Error (*ParseResourceFunc)(void* p_self, Stream* p_stream,Ref<Resource>& r_res,int &line,String &r_err_str);
  32. struct ResourceParser {
  33. void *userdata;
  34. ParseResourceFunc func;
  35. ParseResourceFunc ext_func;
  36. ParseResourceFunc sub_func;
  37. };
  38. enum TokenType {
  39. TK_CURLY_BRACKET_OPEN,
  40. TK_CURLY_BRACKET_CLOSE,
  41. TK_BRACKET_OPEN,
  42. TK_BRACKET_CLOSE,
  43. TK_PARENTHESIS_OPEN,
  44. TK_PARENTHESIS_CLOSE,
  45. TK_IDENTIFIER,
  46. TK_STRING,
  47. TK_NUMBER,
  48. TK_COLOR,
  49. TK_COLON,
  50. TK_COMMA,
  51. TK_PERIOD,
  52. TK_EQUAL,
  53. TK_EOF,
  54. TK_ERROR,
  55. TK_MAX
  56. };
  57. enum Expecting {
  58. EXPECT_OBJECT,
  59. EXPECT_OBJECT_KEY,
  60. EXPECT_COLON,
  61. EXPECT_OBJECT_VALUE,
  62. };
  63. struct Token {
  64. TokenType type;
  65. Variant value;
  66. };
  67. struct Tag {
  68. String name;
  69. Map<String,Variant> fields;
  70. };
  71. private:
  72. static const char * tk_name[TK_MAX];
  73. template<class T>
  74. static Error _parse_construct(Stream *p_stream, Vector<T>& r_construct, int &line, String &r_err_str);
  75. static Error _parse_enginecfg(Stream *p_stream, Vector<String>& strings, int &line, String &r_err_str);
  76. static Error _parse_dictionary(Dictionary &object, Stream *p_stream, int &line, String &r_err_str,ResourceParser *p_res_parser=NULL);
  77. static Error _parse_array(Array &array, Stream *p_stream, int &line, String &r_err_str,ResourceParser *p_res_parser=NULL);
  78. static Error _parse_tag(Token& token,Stream *p_stream, int &line, String &r_err_str,Tag& r_tag,ResourceParser *p_res_parser=NULL,bool p_simple_tag=false);
  79. public:
  80. static Error parse_tag(Stream *p_stream, int &line, String &r_err_str,Tag& r_tag,ResourceParser *p_res_parser=NULL,bool p_simple_tag=false);
  81. static Error parse_tag_assign_eof(Stream *p_stream, int &line, String &r_err_str, Tag& r_tag, String &r_assign, Variant &r_value,ResourceParser *p_res_parser=NULL,bool p_simple_tag=false);
  82. static Error parse_value(Token& token,Variant &value, Stream *p_stream, int &line, String &r_err_str,ResourceParser *p_res_parser=NULL);
  83. static Error get_token(Stream *p_stream,Token& r_token,int &line,String &r_err_str);
  84. static Error parse(Stream *p_stream, Variant &r_ret, String &r_err_str, int &r_err_line,ResourceParser *p_res_parser=NULL);
  85. };
  86. class VariantWriter {
  87. public:
  88. typedef Error (*StoreStringFunc)(void *ud,const String& p_string);
  89. typedef String (*EncodeResourceFunc)(void *ud,const RES& p_resource);
  90. static Error write(const Variant& p_variant, StoreStringFunc p_store_string_func, void *p_store_string_ud,EncodeResourceFunc p_encode_res_func,void* p_encode_res_ud);
  91. static Error write_to_string(const Variant& p_variant, String& r_string, EncodeResourceFunc p_encode_res_func=NULL,void* p_encode_res_ud=NULL);
  92. };
  93. #endif // VARIANT_PARSER_H