boring boring documentation

This commit is contained in:
Thomas Fussell 2017-03-25 11:22:21 -04:00
parent e040a1c4ab
commit 1121bcbe15
8 changed files with 338 additions and 254 deletions

View File

@ -30,7 +30,7 @@
namespace xlnt { namespace xlnt {
/// <summary> /// <summary>
/// Text can be aligned horizontally in these enumerated ways. /// Text can be aligned horizontally within a cell in these enumerated ways.
/// </summary> /// </summary>
enum class XLNT_API horizontal_alignment enum class XLNT_API horizontal_alignment
{ {
@ -45,7 +45,7 @@ enum class XLNT_API horizontal_alignment
}; };
/// <summary> /// <summary>
/// Text can be aligned vertically in these enumerated ways. /// Text can be aligned vertically within a cell in these enumerated ways.
/// </summary> /// </summary>
enum class XLNT_API vertical_alignment enum class XLNT_API vertical_alignment
{ {
@ -57,68 +57,69 @@ enum class XLNT_API vertical_alignment
}; };
/// <summary> /// <summary>
/// Alignment options for use in cell formats. /// Alignment options that determine how text should be displayed within a cell.
/// </summary> /// </summary>
class XLNT_API alignment class XLNT_API alignment
{ {
public: public:
/// <summary> /// <summary>
/// /// Returns true if shrink-to-fit has been enabled.
/// </summary> /// </summary>
bool shrink() const; bool shrink() const;
/// <summary> /// <summary>
/// /// Sets whether the font size should be reduced until all of the text fits in a cell without wrapping.
/// </summary> /// </summary>
alignment &shrink(bool shrink_to_fit); alignment &shrink(bool shrink_to_fit);
/// <summary> /// <summary>
/// /// Returns true if text-wrapping has been enabled.
/// </summary> /// </summary>
bool wrap() const; bool wrap() const;
/// <summary> /// <summary>
/// /// Sets whether text in a cell should continue to multiple lines if it doesn't fit in one line.
/// </summary> /// </summary>
alignment &wrap(bool wrap_text); alignment &wrap(bool wrap_text);
/// <summary> /// <summary>
/// /// Returns the optional value of indentation width in number of spaces.
/// </summary> /// </summary>
optional<int> indent() const; optional<int> indent() const;
/// <summary> /// <summary>
/// /// Sets the indent size in number of spaces from the side of the cell. This will only
/// take effect when left or right horizontal alignment has also been set.
/// </summary> /// </summary>
alignment &indent(int indent_size); alignment &indent(int indent_size);
/// <summary> /// <summary>
/// /// Returns the optional value of rotation for text in the cell in degrees.
/// </summary> /// </summary>
optional<int> rotation() const; optional<int> rotation() const;
/// <summary> /// <summary>
/// /// Sets the rotation for text in the cell in degrees.
/// </summary> /// </summary>
alignment &rotation(int text_rotation); alignment &rotation(int text_rotation);
/// <summary> /// <summary>
/// /// Returns the optional horizontal alignment.
/// </summary> /// </summary>
optional<horizontal_alignment> horizontal() const; optional<horizontal_alignment> horizontal() const;
/// <summary> /// <summary>
/// /// Sets the horizontal alignment.
/// </summary> /// </summary>
alignment &horizontal(horizontal_alignment horizontal); alignment &horizontal(horizontal_alignment horizontal);
/// <summary> /// <summary>
/// /// Returns the optional vertical alignment.
/// </summary> /// </summary>
optional<vertical_alignment> vertical() const; optional<vertical_alignment> vertical() const;
/// <summary> /// <summary>
/// /// Sets the vertical alignment.
/// </summary> /// </summary>
alignment &vertical(vertical_alignment vertical); alignment &vertical(vertical_alignment vertical);
@ -133,11 +134,34 @@ public:
bool operator!=(const alignment &other) const; bool operator!=(const alignment &other) const;
private: private:
bool shrink_to_fit_ = false; /// <summary>
bool wrap_text_ = false; /// Whether or not to shrink font size until it fits on one line
optional<int> indent_; /// </summary>
bool shrink_to_fit_ = false;
/// <summary>
/// Whether or not to wrap text to the next line
/// </summary>
bool wrap_text_ = false;
/// <summary>
/// The indent in number of spaces from the side
/// </summary>
optional<int> indent_;
/// <summary>
/// The text roation in degrees
/// </summary>
optional<int> text_rotation_; optional<int> text_rotation_;
/// <summary>
/// The horizontal alignment
/// </summary>
optional<horizontal_alignment> horizontal_; optional<horizontal_alignment> horizontal_;
/// <summary>
/// The vertical alignment
/// </summary>
optional<vertical_alignment> vertical_; optional<vertical_alignment> vertical_;
}; };

View File

@ -50,7 +50,7 @@ enum class XLNT_API border_side
}; };
/// <summary> /// <summary>
/// /// Enumerates the pattern of the border lines on a particular side.
/// </summary> /// </summary>
enum class XLNT_API border_style enum class XLNT_API border_style
{ {

View File

@ -32,7 +32,7 @@
namespace xlnt { namespace xlnt {
/// <summary> /// <summary>
/// /// An indexed color encapsulates a simple index to a color in the indexedColors of the stylesheet.
/// </summary> /// </summary>
class XLNT_API indexed_color class XLNT_API indexed_color
{ {
@ -60,7 +60,7 @@ private:
}; };
/// <summary> /// <summary>
/// /// A theme color encapsulates a color derived from the theme.
/// </summary> /// </summary>
class XLNT_API theme_color class XLNT_API theme_color
{ {
@ -88,64 +88,60 @@ private:
}; };
/// <summary> /// <summary>
/// /// An RGB color describes a color in terms of its red, green, blue, and alpha components.
/// </summary> /// </summary>
class XLNT_API rgb_color class XLNT_API rgb_color
{ {
public: public:
/// <summary> /// <summary>
/// /// Constructs an RGB color from a string in the form #[aa]rrggbb
/// </summary> /// </summary>
rgb_color(const std::string &hex_string); rgb_color(const std::string &hex_string);
/// <summary> /// <summary>
/// /// Constructs an RGB color from red, green, and blue values in the range 0 to 255
/// plus an optional alpha which defaults to fully opaque.
/// </summary> /// </summary>
rgb_color(std::uint8_t r, std::uint8_t g, std::uint8_t b, std::uint8_t a = 255); rgb_color(std::uint8_t r, std::uint8_t g, std::uint8_t b, std::uint8_t a = 255);
/// <summary> /// <summary>
/// /// Returns a string representation of this color in the form #aarrggbb
/// </summary> /// </summary>
std::string hex_string() const; std::string hex_string() const;
/// <summary> /// <summary>
/// /// Returns a byte representing the red component of this color
/// </summary> /// </summary>
std::uint8_t red() const; std::uint8_t red() const;
/// <summary> /// <summary>
/// /// Returns a byte representing the red component of this color
/// </summary> /// </summary>
std::uint8_t green() const; std::uint8_t green() const;
/// <summary> /// <summary>
/// /// Returns a byte representing the blue component of this color
/// </summary> /// </summary>
std::uint8_t blue() const; std::uint8_t blue() const;
/// <summary> /// <summary>
/// /// Returns a byte representing the alpha component of this color
/// </summary> /// </summary>
std::uint8_t alpha() const; std::uint8_t alpha() const;
/// <summary> /// <summary>
/// /// Returns the red, green, and blue components of this color separately in an array in that order.
/// </summary> /// </summary>
std::array<std::uint8_t, 3> rgb() const; std::array<std::uint8_t, 3> rgb() const;
/// <summary> /// <summary>
/// /// Returns the red, green, blue, and alpha components of this color separately in an array in that order.
/// </summary> /// </summary>
std::array<std::uint8_t, 4> rgba() const; std::array<std::uint8_t, 4> rgba() const;
private: private:
/// <summary> /// <summary>
/// /// The four bytes of this color
/// </summary>
static std::array<std::uint8_t, 4> decode_hex_string(const std::string &hex_string);
/// <summary>
///
/// </summary> /// </summary>
std::array<std::uint8_t, 4> rgba_; std::array<std::uint8_t, 4> rgba_;
}; };
@ -167,163 +163,163 @@ class XLNT_API color
{ {
public: public:
/// <summary> /// <summary>
/// /// Returns the color #000000
/// </summary> /// </summary>
static const color black(); static const color black();
/// <summary> /// <summary>
/// /// Returns the color #ffffff
/// </summary> /// </summary>
static const color white(); static const color white();
/// <summary> /// <summary>
/// /// Returns the color #ff0000
/// </summary> /// </summary>
static const color red(); static const color red();
/// <summary> /// <summary>
/// /// Returns the color #8b0000
/// </summary> /// </summary>
static const color darkred(); static const color darkred();
/// <summary> /// <summary>
/// /// Returns the color #00ff00
/// </summary> /// </summary>
static const color blue(); static const color blue();
/// <summary> /// <summary>
/// /// Returns the color #008b00
/// </summary> /// </summary>
static const color darkblue(); static const color darkblue();
/// <summary> /// <summary>
/// /// Returns the color #0000ff
/// </summary> /// </summary>
static const color green(); static const color green();
/// <summary> /// <summary>
/// /// Returns the color #00008b
/// </summary> /// </summary>
static const color darkgreen(); static const color darkgreen();
/// <summary> /// <summary>
/// /// Returns the color #ffff00
/// </summary> /// </summary>
static const color yellow(); static const color yellow();
/// <summary> /// <summary>
/// /// Returns the color #cccc00
/// </summary> /// </summary>
static const color darkyellow(); static const color darkyellow();
/// <summary> /// <summary>
/// /// Constructs a default color
/// </summary> /// </summary>
color(); color();
/// <summary> /// <summary>
/// /// Constructs a color from a given RGB color
/// </summary> /// </summary>
color(const rgb_color &rgb); color(const rgb_color &rgb);
/// <summary> /// <summary>
/// /// Constructs a color from a given indexed color
/// </summary> /// </summary>
color(const indexed_color &indexed); color(const indexed_color &indexed);
/// <summary> /// <summary>
/// /// Constructs a color from a given theme color
/// </summary> /// </summary>
color(const theme_color &theme); color(const theme_color &theme);
/// <summary> /// <summary>
/// /// Returns the type of this color
/// </summary> /// </summary>
color_type type() const; color_type type() const;
/// <summary> /// <summary>
/// /// Returns true if this color has been set to auto
/// </summary> /// </summary>
bool is_auto() const; bool auto_() const;
/// <summary> /// <summary>
/// /// Sets the auto property of this color to value
/// </summary> /// </summary>
void auto_(bool value); void auto_(bool value);
/// <summary> /// <summary>
/// /// Returns the internal indexed color representing this color. If this is not an RGB color,
/// an invalid_attribute exception will be thrown.
/// </summary> /// </summary>
const rgb_color &rgb() const; rgb_color rgb() const;
/// <summary> /// <summary>
/// /// Returns the internal indexed color representing this color. If this is not an indexed color,
/// an invalid_attribute exception will be thrown.
/// </summary> /// </summary>
const indexed_color &indexed() const; indexed_color indexed() const;
/// <summary> /// <summary>
/// /// Returns the internal indexed color representing this color. If this is not a theme color,
/// an invalid_attribute exception will be thrown.
/// </summary> /// </summary>
const theme_color &theme() const; theme_color theme() const;
/// <summary> /// <summary>
/// /// Returns the tint of this color.
/// </summary> /// </summary>
double tint() const; double tint() const;
/// <summary> /// <summary>
/// /// Sets the tint of this color to tint. Tints lighten or darken an existing color by multiplying the color with the tint.
/// </summary> /// </summary>
void tint(double tint); void tint(double tint);
/// <summary> /// <summary>
/// /// Returns true if this color is equivalent to other
/// </summary> /// </summary>
bool operator==(const color &other) const; bool operator==(const color &other) const;
/// <summary> /// <summary>
/// /// Returns true if this color is not equivalent to other
/// </summary> /// </summary>
bool operator!=(const color &other) const bool operator!=(const color &other) const;
{
return !(*this == other);
}
private: private:
/// <summary> /// <summary>
/// /// Throws an invalid_attribute exception if the given type is different from this color's type
/// </summary> /// </summary>
void assert_type(color_type t) const; void assert_type(color_type t) const;
/// <summary> /// <summary>
/// /// The type of this color
/// </summary> /// </summary>
color_type type_; color_type type_;
/// <summary> /// <summary>
/// /// The internal RGB color. Only valid when this color has a type of rgb
/// </summary> /// </summary>
rgb_color rgb_; rgb_color rgb_;
/// <summary> /// <summary>
/// /// The internal RGB color. Only valid when this color has a type of indexed
/// </summary> /// </summary>
indexed_color indexed_; indexed_color indexed_;
/// <summary> /// <summary>
/// /// The internal RGB color. Only valid when this color has a type of theme
/// </summary> /// </summary>
theme_color theme_; theme_color theme_;
/// <summary> /// <summary>
/// /// The tint of this color
/// </summary> /// </summary>
double tint_; double tint_ = 0.0;
/// <summary> /// <summary>
/// /// Whether or not this is an auto color
/// </summary> /// </summary>
bool auto__; bool auto__ = false;
}; };
} // namespace xlnt } // namespace xlnt

View File

@ -33,7 +33,7 @@
namespace xlnt { namespace xlnt {
/// <summary> /// <summary>
/// /// The pattern of pixels upon which the corresponding pattern fill will be displayed
/// </summary> /// </summary>
enum class XLNT_API pattern_fill_type enum class XLNT_API pattern_fill_type
{ {
@ -59,58 +59,56 @@ enum class XLNT_API pattern_fill_type
}; };
/// <summary> /// <summary>
/// /// Represents a fill which colors the cell based on a foreground and
/// background color and a pattern.
/// </summary> /// </summary>
class XLNT_API pattern_fill class XLNT_API pattern_fill
{ {
public: public:
/// <summary> /// <summary>
/// /// Constructs a default pattern fill with a none pattern and no colors.
/// </summary> /// </summary>
pattern_fill(); pattern_fill();
/// <summary> /// <summary>
/// /// Returns the pattern used by this fill
/// </summary> /// </summary>
pattern_fill_type type() const; pattern_fill_type type() const;
/// <summary> /// <summary>
/// /// Sets the pattern of this fill and returns a reference to it.
/// </summary> /// </summary>
pattern_fill &type(pattern_fill_type new_type); pattern_fill &type(pattern_fill_type new_type);
/// <summary> /// <summary>
/// /// Returns the optional foreground color of this fill
/// </summary> /// </summary>
optional<color> foreground() const; optional<color> foreground() const;
/// <summary> /// <summary>
/// /// Sets the foreground color and returns a reference to this pattern.
/// </summary> /// </summary>
pattern_fill &foreground(const color &foreground); pattern_fill &foreground(const color &foreground);
/// <summary> /// <summary>
/// /// Returns the optional background color of this fill
/// </summary> /// </summary>
optional<color> background() const; optional<color> background() const;
/// <summary> /// <summary>
/// /// Sets the foreground color and returns a reference to this pattern.
/// </summary> /// </summary>
pattern_fill &background(const color &background); pattern_fill &background(const color &background);
/// <summary> /// <summary>
/// Returns true if left is exactly equal to right. /// Returns true if this pattern fill is equivalent to other.
/// </summary> /// </summary>
XLNT_API friend bool operator==(const pattern_fill &left, const pattern_fill &right); bool operator==(const pattern_fill &other) const;
/// <summary> /// <summary>
/// Returns true if left is not exactly equal to right. /// Returns true if this pattern fill is not equivalent to other.
/// </summary> /// </summary>
XLNT_API friend bool operator!=(const pattern_fill &left, const pattern_fill &right) bool operator!=(const pattern_fill &other) const;
{
return !(left == right);
}
private: private:
/// <summary> /// <summary>
@ -139,37 +137,37 @@ enum class XLNT_API gradient_fill_type
}; };
/// <summary> /// <summary>
/// /// Encapsulates a fill which transitions between colors at particular "stops".
/// </summary> /// </summary>
class XLNT_API gradient_fill class XLNT_API gradient_fill
{ {
public: public:
/// <summary> /// <summary>
/// /// Constructs a default linear fill
/// </summary> /// </summary>
gradient_fill(); gradient_fill();
/// <summary> /// <summary>
/// /// Returns the type of this gradient fill
/// </summary> /// </summary>
gradient_fill_type type() const; gradient_fill_type type() const;
// Type // Type
/// <summary> /// <summary>
/// /// Sets the type of this gradient fill
/// </summary> /// </summary>
gradient_fill &type(gradient_fill_type new_type); gradient_fill &type(gradient_fill_type new_type);
// Degree // Degree
/// <summary> /// <summary>
/// /// Sets the angle of the gradient in degrees
/// </summary> /// </summary>
gradient_fill &degree(double degree); gradient_fill &degree(double degree);
/// <summary> /// <summary>
/// /// Returns the angle of the gradient
/// </summary> /// </summary>
double degree() const; double degree() const;
@ -241,15 +239,12 @@ public:
/// <summary> /// <summary>
/// Returns true if left is exactly equal to right. /// Returns true if left is exactly equal to right.
/// </summary> /// </summary>
XLNT_API friend bool operator==(const gradient_fill &left, const gradient_fill &right); bool operator==(const gradient_fill &other) const;
/// <summary> /// <summary>
/// Returns true if left is not exactly equal to right. /// Returns true if left is not exactly equal to right.
/// </summary> /// </summary>
XLNT_API friend bool operator!=(const gradient_fill &left, const gradient_fill &right) bool operator!=(const gradient_fill &right) const;
{
return !(left == right);
}
private: private:
/// <summary> /// <summary>
@ -347,29 +342,26 @@ public:
/// <summary> /// <summary>
/// Returns true if left is exactly equal to right. /// Returns true if left is exactly equal to right.
/// </summary> /// </summary>
XLNT_API friend bool operator==(const fill &left, const fill &right); bool operator==(const fill &other) const;
/// <summary> /// <summary>
/// Returns true if left is not exactly equal to right. /// Returns true if left is not exactly equal to right.
/// </summary> /// </summary>
XLNT_API friend bool operator!=(const fill &left, const fill &right) bool operator!=(const fill &other) const;
{
return !(left == right);
}
private: private:
/// <summary> /// <summary>
/// /// The type of this fill
/// </summary> /// </summary>
fill_type type_ = fill_type::pattern; fill_type type_ = fill_type::pattern;
/// <summary> /// <summary>
/// /// The internal gradient fill if this is a gradient fill type
/// </summary> /// </summary>
xlnt::gradient_fill gradient_; xlnt::gradient_fill gradient_;
/// <summary> /// <summary>
/// /// The internal pattern fill if this is a pattern fill type
/// </summary> /// </summary>
xlnt::pattern_fill pattern_; xlnt::pattern_fill pattern_;
}; };

View File

@ -2950,7 +2950,7 @@ void xlsx_producer::write_relationships(const std::vector<xlnt::relationship> &r
void xlsx_producer::write_color(const xlnt::color &color) void xlsx_producer::write_color(const xlnt::color &color)
{ {
if (color.is_auto()) if (color.auto_())
{ {
write_attribute("auto", write_bool(true)); write_attribute("auto", write_bool(true));
return; return;

View File

@ -28,114 +28,47 @@
#include <xlnt/styles/color.hpp> #include <xlnt/styles/color.hpp>
#include <xlnt/utils/exceptions.hpp> #include <xlnt/utils/exceptions.hpp>
namespace {
std::array<std::uint8_t, 4> decode_hex_string(const std::string &hex_string)
{
auto x = std::strtoul(hex_string.c_str(), NULL, 16);
auto a = static_cast<std::uint8_t>(x >> 24);
auto r = static_cast<std::uint8_t>((x >> 16) & 0xff);
auto g = static_cast<std::uint8_t>((x >> 8) & 0xff);
auto b = static_cast<std::uint8_t>(x & 0xff);
return { { r, g, b, a } };
}
} // namespace
namespace xlnt { namespace xlnt {
indexed_color::indexed_color(std::size_t index) // indexed_color implementation
: index_(index)
indexed_color::indexed_color(std::size_t index) : index_(index)
{ {
} }
theme_color::theme_color(std::size_t index) std::size_t indexed_color::index() const
: index_(index) {
return index_;
}
// theme_color implementation
theme_color::theme_color(std::size_t index) : index_(index)
{ {
} }
const color color::black() std::size_t theme_color::index() const
{ {
return color(rgb_color("ff000000")); return index_;
} }
const color color::white() // rgb_color implementation
{
return color(rgb_color("ffffffff"));
}
const color color::red()
{
return color(rgb_color("ffff0000"));
}
const color color::darkred()
{
return color(rgb_color("ff8b0000"));
}
const color color::blue()
{
return color(rgb_color("ff0000ff"));
}
const color color::darkblue()
{
return color(rgb_color("ff00008b"));
}
const color color::green()
{
return color(rgb_color("ff00ff00"));
}
const color color::darkgreen()
{
return color(rgb_color("ff008b00"));
}
const color color::yellow()
{
return color(rgb_color("ffffff00"));
}
const color color::darkyellow()
{
return color(rgb_color("ffcccc00"));
}
color::color()
: type_(color_type::indexed), rgb_(rgb_color(0, 0, 0, 0)), indexed_(0), theme_(0), tint_(0), auto__(false)
{
}
color::color(const rgb_color &rgb)
: type_(color_type::rgb), rgb_(rgb), indexed_(0), theme_(0), tint_(0), auto__(false)
{
}
color::color(const indexed_color &indexed)
: type_(color_type::indexed), rgb_(rgb_color(0, 0, 0, 0)), indexed_(indexed), theme_(0), tint_(0), auto__(false)
{
}
color::color(const theme_color &theme)
: type_(color_type::theme), rgb_(rgb_color(0, 0, 0, 0)), indexed_(0), theme_(theme), tint_(0), auto__(false)
{
}
color_type color::type() const
{
return type_;
}
bool color::is_auto() const
{
return auto__;
}
void color::auto_(bool value)
{
auto__ = value;
}
const indexed_color &color::indexed() const
{
assert_type(color_type::indexed);
return indexed_;
}
const theme_color &color::theme() const
{
assert_type(color_type::theme);
return theme_;
}
std::string rgb_color::hex_string() const std::string rgb_color::hex_string() const
{ {
@ -155,18 +88,6 @@ std::string rgb_color::hex_string() const
return hex_string; return hex_string;
} }
std::array<std::uint8_t, 4> rgb_color::decode_hex_string(const std::string &hex_string)
{
auto x = std::strtoul(hex_string.c_str(), NULL, 16);
auto a = static_cast<std::uint8_t>(x >> 24);
auto r = static_cast<std::uint8_t>((x >> 16) & 0xff);
auto g = static_cast<std::uint8_t>((x >> 8) & 0xff);
auto b = static_cast<std::uint8_t>(x & 0xff);
return {{r, g, b, a}};
}
rgb_color::rgb_color(const std::string &hex_string) rgb_color::rgb_color(const std::string &hex_string)
: rgba_(decode_hex_string(hex_string)) : rgba_(decode_hex_string(hex_string))
{ {
@ -177,17 +98,144 @@ rgb_color::rgb_color(std::uint8_t r, std::uint8_t g, std::uint8_t b, std::uint8_
{ {
} }
std::size_t indexed_color::index() const std::uint8_t rgb_color::red() const
{ {
return index_; return rgba_[0];
} }
std::size_t theme_color::index() const std::uint8_t rgb_color::green() const
{ {
return index_; return rgba_[1];
} }
const rgb_color &color::rgb() const std::uint8_t rgb_color::blue() const
{
return rgba_[2];
}
std::uint8_t rgb_color::alpha() const
{
return rgba_[3];
}
std::array<std::uint8_t, 3> rgb_color::rgb() const
{
return { red(), green(), blue() };
}
std::array<std::uint8_t, 4> rgb_color::rgba() const
{
return rgba_;
}
// color implementation
const color color::black()
{
return color(rgb_color("ff000000"));
}
const color color::white()
{
return color(rgb_color("ffffffff"));
}
const color color::red()
{
return color(rgb_color("ffff0000"));
}
const color color::darkred()
{
return color(rgb_color("ff8b0000"));
}
const color color::blue()
{
return color(rgb_color("ff0000ff"));
}
const color color::darkblue()
{
return color(rgb_color("ff00008b"));
}
const color color::green()
{
return color(rgb_color("ff00ff00"));
}
const color color::darkgreen()
{
return color(rgb_color("ff008b00"));
}
const color color::yellow()
{
return color(rgb_color("ffffff00"));
}
const color color::darkyellow()
{
return color(rgb_color("ffcccc00"));
}
color::color() : color(indexed_color(0))
{
}
color::color(const rgb_color &rgb)
: type_(color_type::rgb),
rgb_(rgb),
indexed_(0),
theme_(0)
{
}
color::color(const indexed_color &indexed)
: type_(color_type::indexed),
rgb_(rgb_color(0, 0, 0, 0)),
indexed_(indexed),
theme_(0)
{
}
color::color(const theme_color &theme)
: type_(color_type::theme),
rgb_(rgb_color(0, 0, 0, 0)),
indexed_(0),
theme_(theme)
{
}
color_type color::type() const
{
return type_;
}
bool color::auto_() const
{
return auto__;
}
void color::auto_(bool value)
{
auto__ = value;
}
indexed_color color::indexed() const
{
assert_type(color_type::indexed);
return indexed_;
}
theme_color color::theme() const
{
assert_type(color_type::theme);
return theme_;
}
rgb_color color::rgb() const
{ {
assert_type(color_type::rgb); assert_type(color_type::rgb);
return rgb_; return rgb_;
@ -198,6 +246,11 @@ void color::tint(double tint)
tint_ = tint; tint_ = tint;
} }
double color::tint() const
{
return tint_;
}
void color::assert_type(color_type t) const void color::assert_type(color_type t) const
{ {
if (t != type_) if (t != type_)
@ -206,7 +259,7 @@ void color::assert_type(color_type t) const
} }
} }
XLNT_API bool color::operator==(const xlnt::color &other) const bool color::operator==(const xlnt::color &other) const
{ {
if (type_ != other.type_ || std::fabs(tint_ - other.tint_) != 0.0 || auto__ != other.auto__) if (type_ != other.type_ || std::fabs(tint_ - other.tint_) != 0.0 || auto__ != other.auto__)
{ {
@ -226,4 +279,9 @@ XLNT_API bool color::operator==(const xlnt::color &other) const
return false; return false;
} }
bool color::operator!=(const color &other) const
{
return !(*this == other);
}
} // namespace xlnt } // namespace xlnt

View File

@ -73,35 +73,35 @@ pattern_fill &pattern_fill::background(const color &new_background)
return *this; return *this;
} }
XLNT_API bool operator==(const pattern_fill &left, const pattern_fill &right) bool pattern_fill::operator==(const pattern_fill &other) const
{ {
if (left.background().is_set() != right.background().is_set()) if (background().is_set() != other.background().is_set())
{ {
return false; return false;
} }
if (left.background().is_set()) if (background().is_set())
{ {
if (left.background().get() != right.background().get()) if (background().get() != other.background().get())
{ {
return false; return false;
} }
} }
if (left.foreground().is_set() != right.foreground().is_set()) if (foreground().is_set() != other.foreground().is_set())
{ {
return false; return false;
} }
if (left.foreground().is_set()) if (foreground().is_set())
{ {
if (left.foreground().get() != right.foreground().get()) if (foreground().get() != other.foreground().get())
{ {
return false; return false;
} }
} }
if (left.type() != right.type()) if (type() != other.type())
{ {
return false; return false;
} }
@ -109,10 +109,14 @@ XLNT_API bool operator==(const pattern_fill &left, const pattern_fill &right)
return true; return true;
} }
bool pattern_fill::operator!=(const pattern_fill &other) const
{
return !(*this == other);
}
// gradient_fill // gradient_fill
gradient_fill::gradient_fill() gradient_fill::gradient_fill() : type_(gradient_fill_type::linear)
: type_(gradient_fill_type::linear)
{ {
} }
@ -199,39 +203,39 @@ std::unordered_map<double, color> gradient_fill::stops() const
return stops_; return stops_;
} }
XLNT_API bool operator==(const gradient_fill &left, const gradient_fill &right) bool gradient_fill::operator==(const gradient_fill &other) const
{ {
if (left.type() != right.type()) if (type() != other.type())
{ {
return false; return false;
} }
if (std::fabs(left.degree() - right.degree()) != 0.) if (std::fabs(degree() - other.degree()) != 0.)
{ {
return false; return false;
} }
if (std::fabs(left.bottom() - right.bottom()) != 0.) if (std::fabs(bottom() - other.bottom()) != 0.)
{ {
return false; return false;
} }
if (std::fabs(left.right() - right.right()) != 0.) if (std::fabs(right() - other.right()) != 0.)
{ {
return false; return false;
} }
if (std::fabs(left.top() - right.top()) != 0.) if (std::fabs(top() - other.top()) != 0.)
{ {
return false; return false;
} }
if (std::fabs(left.left() - right.left()) != 0.) if (std::fabs(left() - other.left()) != 0.)
{ {
return false; return false;
} }
if (left.stops() != right.stops()) if (stops() != other.stops())
{ {
return false; return false;
} }
@ -239,6 +243,11 @@ XLNT_API bool operator==(const gradient_fill &left, const gradient_fill &right)
return true; return true;
} }
bool gradient_fill::operator!=(const gradient_fill &other) const
{
return !(*this == other);
}
// fill // fill
fill fill::solid(const color &fill_color) fill fill::solid(const color &fill_color)
@ -287,19 +296,24 @@ pattern_fill fill::pattern_fill() const
return pattern_; return pattern_;
} }
XLNT_API bool operator==(const fill &left, const fill &right) bool fill::operator==(const fill &other) const
{ {
if (left.type() != right.type()) if (type() != other.type())
{ {
return false; return false;
} }
if (left.type() == fill_type::gradient) if (type() == fill_type::gradient)
{ {
return left.gradient_fill() == right.gradient_fill(); return gradient_fill() == other.gradient_fill();
} }
return left.pattern_fill() == right.pattern_fill(); return pattern_fill() == other.pattern_fill();
}
bool fill::operator!=(const fill &other) const
{
return !(*this == other);
} }
} // namespace xlnt } // namespace xlnt

View File

@ -33,13 +33,13 @@ public:
void test_non_rgb_colors() void test_non_rgb_colors()
{ {
xlnt::color indexed = xlnt::indexed_color(1); xlnt::color indexed = xlnt::indexed_color(1);
TS_ASSERT(!indexed.is_auto()); TS_ASSERT(!indexed.auto_());
TS_ASSERT_EQUALS(indexed.indexed().index(), 1); TS_ASSERT_EQUALS(indexed.indexed().index(), 1);
TS_ASSERT_THROWS(indexed.theme(), xlnt::invalid_attribute); TS_ASSERT_THROWS(indexed.theme(), xlnt::invalid_attribute);
TS_ASSERT_THROWS(indexed.rgb(), xlnt::invalid_attribute); TS_ASSERT_THROWS(indexed.rgb(), xlnt::invalid_attribute);
xlnt::color theme = xlnt::theme_color(3); xlnt::color theme = xlnt::theme_color(3);
TS_ASSERT(!theme.is_auto()); TS_ASSERT(!theme.auto_());
TS_ASSERT_EQUALS(theme.theme().index(), 3); TS_ASSERT_EQUALS(theme.theme().index(), 3);
TS_ASSERT_THROWS(theme.indexed(), xlnt::invalid_attribute); TS_ASSERT_THROWS(theme.indexed(), xlnt::invalid_attribute);
TS_ASSERT_THROWS(theme.rgb(), xlnt::invalid_attribute); TS_ASSERT_THROWS(theme.rgb(), xlnt::invalid_attribute);