18bf80f4bSopenharmony_ci/* 28bf80f4bSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 38bf80f4bSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 48bf80f4bSopenharmony_ci * you may not use this file except in compliance with the License. 58bf80f4bSopenharmony_ci * You may obtain a copy of the License at 68bf80f4bSopenharmony_ci * 78bf80f4bSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 88bf80f4bSopenharmony_ci * 98bf80f4bSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 108bf80f4bSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 118bf80f4bSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 128bf80f4bSopenharmony_ci * See the License for the specific language governing permissions and 138bf80f4bSopenharmony_ci * limitations under the License. 148bf80f4bSopenharmony_ci */ 158bf80f4bSopenharmony_ci 168bf80f4bSopenharmony_ci#ifndef META_SRC_LOADERS_CSV_PARSER_H 178bf80f4bSopenharmony_ci#define META_SRC_LOADERS_CSV_PARSER_H 188bf80f4bSopenharmony_ci 198bf80f4bSopenharmony_ci#include <base/containers/string.h> 208bf80f4bSopenharmony_ci#include <base/containers/string_view.h> 218bf80f4bSopenharmony_ci#include <base/containers/vector.h> 228bf80f4bSopenharmony_ci 238bf80f4bSopenharmony_ci#include <meta/base/namespace.h> 248bf80f4bSopenharmony_ci 258bf80f4bSopenharmony_ciMETA_BEGIN_NAMESPACE() 268bf80f4bSopenharmony_ci 278bf80f4bSopenharmony_ci/** 288bf80f4bSopenharmony_ci * @brief The CsvParser class implements a simple CSV parser, which 298bf80f4bSopenharmony_ci * parses a given CSV format string. 308bf80f4bSopenharmony_ci * The parser supports non-quoted and quoted items, separated 318bf80f4bSopenharmony_ci * by a configurable delimiter. Also multiline quotes are 328bf80f4bSopenharmony_ci * supported. 338bf80f4bSopenharmony_ci */ 348bf80f4bSopenharmony_ciclass CsvParser { 358bf80f4bSopenharmony_cipublic: 368bf80f4bSopenharmony_ci CsvParser() = delete; 378bf80f4bSopenharmony_ci explicit CsvParser(BASE_NS::string_view csv, const char delimiter = ','); 388bf80f4bSopenharmony_ci 398bf80f4bSopenharmony_ci using CsvRow = BASE_NS::vector<BASE_NS::string>; 408bf80f4bSopenharmony_ci 418bf80f4bSopenharmony_ci /** 428bf80f4bSopenharmony_ci * @brief GetRow returns the next row from the CSV file. 438bf80f4bSopenharmony_ci * Regularly the user should call GetRow in a loop until 448bf80f4bSopenharmony_ci * the function returns false (either parse error or 458bf80f4bSopenharmony_ci * end of the CSV file). 468bf80f4bSopenharmony_ci * @param row Row items will be placed here. 478bf80f4bSopenharmony_ci * @return True if parsing was successful, false otherwide. 488bf80f4bSopenharmony_ci */ 498bf80f4bSopenharmony_ci bool GetRow(CsvRow& row); 508bf80f4bSopenharmony_ci /** 518bf80f4bSopenharmony_ci * @brief Resets to the beginning of the CSV string. 528bf80f4bSopenharmony_ci */ 538bf80f4bSopenharmony_ci void Reset(); 548bf80f4bSopenharmony_ci 558bf80f4bSopenharmony_ciprivate: 568bf80f4bSopenharmony_ci enum State { 578bf80f4bSopenharmony_ci NO_QUOTE, 588bf80f4bSopenharmony_ci IN_QUOTE, 598bf80f4bSopenharmony_ci QUOTED, 608bf80f4bSopenharmony_ci }; 618bf80f4bSopenharmony_ci CsvRow ParseRow(); 628bf80f4bSopenharmony_ci BASE_NS::string_view Trimmed(BASE_NS::string_view sv, State state); 638bf80f4bSopenharmony_ci 648bf80f4bSopenharmony_ci char delimiter_ {}; 658bf80f4bSopenharmony_ci BASE_NS::string csv_; 668bf80f4bSopenharmony_ci size_t pos_ {}; 678bf80f4bSopenharmony_ci}; 688bf80f4bSopenharmony_ci 698bf80f4bSopenharmony_ciMETA_END_NAMESPACE() 708bf80f4bSopenharmony_ci 718bf80f4bSopenharmony_ci#endif 72