restore worksheet::cell(column_t, row_t) method (#137) and move some single use classes/structs/enums into parent header

This commit is contained in:
Thomas Fussell 2017-03-22 21:44:59 -04:00
parent 0541b74c1f
commit c7f61e38c1
30 changed files with 793 additions and 187 deletions

View File

@ -92,12 +92,12 @@ public:
path canonicalize(const std::vector<xlnt::relationship> &rels) const;
/// <summary>
///
/// Registers a new relationship by specifying all of the relationship properties explicitly.
/// </summary>
std::string register_relationship(const uri &source, relationship_type type, const uri &target, target_mode mode);
/// <summary>
///
/// Registers a new relationship already constructed elsewhere.
/// </summary>
std::string register_relationship(const class relationship &rel);
@ -174,22 +174,22 @@ public:
private:
/// <summary>
///
/// Returns the lowest rId for the given part that hasn't already been registered.
/// </summary>
std::string next_relationship_id(const path &part) const;
/// <summary>
///
/// The map of extensions to default content types.
/// </summary>
std::unordered_map<std::string, std::string> default_content_types_;
/// <summary>
///
/// The map of package parts to overriding content types.
/// </summary>
std::unordered_map<path, std::string> override_content_types_;
/// <summary>
///
/// The map of package parts to their registered relationships.
/// </summary>
std::unordered_map<path, std::unordered_map<std::string, xlnt::relationship>> relationships_;
};

View File

@ -102,15 +102,15 @@ class XLNT_API relationship
{
public:
/// <summary>
///
/// Constructs a new empty relationship.
/// </summary>
relationship();
/// <summary>
///
/// Constructs a new relationship by specifying all of its properties.
/// </summary>
relationship(
const std::string &id, relationship_type t, const uri &source, const uri &target, xlnt::target_mode mode);
relationship(const std::string &id, relationship_type t, const uri &source,
const uri &target, xlnt::target_mode mode);
/// <summary>
/// Returns a string of the form rId# that identifies the relationship.
@ -149,27 +149,27 @@ public:
private:
/// <summary>
///
/// The id of this relationship in the format "rId#"
/// </summary>
std::string id_;
/// <summary>
///
/// The type of this relationship.
/// </summary>
relationship_type type_;
/// <summary>
///
/// The URI of the source of this relationship.
/// </summary>
uri source_;
/// <summary>
///
/// The URI of the target of this relationshp.
/// </summary>
uri target_;
/// <summary>
///
/// Whether the target of this relationship is internal or external.
/// </summary>
xlnt::target_mode mode_;
};

View File

