nlib
CsvReader.h
[詳解]
1 
2 /*--------------------------------------------------------------------------------*
3  Project: CrossRoad
4  Copyright (C)Nintendo All rights reserved.
5 
6  These coded instructions, statements, and computer programs contain proprietary
7  information of Nintendo and/or its licensed developers and are protected by
8  national and international copyright laws. They may not be disclosed to third
9  parties or copied or duplicated in any form, in whole or in part, without the
10  prior written consent of Nintendo.
11 
12  The content herein is highly confidential and should be handled accordingly.
13  *--------------------------------------------------------------------------------*/
14 
15 #pragma once
16 #ifndef INCLUDE_NN_NLIB_MSGPACK_CSVREADER_H_
17 #define INCLUDE_NN_NLIB_MSGPACK_CSVREADER_H_
18 
19 #include <utility>
20 
22 #include "nn/nlib/Swap.h"
23 
24 #if defined(_MSC_VER) && defined(nx_msgpack_EXPORTS)
25 #undef NLIB_VIS_PUBLIC
26 #define NLIB_VIS_PUBLIC NLIB_WINEXPORT
27 #endif
28 
29 NLIB_NAMESPACE_BEGIN
30 class InputStream;
31 namespace msgpack {
32 
34  public:
35  // In Conformance with RFC4180(https://www.ietf.org/rfc/rfc4180.txt).
36  // except that
37  // pass UTF-8, the UTF-8 string is checked validity.
38  // pass CR, LF, CRLF as a new line.
39  NLIB_CEXPR CsvReader() NLIB_NOEXCEPT : prv_(nullptr), error_(0) {}
40  ~CsvReader() NLIB_NOEXCEPT { Reset(); }
41  NLIB_DEFMOVE_PIMPL(CsvReader);
42  NLIB_DEPRECATED void swap(CsvReader& rhs) NLIB_NOEXCEPT {
43  using std::swap;
44  swap(prv_, rhs.prv_);
45  }
46  void Reset() NLIB_NOEXCEPT;
47  errno_t Init() NLIB_NOEXCEPT;
48  errno_t Open(InputStream* stream) NLIB_NOEXCEPT;
49  bool Close() NLIB_NOEXCEPT;
50  errno_t GetErrorValue() const NLIB_NOEXCEPT { return error_; }
51 
52  public:
53  static bool Read(MpObject* obj, const nlib_utf8_t* csvtext) NLIB_NOEXCEPT NLIB_NONNULL;
54 #ifdef __cpp_rvalue_references
55  static std::pair<bool, MpObject>
56  Read(const nlib_utf8_t* csvtext) NLIB_NOEXCEPT {
57  std::pair<bool, MpObject> rval;
58  rval.first = Read(&rval.second, csvtext);
59  return rval;
60  }
61 #endif
62  bool Read(MpObject* obj) NLIB_NOEXCEPT NLIB_NONNULL;
63  InputStream* GetStream() NLIB_NOEXCEPT;
64  NLIB_SAFE_BOOL(CsvReader, error_ == 0)
65 
66  private:
67  void SetError(errno_t e) NLIB_NOEXCEPT {
68  if (error_ == 0) error_ = e;
69  }
70 
71  private:
72  struct CsvReaderPrivate;
73  CsvReaderPrivate* prv_;
74  errno_t error_;
76 };
77 
78 } // namespace msgpack
79 NLIB_NAMESPACE_END
80 NLIB_DEFINE_STD_SWAP(::nlib_ns::msgpack::CsvReader)
81 #if defined(_MSC_VER) && defined(nx_msgpack_EXPORTS)
82 #undef NLIB_VIS_PUBLIC
83 #define NLIB_VIS_PUBLIC NLIB_WINIMPORT
84 #endif
85 
86 #endif // INCLUDE_NN_NLIB_MSGPACK_CSVREADER_H_
CSVパーサーです。ストリームからCSV文字列を読み込んでパースします。
Definition: CsvReader.h:33
#define NLIB_DISALLOW_COPY_AND_ASSIGN(TypeName)
TypeName で指定されたクラスのコピーコンストラクタと代入演算子を禁止します。
Definition: Config.h:179
#define NLIB_SAFE_BOOL(class_name, exp)
クラス内に安全なoperator bool()を定義します。 可能であればC++11のexplicit boolを利用します。 ...
Definition: Config.h:194
#define NLIB_DEPRECATED
関数等がdeprecatedになったことを示します。
Definition: Config.h:109
#define NLIB_VIS_PUBLIC
関数やクラス等のシンボルをライブラリの外部に公開します。
Definition: Platform_unix.h:89
MessagePack又はJSONを読み込むことで作成されるオブジェクトです。
Definition: MpObject.h:95
MessagePack, JSON及びCSVを読み込むと作成されるオブジェクトです。
入力ストリームの基底クラスです。このクラスを実体化することはできません。
Definition: InputStream.h:29
#define NLIB_NOEXCEPT
環境に合わせてnoexcept 又は同等の定義がされます。
Definition: Config.h:105
~CsvReader() noexcept
デストラクタです。
Definition: CsvReader.h:40
#define NLIB_CEXPR
利用可能であればconstexprが定義されます。そうでない場合は空文字列です。
Definition: Config.h:107
constexpr CsvReader() noexcept
デフォルトコンストラクタです。
Definition: CsvReader.h:39
#define NLIB_FINAL
利用可能であればfinalが定義されます。そうでない場合は空文字列です。
Definition: Config.h:245
bool Read(BinaryReader *r, T *x)
この関数テンプレートを特殊化することで、ユーザー定義クラスに読み込むことができます。 ...
Definition: BinaryReader.h:172
errno_t GetErrorValue() const noexcept
発生したエラーを取得します。
Definition: CsvReader.h:50
#define NLIB_NONNULL
全ての引数にNULLを指定することができないことを示します。
char nlib_utf8_t
charのtypedefです。文字列がUTF-8であることを示します。
Definition: Platform.h:308
int errno_t
intのtypedefで、戻り値としてPOSIXのエラー値を返すことを示します。
Definition: NMalloc.h:37