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