@ -31,194 +31,207 @@
namespace xlnt {
/// <summary>
///
/// Encapsulates a uniform resource identifier (URI) as described
/// by RFC 3986.
/// </summary>
class XLNT_API uri
{
public:
/// <summary>
///
/// Constructs an empty URI.
/// </summary>
uri();
/// <summary>
///
/// Constructs a URI by combining base with relative.
/// </summary>
uri(const uri &base, const uri &relative);
/// <summary>
///
/// Constructs a URI by combining base with relative path.
/// </summary>
uri(const uri &base, const path &relative);
/// <summary>
///
/// Constructs a URI by parsing the given uri_string.
/// </summary>
uri(const std::string &uri_string);
/// <summary>
///
/// Returns true if this URI is relative.
/// </summary>
bool is_relative() const;
/// <summary>
///
/// Returns true if this URI is not relative (i.e. absolute).
/// </summary>
bool is_absolute() const;
/// <summary>
///
/// Returns the scheme of this URI.
/// E.g. the scheme of http://user:pass@example.com is "http"
/// </summary>
std::string scheme() const;
/// <summary>
///
/// Returns the authority of this URI.
/// E.g. the authority of http://user:pass@example.com:80/document is "user:pass@example.com:80"
/// </summary>
std::string authority() const;
/// <summary>
///
/// Returns true if an authentication section is specified for this URI.
/// </summary>
bool has_authentication() const;
/// <summary>
///
/// Returns the authentication of this URI.
/// E.g. the authentication of http://user:pass@example.com is "user:pass"
/// </summary>
std::string authentication() const;
/// <summary>
///
/// Returns the username of this URI.
/// E.g. the username of http://user:pass@example.com is "user"
/// </summary>
std::string username() const;
/// <summary>
///
/// Returns the password of this URI.
/// E.g. the password of http://user:pass@example.com is "pass"
/// </summary>
std::string password() const;
/// <summary>
///
/// Returns the host of this URI.
/// E.g. the host of http://example.com:80/document is "example.com"
/// </summary>
std::string host() const;
/// <summary>
///
/// Returns true if a non-default port is specified for this URI.
/// </summary>
bool has_port() const;
/// <summary>
///
/// Returns the port of this URI.
/// E.g. the port of https://example.com:443/document is "443"
/// </summary>
std::size_t port() const;
/// <summary>
///
/// Returns the path of this URI.
/// E.g. the path of http://example.com/document is "/document"
/// </summary>
class path path() const;
/// <summary>
///
/// Returns true if this URI has a non-null query string section.
/// </summary>
bool has_query() const;
/// <summary>
///
/// Returns the query string of this URI.
/// E.g. the query of http://example.com/document?v=1&x=3#abc is "v=1&x=3"
/// </summary>
std::string query() const;
/// <summary>
///
/// Returns true if this URI has a non-empty fragment section.
/// </summary>
bool has_fragment() const;
/// <summary>
///
/// Returns the fragment section of this URI.
/// E.g. the fragment of http://example.com/document#abc is "abc"
/// </summary>
std::string fragment() const;
/// <summary>
///
/// Returns a string representation of this URI.
/// </summary>
std::string to_string() const;
/// <summary>
///
/// If this URI is relative, an absolute URI will be returned by appending
/// the path to the given absolute base URI.
/// </summary>
uri make_absolute(const uri &base);
/// <summary>
///
/// If this URI is absolute, a relative URI will be returned by removing the
/// common base path from the given absolute base URI.
/// </summary>
uri make_reference(const uri &base);
/// <summary>
///
/// Returns true if this URI is equivalent to other.
/// </summary>
friend XLNT_API bool operator==(const uri &left, const uri &right);
bool operator==(const uri &other) const;
private:
/// <summary>
///
/// True if this URI is absolute.
/// </summary>
bool absolute_ = false;
/// <summary>
///
/// The scheme, like "http"
/// </summary>
std::string scheme_;
/// <summary>
///
/// True if this URI has an authentication section.
/// </summary>
bool has_authentication_ = false;
/// <summary>
///
/// The username
/// </summary>
std::string username_;
/// <summary>
///
/// The password
/// </summary>
std::string password_;
/// <summary>
///
/// The host
/// </summary>
std::string host_;
/// <summary>
///
/// True if this URI has a non-default port specified
/// </summary>
bool has_port_ = false;
/// <summary>
///
/// The numeric port
/// </summary>
std::size_t port_ = 0;
/// <summary>
///
/// True if this URI has a query section
/// </summary>
bool has_query_ = false;
/// <summary>
///
/// The query section
/// </summary>
std::string query_;
/// <summary>
///
/// True if this URI has a fragment section
/// </summary>
bool has_fragment_ = false;
/// <summary>
///
/// The fragment section
/// </summary>
std::string fragment_;
/// <summary>
///
/// The path section
/// </summary>
class path path_;
};

View File

@ -25,12 +25,37 @@
#pragma once
#include <xlnt/xlnt_config.hpp>
#include <xlnt/styles/horizontal_alignment.hpp>
#include <xlnt/styles/vertical_alignment.hpp>
#include <xlnt/utils/optional.hpp>
namespace xlnt {
/// <summary>
/// Text can be aligned horizontally in these enumerated ways.
/// </summary>
enum class XLNT_API horizontal_alignment
{
general,
left,
center,
right,
fill,
justify,
center_continuous,
distributed
};
/// <summary>
/// Text can be aligned vertically in these enumerated ways.
/// </summary>
enum class XLNT_API vertical_alignment
{
top,
center,
bottom,
justify,
distributed
};
/// <summary>
/// Alignment options for use in cell formats.
/// </summary>
@ -98,17 +123,14 @@ public:
alignment &vertical(vertical_alignment vertical);
/// <summary>
/// Returns true if left is exactly equal to right.
/// Returns true if this alignment is equivalent to other.
/// </summary>
XLNT_API friend bool operator==(const alignment &left, const alignment &right);
bool operator==(const alignment &other) const;
/// <summary>
/// Returns true if left is not exactly equal to right.
/// Returns true if this alignment is not equivalent to other.
/// </summary>
XLNT_API friend bool operator!=(const alignment &left, const alignment &right)
{
return !(left == right);
}
bool operator!=(const alignment &other) const;
private:
bool shrink_to_fit_ = false;

View File

@ -30,15 +30,13 @@
#include <vector>
#include <xlnt/xlnt_config.hpp>
#include <xlnt/styles/border_style.hpp>
#include <xlnt/styles/color.hpp>
#include <xlnt/styles/diagonal_direction.hpp>
#include <xlnt/utils/optional.hpp>
namespace xlnt {
/// <summary>
///
/// Enumerates the sides of a cell to which a border style can be applied.
/// </summary>
enum class XLNT_API border_side
{
@ -51,6 +49,40 @@ enum class XLNT_API border_side
horizontal
};
/// <summary>
///
/// </summary>
enum class XLNT_API border_style
{
none,
dashdot,
dashdotdot,
dashed,
dotted,
double_,
hair,
medium,
mediumdashdot,
mediumdashdotdot,
mediumdashed,
slantdashdot,
thick,
thin
};
/// <summary>
/// Cells can have borders that go from the top-left to bottom-right
/// or from the top-right to bottom-left, or both, or neither.
/// Used by style->border.
/// </summary>
enum class XLNT_API diagonal_direction
{
neither,
up,
down,
both
};
} // namespace xlnt
namespace xlnt {
@ -62,139 +94,132 @@ class XLNT_API border
{
public:
/// <summary>
///
/// Each side of a cell can have a border_property applied to it to change
/// how it is displayed.
/// </summary>
class XLNT_API border_property
{
public:
/// <summary>
///
/// Returns the color of the side.
/// </summary>
optional<class color> color() const;
/// <summary>
///
/// Sets the color of the side and returns a reference to the side properties.
/// </summary>
border_property &color(const xlnt::color &c);
/// <summary>
///
/// Returns the style of the side.
/// </summary>
optional<border_style> style() const;
/// <summary>
///
/// Sets the style of the side and returns a reference to the side properties.
/// </summary>
border_property &style(border_style style);
/// <summary>
/// Returns true if left is exactly equal to right.
/// </summary>
friend bool operator==(const border_property &left, const border_property &right);
bool operator==(const border_property &right) const;
/// <summary>
/// Returns true if left is not exactly equal to right.
/// </summary>
friend bool operator!=(const border_property &left, const border_property &right)
{
return !(left == right);
}
bool operator!=(const border_property &right) const;
private:
/// <summary>
///
/// The color of the side
/// </summary>
optional<class color> color_;
/// <summary>
///
/// The style of the side
/// </summary>
optional<border_style> style_;
};
/// <summary>
///
/// A vector to the all of the border sides for iteration.
/// </summary>
static const std::vector<border_side> &all_sides();
/// <summary>
///
/// Constructs a default border.
/// </summary>
border();
/// <summary>
///
/// Returns the border properties of the given side.
/// </summary>
optional<border_property> side(border_side s) const;
/// <summary>
///
/// Sets the border properties of the side s to prop.
/// </summary>
border &side(border_side s, const border_property &prop);
/// <summary>
///
/// Returns the diagonal direction of this border.
/// </summary>
optional<diagonal_direction> diagonal() const;
/// <summary>
///
/// Sets the diagonal direction of this border to dir.
/// </summary>
border &diagonal(diagonal_direction dir);
/// <summary>
/// Returns true if left is exactly equal to right.
/// </summary>
XLNT_API friend bool operator==(const border &left, const border &right);
bool operator==(const border &right) const;
/// <summary>
/// Returns true if left is not exactly equal to right.
/// </summary>
XLNT_API friend bool operator!=(const border &left, const border &right)
{
return !(left == right);
}
bool operator!=(const border &right) const;
private:
/// <summary>
///
/// Start side (i.e. left) border properties
/// </summary>
optional<border_property> start_;
/// <summary>
///
/// End side (i.e. right) border properties
/// </summary>
optional<border_property> end_;
/// <summary>
///
/// Top side border properties
/// </summary>
optional<border_property> top_;
/// <summary>
///
/// Bottom side border properties
/// </summary>
optional<border_property> bottom_;
/// <summary>
///
/// Vertical border properties
/// </summary>
optional<border_property> vertical_;
/// <summary>
///
/// Horizontal border properties
/// </summary>
optional<border_property> horizontal_;
/// <summary>
///
/// Diagonal border properties
/// </summary>
optional<border_property> diagonal_;
// bool outline_ = true;
/// <summary>
///
/// Direction of diagonal border properties to be applied
/// </summary>
optional<diagonal_direction> diagonal_direction_;
};

View File

@ -28,18 +28,20 @@
namespace xlnt {
/// <summary>
///
/// Workbook file properties relating to calculations.
/// </summary>
class XLNT_API calculation_properties
{
public:
/// <summary>
/// Uniquely identifies these calculation properties.
/// The version of calculation engine used to calculate cell formula values.
/// If this is older than the version of the Excel calculation engine opening
/// the workbook, cell values will be recalculated.
/// </summary>
std::size_t calc_id;
/// <summary>
/// If this is true, concurrent calculation is enabled.
/// If this is true, concurrent calculation will be enabled for the workbook.
/// </summary>
bool concurrent_calc;
};

View File

@ -31,40 +31,68 @@
namespace xlnt {
/// <summary>
/// Security information about the OOXML document.
/// Properties governing how the data in a workbook should be protected.
/// These values can be ignored by consumers.
/// </summary>
class XLNT_API document_security
{
public:
/// <summary>
/// Holds data describing the verifier that locks revisions or a workbook.
/// </summary>
struct lock_verifier
{
/// <summary>
///
/// </summary>
std::string hash_algorithm;
/// <summary>
///
/// </summary>
std::string salt;
/// <summary>
///
/// </summary>
std::string hash;
/// <summary>
///
/// </summary>
std::size_t spin_count;
};
/// <summary>
/// Constructs a new document security object with default values.
/// </summary>
document_security();
/// <summary>
///
/// If true, the workbook is locked for revisions.
/// </summary>
bool lock_revision;
bool lock_revision = false;
/// <summary>
///
/// If true, worksheets can't be moved, renamed, (un)hidden, inserted, or deleted.
/// </summary>
bool lock_structure;
bool lock_structure = false;
/// <summary>
///
/// If true, workbook windows will be opened at the same position with the same size
/// every time they are loaded.
/// </summary>
bool lock_windows;
bool lock_windows = false;
/// <summary>
///
/// The settings to allow the revision lock to be removed.
/// </summary>
std::string revision_password;
lock_verifier revision_lock;
/// <summary>
///
/// The settings to allow the structure and windows lock to be removed.
/// </summary>
std::string workbook_password;
lock_verifier workbook_lock;
};
} // namespace xlnt

View File

@ -42,48 +42,48 @@ class XLNT_API named_range
{
public:
/// <summary>
///
/// Type alias for the combination of sheet and range this named_range points to.
/// </summary>
using target = std::pair<worksheet, range_reference>;
/// <summary>
///
/// Constructs a named range that has no name and has no targets.
/// </summary>
named_range();
/// <summary>
///
/// Constructs a named range by copying its name and targets from other.
/// </summary>
named_range(const named_range &other);
/// <summary>
///
/// Constructs a named range with the given name and targets.
/// </summary>
named_range(const std::string &name, const std::vector<target> &targets);
/// <summary>
///
/// Returns the name of this range.
/// </summary>
std::string name() const;
/// <summary>
///
/// Returns the set of targets of this named range as a vector.
/// </summary>
const std::vector<target> &targets() const;
/// <summary>
///
/// Assigns the name and targets of this named_range to that of other.
/// </summary>
named_range &operator=(const named_range &other);
private:
/// <summary>
///
/// The name of this named range.
/// </summary>
std::string name_;
/// <summary>
///
/// The targets of this named range.
/// </summary>
std::vector<target> targets_;
};

View File

@ -37,67 +37,67 @@ class XLNT_API workbook_view
{
public:
/// <summary>
///
/// If true, dates will be grouped when presenting the user with filtering options.
/// </summary>
bool auto_filter_date_grouping = false;
bool auto_filter_date_grouping = true;
/// <summary>
///
/// If true, the view will be minimized.
/// </summary>
bool minimized = false;
/// <summary>
///
/// If true, the horizontal scroll bar will be displayed.
/// </summary>
bool show_horizontal_scroll = false;
bool show_horizontal_scroll = true;
/// <summary>
///
/// If true, the sheet tabs will be displayed.
/// </summary>
bool show_sheet_tabs = false;
bool show_sheet_tabs = true;
/// <summary>
///
/// If true, the vertical scroll bar will be displayed.
/// </summary>
bool show_vertical_scroll = false;
bool show_vertical_scroll = true;
/// <summary>
///
/// If true, the workbook window will be visible.
/// </summary>
bool visible = true;
/// <summary>
///
/// The optional index to the active sheet in this view.
/// </summary>
optional<std::size_t> active_tab;
/// <summary>
///
/// The optional index to the first sheet in this view.
/// </summary>
optional<std::size_t> first_sheet;
/// <summary>
///
/// The optional ratio between the tabs bar and the horizontal scroll bar.
/// </summary>
optional<std::size_t> tab_ratio;
/// <summary>
///
/// The width of the workbook window in twips.
/// </summary>
optional<std::size_t> window_width;
/// <summary>
///
/// The height of the workbook window in twips.
/// </summary>
optional<std::size_t> window_height;
/// <summary>
///
/// The distance of the workbook window from the left side of the screen in twips.
/// </summary>
optional<std::size_t> x_window;
/// <summary>
///
/// The distance of the workbook window from the top of the screen in twips.
/// </summary>
optional<std::size_t> y_window;
};

View File

@ -33,6 +33,10 @@ namespace xlnt {
class workbook;
class worksheet;
// Note: There are const and non-const implementations of this iterator
// because one needs to point at a const workbook and the other needs
// to point at a non-const workbook stored as a member variable, respectively.
/// <summary>
/// Alias the parent class of this iterator to increase clarity.
/// </summary>
@ -40,62 +44,132 @@ using ws_iter_type = std::iterator<std::bidirectional_iterator_tag,
worksheet, std::ptrdiff_t, worksheet *, worksheet>;
/// <summary>
///
/// An iterator which is used to iterate over the worksheets in a workbook.
/// </summary>
class XLNT_API worksheet_iterator : public ws_iter_type
{
public:
/// <summary>
///
/// Constructs a worksheet iterator from a workbook and sheet index.
/// </summary>
worksheet_iterator(workbook &wb, std::size_t index);
/// <summary>
///
/// Copy constructs a worksheet iterator from another iterator.
/// </summary>
worksheet_iterator(const worksheet_iterator &);
/// <summary>
///
/// Assigns the iterator so that it points to the same worksheet in the same workbook.
/// </summary>
worksheet_iterator &operator=(const worksheet_iterator &);
/// <summary>
///
/// Dereferences the iterator to return the worksheet it is pointing to.
/// If the iterator points to one-past-the-end of the workbook, an invalid_parameter
/// exception will be thrown.
/// </summary>
worksheet operator*();
/// <summary>
///
/// Returns true if this iterator points to the same worksheet as comparand.
/// </summary>
bool operator==(const worksheet_iterator &comparand) const;
/// <summary>
///
/// Returns true if this iterator doesn't point to the same worksheet as comparand.
/// </summary>
bool operator!=(const worksheet_iterator &comparand) const
{
return !(*this == comparand);
}
bool operator!=(const worksheet_iterator &comparand) const;
/// <summary>
///
/// Post-increment the iterator's internal workseet index. Returns a copy of the
/// iterator as it was before being incremented.
/// </summary>
worksheet_iterator operator++(int);
/// <summary>
///
/// Pre-increment the iterator's internal workseet index. Returns a refernce
/// to the same iterator.
/// </summary>
worksheet_iterator &operator++();
private:
/// <summary>
///
/// The target workbook of this iterator.
/// </summary>
workbook &wb_;
/// <summary>
///
/// The index of the worksheet in wb_ this iterator is currently pointing to.
/// </summary>
std::size_t index_;
};
/// <summary>
/// Alias the parent class of this iterator to increase clarity.
/// </summary>
using c_ws_iter_type = std::iterator<std::bidirectional_iterator_tag,
const worksheet, std::ptrdiff_t, const worksheet *, const worksheet>;
/// <summary>
/// An iterator which is used to iterate over the worksheets in a const workbook.
/// </summary>
class XLNT_API const_worksheet_iterator : public c_ws_iter_type
{
public:
/// <summary>
/// Constructs a worksheet iterator from a workbook and sheet index.
/// </summary>
const_worksheet_iterator(const workbook &wb, std::size_t index);
/// <summary>
/// Copy constructs a worksheet iterator from another iterator.
/// </summary>
const_worksheet_iterator(const const_worksheet_iterator &);
/// <summary>
/// Assigns the iterator so that it points to the same worksheet in the same workbook.
/// </summary>
const_worksheet_iterator &operator=(const const_worksheet_iterator &);
/// <summary>
/// Dereferences the iterator to return the worksheet it is pointing to.
/// If the iterator points to one-past-the-end of the workbook, an invalid_parameter
/// exception will be thrown.
/// </summary>
const worksheet operator*();
/// <summary>
/// Returns true if this iterator points to the same worksheet as comparand.
/// </summary>
bool operator==(const const_worksheet_iterator &comparand) const;
/// <summary>
/// Returns true if this iterator doesn't point to the same worksheet as comparand.
/// </summary>
bool operator!=(const const_worksheet_iterator &comparand) const;
/// <summary>
/// Post-increment the iterator's internal workseet index. Returns a copy of the
/// iterator as it was before being incremented.
/// </summary>
const_worksheet_iterator operator++(int);
/// <summary>
/// Pre-increment the iterator's internal workseet index. Returns a refernce
/// to the same iterator.
/// </summary>
const_worksheet_iterator &operator++();
private:
/// <summary>
/// The target workbook of this iterator.
/// </summary>
const workbook &wb_;
/// <summary>
/// The index of the worksheet in wb_ this iterator is currently pointing to.
/// </summary>
std::size_t index_;
};

View File

@ -129,4 +129,93 @@ private:
major_order order_;
};
/// <summary>
/// Alias the parent class of this iterator to increase clarity.
/// </summary>
using cc_iter_type = std::iterator<std::bidirectional_iterator_tag,
const cell, std::ptrdiff_t, const cell *, const cell>;
/// <summary>
///
/// </summary>
class XLNT_API const_cell_iterator : public cc_iter_type
{
public:
/// <summary>
///
/// </summary>
const_cell_iterator(worksheet ws, const cell_reference &start_cell);
/// <summary>
///
/// </summary>
const_cell_iterator(worksheet ws, const cell_reference &start_cell, major_order order);
/// <summary>
///
/// </summary>
const_cell_iterator(const const_cell_iterator &other);
/// <summary>
///
/// </summary>
const_cell_iterator &operator=(const const_cell_iterator &) = default;
/// <summary>
///
/// </summary>
const cell operator*() const;
/// <summary>
///
/// </summary>
bool operator==(const const_cell_iterator &other) const;
/// <summary>
///
/// </summary>
bool operator!=(const const_cell_iterator &other) const;
/// <summary>
///
/// </summary>
const_cell_iterator &operator--();
/// <summary>
///
/// </summary>
const_cell_iterator operator--(int);
/// <summary>
///
/// </summary>
const_cell_iterator &operator++();
/// <summary>
///
/// </summary>
const_cell_iterator operator++(int);
private:
/// <summary>
///
/// </summary>
worksheet ws_;
/// <summary>
///
/// </summary>
cell_reference current_cell_;
/// <summary>
///
/// </summary>
range_reference range_;
/// <summary>
///
/// </summary>
major_order order_;
};
} // namespace xlnt

View File

@ -28,7 +28,6 @@
#include <xlnt/xlnt_config.hpp>
#include <xlnt/cell/cell_reference.hpp>
#include <xlnt/worksheet/cell_iterator.hpp>
#include <xlnt/worksheet/const_cell_iterator.hpp>
#include <xlnt/worksheet/major_order.hpp>
#include <xlnt/worksheet/range_reference.hpp>
#include <xlnt/worksheet/worksheet.hpp>

View File

@ -25,13 +25,57 @@
#pragma once
#include <xlnt/xlnt_config.hpp>
#include <xlnt/worksheet/orientation.hpp>
#include <xlnt/worksheet/page_break.hpp>
#include <xlnt/worksheet/paper_size.hpp>
#include <xlnt/worksheet/sheet_state.hpp>
namespace xlnt {
/// <summary>
/// The orientation of the worksheet when it is printed.
/// </summary>
enum class XLNT_API orientation
{
portrait,
landscape
};
/// <summary>
/// The types of page breaks.
/// </summary>
enum class XLNT_API page_break
{
none = 0,
row = 1,
column = 2
};
/// <summary>
/// The possible paper sizes for printing.
/// </summary>
enum class XLNT_API paper_size
{
letter = 1,
letter_small = 2,
tabloid = 3,
ledger = 4,
legal = 5,
statement = 6,
executive = 7,
a3 = 8,
a4 = 9,
a4_small = 10,
a5 = 11
};
/// <summary>
/// Defines how a worksheet appears in the workbook.
/// A workbook must have at least one sheet which is visible at all times.
/// </summary>
enum class XLNT_API sheet_state
{
visible,
hidden,
very_hidden
};
/// <summary>
/// Describes how a worksheet will be converted into a page during printing.
/// </summary>

View File

@ -31,7 +31,6 @@
#include <xlnt/xlnt_config.hpp>
#include <xlnt/worksheet/cell_vector.hpp>
#include <xlnt/worksheet/const_range_iterator.hpp>
#include <xlnt/worksheet/major_order.hpp>
#include <xlnt/worksheet/range_iterator.hpp>
#include <xlnt/worksheet/range_reference.hpp>

View File

@ -121,4 +121,89 @@ private:
major_order order_;
};
/// <summary>
/// Alias the parent class of this iterator to increase clarity.
/// </summary>
using cr_iter_type = std::iterator<std::bidirectional_iterator_tag,
const cell_vector, std::ptrdiff_t, const cell_vector *, const cell_vector>;
/// <summary>
/// A const version of range_iterator which does not allow modification
/// to the dereferenced cell_vector.
/// </summary>
class XLNT_API const_range_iterator : public cr_iter_type
{
public:
/// <summary>
///
/// </summary>
const_range_iterator(const worksheet &ws, const range_reference &start_cell, major_order order = major_order::row);
/// <summary>
///
/// </summary>
const_range_iterator(const const_range_iterator &other);
/// <summary>
///
/// </summary>
const cell_vector operator*() const;
/// <summary>
///
/// </summary>
const_range_iterator &operator=(const const_range_iterator &) = default;
/// <summary>
///
/// </summary>
bool operator==(const const_range_iterator &other) const;
/// <summary>
///
/// </summary>
bool operator!=(const const_range_iterator &other) const;
/// <summary>
///
/// </summary>
const_range_iterator &operator--();
/// <summary>
///
/// </summary>
const_range_iterator operator--(int);
/// <summary>
///
/// </summary>
const_range_iterator &operator++();
/// <summary>
///
/// </summary>
const_range_iterator operator++(int);
private:
/// <summary>
///
/// </summary>
detail::worksheet_impl *ws_;
/// <summary>
///
/// </summary>
cell_reference current_cell_;
/// <summary>
///
/// </summary>
range_reference range_;
/// <summary>
///
/// </summary>
major_order order_;
};
} // namespace xlnt

View File

@ -188,6 +188,18 @@ public:
/// </summary>
const class cell cell(const cell_reference &reference) const;
/// <summary>
/// Returns the cell at the given column and row. If the cell doesn't exist, it
/// will be initialized to null before being returned.
/// </summary>
class cell cell(column_t column, row_t row);
/// <summary>
/// Returns the cell at the given column and row. If the cell doesn't exist, an
/// invalid_parameter exception will be thrown.
/// </summary>
const class cell cell(column_t column, row_t row) const;
/// <summary>
/// Returns the range defined by reference string. If reference string is the name of
/// a previously-defined named range in the sheet, it will be returned.

View File

@ -37,21 +37,18 @@
// packaging
#include <xlnt/packaging/manifest.hpp>
#include <xlnt/packaging/relationship.hpp>
#include <xlnt/packaging/uri.hpp>
// styles
#include <xlnt/styles/alignment.hpp>
#include <xlnt/styles/border.hpp>
#include <xlnt/styles/border_style.hpp>
#include <xlnt/styles/color.hpp>
#include <xlnt/styles/diagonal_direction.hpp>
#include <xlnt/styles/fill.hpp>
#include <xlnt/styles/font.hpp>
#include <xlnt/styles/format.hpp>
#include <xlnt/styles/horizontal_alignment.hpp>
#include <xlnt/styles/number_format.hpp>
#include <xlnt/styles/protection.hpp>
#include <xlnt/styles/style.hpp>
#include <xlnt/styles/vertical_alignment.hpp>
// utils
#include <xlnt/utils/calendar.hpp>
@ -64,7 +61,6 @@
#include <xlnt/utils/variant.hpp>
// workbook
#include <xlnt/workbook/const_worksheet_iterator.hpp>
#include <xlnt/workbook/document_security.hpp>
#include <xlnt/workbook/external_book.hpp>
#include <xlnt/workbook/metadata_property.hpp>
@ -77,24 +73,17 @@
#include <xlnt/worksheet/cell_iterator.hpp>
#include <xlnt/worksheet/cell_vector.hpp>
#include <xlnt/worksheet/column_properties.hpp>
#include <xlnt/worksheet/const_cell_iterator.hpp>
#include <xlnt/worksheet/const_range_iterator.hpp>
#include <xlnt/worksheet/header_footer.hpp>
#include <xlnt/worksheet/header_footer.hpp>
#include <xlnt/worksheet/major_order.hpp>
#include <xlnt/worksheet/orientation.hpp>
#include <xlnt/worksheet/page_break.hpp>
#include <xlnt/worksheet/page_margins.hpp>
#include <xlnt/worksheet/page_setup.hpp>
#include <xlnt/worksheet/pane.hpp>
#include <xlnt/worksheet/paper_size.hpp>
#include <xlnt/worksheet/range.hpp>
#include <xlnt/worksheet/range_iterator.hpp>
#include <xlnt/worksheet/range_reference.hpp>
#include <xlnt/worksheet/row_properties.hpp>
#include <xlnt/worksheet/selection.hpp>
#include <xlnt/worksheet/sheet_protection.hpp>
#include <xlnt/worksheet/sheet_state.hpp>
#include <xlnt/worksheet/sheet_view.hpp>
#include <xlnt/worksheet/worksheet.hpp>
#include <xlnt/worksheet/worksheet_properties.hpp>

View File

@ -3,11 +3,10 @@
#include <detail/default_case.hpp>
#include <detail/include_libstudxml.hpp>
#include <xlnt/packaging/relationship.hpp>
#include <xlnt/styles/alignment.hpp>
#include <xlnt/styles/border.hpp>
#include <xlnt/styles/font.hpp>
#include <xlnt/styles/fill.hpp>
#include <xlnt/styles/horizontal_alignment.hpp>
#include <xlnt/styles/vertical_alignment.hpp>
#include <xlnt/utils/exceptions.hpp>
#include <xlnt/utils/variant.hpp>
#include <xlnt/worksheet/pane.hpp>

View File

@ -27,7 +27,6 @@
#include <xlnt/cell/cell.hpp>
#include <xlnt/packaging/manifest.hpp>
#include <xlnt/utils/path.hpp>
#include <xlnt/workbook/const_worksheet_iterator.hpp>
#include <xlnt/workbook/workbook.hpp>
#include <xlnt/worksheet/worksheet.hpp>
#include <detail/constants.hpp>

View File

@ -29,7 +29,6 @@
#include <xlnt/cell/cell.hpp>
#include <xlnt/packaging/manifest.hpp>
#include <xlnt/utils/path.hpp>
#include <xlnt/workbook/const_worksheet_iterator.hpp>
#include <xlnt/workbook/workbook.hpp>
#include <xlnt/workbook/workbook_view.hpp>
#include <xlnt/worksheet/header_footer.hpp>

View File

@ -21,9 +21,9 @@ path uri::path() const
return path_;
}
bool operator==(const uri &left, const uri &right)
bool uri::operator==(const uri &other) const
{
return left.to_string() == right.to_string();
return to_string() == other.to_string();
}
} // namespace xlnt

