xlnt
rich_text.hpp
1 // Copyright (c) 2016-2022 Thomas Fussell
2 // Copyright (c) 2024 xlnt-community
3 //
4 // Permission is hereby granted, free of charge, to any person obtaining a copy
5 // of this software and associated documentation files (the "Software"), to deal
6 // in the Software without restriction, including without limitation the rights
7 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 // copies of the Software, and to permit persons to whom the Software is
9 // furnished to do so, subject to the following conditions:
10 //
11 // The above copyright notice and this permission notice shall be included in
12 // all copies or substantial portions of the Software.
13 //
14 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 // THE SOFTWARE
21 //
22 // @license: http://www.opensource.org/licenses/mit-license.php
23 // @author: see AUTHORS file
24 
25 #pragma once
26 
27 #include <string>
28 #include <vector>
29 
30 #include <xlnt/xlnt_config.hpp>
31 #include <xlnt/cell/phonetic_run.hpp>
32 #include <xlnt/cell/rich_text_run.hpp>
33 #include <xlnt/worksheet/phonetic_pr.hpp>
34 
35 namespace xlnt {
36 
41 class XLNT_API rich_text
42 {
43 public:
47  rich_text() = default;
48 
52  rich_text(const std::string &plain_text);
53 
57  rich_text(const rich_text &other);
58 
62  rich_text(const std::string &plain_text, const class font &text_font);
63 
67  rich_text(const rich_text_run &single_run);
68 
72  void clear();
73 
78  void plain_text(const std::string &s, bool preserve_space);
79 
83  std::string plain_text() const;
84 
88  std::vector<rich_text_run> runs() const;
89 
93  void runs(const std::vector<rich_text_run> &new_runs);
94 
98  void add_run(const rich_text_run &t);
99 
103  std::vector<phonetic_run> phonetic_runs() const;
104 
108  void phonetic_runs(const std::vector<phonetic_run> &new_phonetic_runs);
109 
113  void add_phonetic_run(const phonetic_run &t);
114 
118  bool has_phonetic_properties() const;
119 
123  const phonetic_pr &phonetic_properties() const;
124 
128  void phonetic_properties(const phonetic_pr &phonetic_props);
129 
133  rich_text &operator=(const rich_text &rhs);
134 
138  bool operator==(const rich_text &rhs) const;
139 
143  bool operator!=(const rich_text &rhs) const;
144 
148  bool operator==(const std::string &rhs) const;
149 
153  bool operator!=(const std::string &rhs) const;
154 
155 private:
159  std::vector<rich_text_run> runs_;
160  std::vector<phonetic_run> phonetic_runs_;
161  optional<phonetic_pr> phonetic_properties_;
162 };
163 
164 class XLNT_API rich_text_hash
165 {
166 public:
167  std::size_t operator()(const rich_text &k) const
168  {
169  std::size_t res = 0;
170 
171  for (auto r : k.runs())
172  {
173  res ^= std::hash<std::string>()(r.first);
174  }
175 
176  return res;
177  }
178 };
179 
180 } // namespace xlnt
Typedef a rich_text_run as a pair of string and optional font.
Definition: rich_text_run.hpp:38
std::vector< rich_text_run > runs() const
Returns a copy of the individual runs that comprise this text.
Enumerates the possible types a cell can be determined by it&#39;s current value.
Definition: cell.hpp:37
Describes the font style of a particular cell.
Definition: font.hpp:41
bool operator==(std::nullptr_t, const cell &cell)
Returns true if this cell is uninitialized.
Encapsulates zero or more formatted text runs where a text run is a string of text with the same defi...
Definition: rich_text.hpp:41
Encapsulates a run of text that
Definition: phonetic_run.hpp:37
Many settings in xlnt are allowed to not have a value set. This class encapsulates a value which may ...
Definition: format.hpp:44
Definition: rich_text.hpp:164
bool operator!=(const std::string &reference_string, const range_reference &ref)
Returns true if the string representation of the range is not equivalent to ref.
Phonetic properties Element provides a collection of properties that affect display of East Asian Lan...
Definition: phonetic_pr.hpp:39