KVParser.cpp 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * Author: Patrick-Christopher Mattulat
  3. * Company: Lynar Studios
  4. * E-Mail: webmaster@lynarstudios.com
  5. * Created: 2020-12-25
  6. * Changed: 2021-04-23
  7. *
  8. * */
  9. #include <ls_std/io/kv/KVParser.hpp>
  10. #include <ls_std/exception/NullPointerException.hpp>
  11. #include <ls_std/io/NewLine.hpp>
  12. ls_std::KVParser::KVParser(const std::shared_ptr<ls_std::KVDocument> &_document) : ls_std::Class("KVParser")
  13. {
  14. this->_assignDocument(_document);
  15. }
  16. std::shared_ptr<ls_std::KVDocument> ls_std::KVParser::getDocument()
  17. {
  18. return this->document;
  19. }
  20. void ls_std::KVParser::parse(const ls_std::byte_field &_data)
  21. {
  22. this->_parse(_data);
  23. }
  24. void ls_std::KVParser::setDocument(const std::shared_ptr<ls_std::KVDocument> &_document)
  25. {
  26. this->_assignDocument(_document);
  27. }
  28. void ls_std::KVParser::_assignDocument(const std::shared_ptr<ls_std::KVDocument> &_document)
  29. {
  30. if (_document == nullptr)
  31. {
  32. throw ls_std::NullPointerException{};
  33. }
  34. this->document = _document;
  35. }
  36. bool ls_std::KVParser::_lineHasPair(ls_std::KVParseData _parseData)
  37. {
  38. return _parseData.line.contains("=") && _parseData.line.contains(";");
  39. }
  40. void ls_std::KVParser::_parse(const ls_std::byte_field &_data)
  41. {
  42. for (std::string::size_type index = 0; index < _data.size(); index++)
  43. {
  44. ls_std::KVParseData parseData = ls_std::KVParser::_readLine(_data, index);
  45. this->_parsePair(parseData);
  46. index = parseData.index;
  47. }
  48. }
  49. void ls_std::KVParser::_parsePair(ls_std::KVParseData _parseData)
  50. {
  51. if (ls_std::KVParser::_lineHasPair(_parseData))
  52. {
  53. size_t equalSignPosition = _parseData.line.toString().find('=');
  54. ls_std::kv_key key = _parseData.line.toString().substr(0, equalSignPosition);
  55. ls_std::kv_value value = _parseData.line.toString().substr(equalSignPosition + 1);
  56. value = value.substr(0, value.find(';'));
  57. this->document->addPair(ls_std::KVPair{key, value});
  58. }
  59. }
  60. ls_std::KVParseData ls_std::KVParser::_readLine(const ls_std::byte_field &_data, std::string::size_type _index)
  61. {
  62. ls_std::KVParseData parseData{};
  63. parseData.line = _data.substr(_index);
  64. if (parseData.line.contains(ls_std::NewLine::getWindowsNewLine()))
  65. {
  66. ls_std::KVParser::_readLineWithWindowsLineBreak(parseData);
  67. }
  68. else
  69. {
  70. if (parseData.line.contains(ls_std::NewLine::getUnixNewLine()))
  71. {
  72. ls_std::KVParser::_readLineWithUnixLineBreak(parseData);
  73. }
  74. }
  75. parseData.index = _index + parseData.line.toString().size();
  76. return parseData;
  77. }
  78. void ls_std::KVParser::_readLineWithUnixLineBreak(ls_std::KVParseData &_parseData)
  79. {
  80. size_t newLinePosition = _parseData.line.toString().find(ls_std::NewLine::getUnixNewLine());
  81. _parseData.line = _parseData.line.toString().substr(0, newLinePosition);
  82. }
  83. void ls_std::KVParser::_readLineWithWindowsLineBreak(ls_std::KVParseData &_parseData)
  84. {
  85. size_t newLinePosition = _parseData.line.toString().find(ls_std::NewLine::getWindowsNewLine());
  86. _parseData.line = _parseData.line.toString().substr(0, newLinePosition + 1);
  87. }