View File

@ -92,8 +92,10 @@ optional<int> alignment::rotation() const
return text_rotation_;
}
XLNT_API bool operator==(const alignment &left, const alignment &right)
bool alignment::operator==(const alignment &right) const
{
auto &left = *this;
if (left.horizontal().is_set() != right.horizontal().is_set())
{
return false;
@ -159,4 +161,9 @@ XLNT_API bool operator==(const alignment &left, const alignment &right)
return true;
}
bool alignment::operator!=(const alignment &other) const
{
return !(*this == other);
}
} // namespace xlnt

View File

@ -50,8 +50,10 @@ border::border_property &border::border_property::style(border_style s)
return *this;
}
bool operator==(const border::border_property &left, const border::border_property &right)
bool border::border_property::operator==(const border::border_property &right) const
{
auto &left = *this;
if (left.style().is_set() != right.style().is_set())
{
return false;
@ -81,6 +83,11 @@ bool operator==(const border::border_property &left, const border::border_proper
return true;
}
bool border::border_property::operator!=(const border::border_property &right) const
{
return !(*this == right);
}
border::border()
{
}
@ -158,8 +165,10 @@ optional<diagonal_direction> border::diagonal() const
return diagonal_direction_;
}
XLNT_API bool operator==(const border &left, const border &right)
bool border::operator==(const border &right) const
{
auto &left = *this;
for (auto side : border::all_sides())
{
if (left.side(side).is_set() != right.side(side).is_set())
@ -179,4 +188,9 @@ XLNT_API bool operator==(const border &left, const border &right)
return true;
}
bool border::operator!=(const border &right) const
{
return !(*this == right);
}
} // namespace xlnt

View File

@ -46,7 +46,6 @@
#include <xlnt/utils/exceptions.hpp>
#include <xlnt/utils/path.hpp>
#include <xlnt/utils/variant.hpp>
#include <xlnt/workbook/const_worksheet_iterator.hpp>
#include <xlnt/workbook/metadata_property.hpp>
#include <xlnt/workbook/named_range.hpp>
#include <xlnt/workbook/theme.hpp>

View File

@ -60,10 +60,53 @@ bool worksheet_iterator::operator==(const worksheet_iterator &comparand) const
return index_ == comparand.index_ && wb_ == comparand.wb_;
}
bool worksheet_iterator::operator!=(const worksheet_iterator &comparand) const
{
return !(*this == comparand);
}
worksheet_iterator &worksheet_iterator::operator=(const worksheet_iterator &other)
{
index_ = other.index_;
return *this;
}
const_worksheet_iterator::const_worksheet_iterator(const workbook &wb, std::size_t index)
: wb_(wb), index_(index)
{
}
const_worksheet_iterator::const_worksheet_iterator(const const_worksheet_iterator &rhs)
: wb_(rhs.wb_), index_(rhs.index_)
{
}
const worksheet const_worksheet_iterator::operator*()
{
return wb_.sheet_by_index(index_);
}
const_worksheet_iterator &const_worksheet_iterator::operator++()
{
index_++;
return *this;
}
const_worksheet_iterator const_worksheet_iterator::operator++(int)
{
const_worksheet_iterator old(wb_, index_);
++*this;
return old;
}
bool const_worksheet_iterator::operator==(const const_worksheet_iterator &comparand) const
{
return index_ == comparand.index_ && wb_ == comparand.wb_;
}
bool const_worksheet_iterator::operator!=(const const_worksheet_iterator &comparand) const
{
return !(*this == comparand);
}
} // namespace xlnt

View File

@ -131,4 +131,77 @@ cell cell_iterator::operator*()
return ws_[current_cell_];
}
const_cell_iterator::const_cell_iterator(worksheet ws, const cell_reference &start_cell, major_order order)
: ws_(ws),
current_cell_(start_cell),
range_(start_cell.to_range()),
order_(order)
{
}
const_cell_iterator::const_cell_iterator(const const_cell_iterator &other)
{
*this = other;
}
bool const_cell_iterator::operator==(const const_cell_iterator &other) const
{
return ws_ == other.ws_ && current_cell_ == other.current_cell_ && order_ == other.order_;
}
bool const_cell_iterator::operator!=(const const_cell_iterator &other) const
{
return !(*this == other);
}
const_cell_iterator &const_cell_iterator::operator--()
{
if (order_ == major_order::row)
{
current_cell_.column_index(current_cell_.column_index() - 1);
}
else
{
current_cell_.row(current_cell_.row() - 1);
}
return *this;
}
const_cell_iterator const_cell_iterator::operator--(int)
{
const_cell_iterator old = *this;
--*this;
return old;
}
const_cell_iterator &const_cell_iterator::operator++()
{
if (order_ == major_order::row)
{
current_cell_.column_index(current_cell_.column_index() + 1);
}
else
{
current_cell_.row(current_cell_.row() + 1);
}
return *this;
}
const_cell_iterator const_cell_iterator::operator++(int)
{
const_cell_iterator old = *this;
++*this;
return old;
}
const cell const_cell_iterator::operator*() const
{
return ws_.cell(current_cell_);
}
} // namespace xlnt

View File

@ -20,10 +20,10 @@
//
// @license: http://www.opensource.org/licenses/mit-license.php
// @author: see AUTHORS file
#include <xlnt/cell/cell.hpp>
#include <xlnt/worksheet/cell_iterator.hpp>
#include <xlnt/worksheet/cell_vector.hpp>
#include <xlnt/worksheet/const_cell_iterator.hpp>
namespace xlnt {

View File

@ -24,7 +24,6 @@
#include <xlnt/cell/cell.hpp>
#include <xlnt/styles/style.hpp>
#include <xlnt/workbook/workbook.hpp>
#include <xlnt/worksheet/const_range_iterator.hpp>
#include <xlnt/worksheet/range.hpp>
#include <xlnt/worksheet/range_iterator.hpp>
#include <xlnt/worksheet/range_reference.hpp>

View File

@ -127,4 +127,89 @@ range_iterator range_iterator::operator++(int)
return old;
}
const_range_iterator::const_range_iterator(const worksheet &ws,
const range_reference &start_cell, major_order order)
: ws_(ws.d_),
current_cell_(start_cell.top_left()),
range_(start_cell),
order_(order)
{
}
const_range_iterator::const_range_iterator(const const_range_iterator &other)
{
*this = other;
}
bool const_range_iterator::operator==(const const_range_iterator &other) const
{
return ws_ == other.ws_
&& current_cell_ == other.current_cell_
&& order_ == other.order_;
}
bool const_range_iterator::operator!=(const const_range_iterator &other) const
{
return !(*this == other);
}
const_range_iterator &const_range_iterator::operator--()
{
if (order_ == major_order::row)
{
current_cell_.row(current_cell_.row() - 1);
}
else
{
current_cell_.column_index(current_cell_.column_index() - 1);
}
return *this;
}
const_range_iterator const_range_iterator::operator--(int)
{
const_range_iterator old = *this;
--*this;
return old;
}
const_range_iterator &const_range_iterator::operator++()
{
if (order_ == major_order::row)
{
current_cell_.row(current_cell_.row() + 1);
}
else
{
current_cell_.column_index(current_cell_.column_index() + 1);
}
return *this;
}
const_range_iterator const_range_iterator::operator++(int)
{
const_range_iterator old = *this;
++*this;
return old;
}
const cell_vector const_range_iterator::operator*() const
{
if (order_ == major_order::row)
{
range_reference reference(range_.top_left().column_index(), current_cell_.row(),
range_.bottom_right().column_index(), current_cell_.row());
return cell_vector(ws_, reference, order_);
}
range_reference reference(current_cell_.column_index(), range_.top_left().row(),
current_cell_.column_index(), range_.bottom_right().row());
return cell_vector(ws_, reference, order_);
}
} // namespace xlnt

View File

@ -36,8 +36,6 @@
#include <xlnt/workbook/workbook.hpp>
#include <xlnt/workbook/worksheet_iterator.hpp>
#include <xlnt/worksheet/cell_iterator.hpp>
#include <xlnt/worksheet/const_cell_iterator.hpp>
#include <xlnt/worksheet/const_range_iterator.hpp>
#include <xlnt/worksheet/header_footer.hpp>
#include <xlnt/worksheet/range.hpp>
#include <xlnt/worksheet/range_iterator.hpp>
@ -377,6 +375,16 @@ const cell worksheet::cell(const cell_reference &reference) const
return xlnt::cell(&d_->cell_map_.at(reference.row()).at(reference.column_index()));
}
cell worksheet::cell(xlnt::column_t column, row_t row)
{
return cell(cell_reference(column, row));
}
const cell worksheet::cell(xlnt::column_t column, row_t row) const
{
return cell(cell_reference(column, row));
}
bool worksheet::has_cell(const cell_reference &reference) const
{
const auto row = d_->cell_map_.find(reference.row());