mirror of
https://github.com/tfussell/xlnt.git
synced 2024-03-22 13:11:17 +08:00
fix some more tests
This commit is contained in:
parent
df49f332bf
commit
d80ba60b31
|
@ -10,12 +10,12 @@ class PackageTestSuite : public CxxTest::TestSuite
|
|||
public:
|
||||
PackageTestSuite()
|
||||
{
|
||||
xlnt::file::copy("../../source/tests/test_data/packaging/test.zip", "../../source/tests/test_data/packaging/a.zip", true);
|
||||
xlnt::file::copy("source/tests/test_data/packaging/test.zip", "source/tests/test_data/packaging/a.zip", true);
|
||||
}
|
||||
|
||||
void test_read_text()
|
||||
{
|
||||
auto package = xlnt::package::open("../../source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
auto package = xlnt::package::open("source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
TS_ASSERT_DIFFERS(package, nullptr);
|
||||
|
||||
auto part_1 = package.get_part("a.txt");
|
||||
|
@ -28,7 +28,7 @@ public:
|
|||
void test_write_text()
|
||||
{
|
||||
{
|
||||
auto package = xlnt::package::open("../../source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
auto package = xlnt::package::open("source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
TS_ASSERT_DIFFERS(package, nullptr);
|
||||
|
||||
auto part_1 = package.get_part("a.txt");
|
||||
|
@ -38,7 +38,7 @@ public:
|
|||
}
|
||||
|
||||
{
|
||||
auto package = xlnt::package::open("../../source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
auto package = xlnt::package::open("source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
TS_ASSERT_DIFFERS(package, nullptr);
|
||||
|
||||
auto part_1 = package.get_part("a.txt");
|
||||
|
@ -52,7 +52,7 @@ public:
|
|||
|
||||
void test_read_xml()
|
||||
{
|
||||
auto package = xlnt::package::open("../../source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
auto package = xlnt::package::open("source/tests/test_data/packaging/a.zip", xlnt::file_mode::Open, xlnt::file_access::ReadWrite);
|
||||
TS_ASSERT_DIFFERS(package, nullptr);
|
||||
|
||||
auto part_2 = package.get_part("a.xml");
|
||||
|
|
|
@ -618,6 +618,7 @@ struct cell_struct
|
|||
|
||||
tm date_value;
|
||||
std::string string_value;
|
||||
std::string formula_value;
|
||||
worksheet_struct *parent_worksheet;
|
||||
int column;
|
||||
int row;
|
||||
|
@ -705,7 +706,7 @@ int cell::column_index_from_string(const std::string &column_string)
|
|||
}
|
||||
|
||||
int column_index = 0;
|
||||
int place = std::pow(26, column_string.length() - 1);
|
||||
int place = 1;
|
||||
|
||||
for(int i = column_string.length() - 1; i >= 0; i--)
|
||||
{
|
||||
|
@ -715,7 +716,7 @@ int cell::column_index_from_string(const std::string &column_string)
|
|||
}
|
||||
|
||||
column_index += (std::toupper(column_string[i]) - 'A' + 1) * place;
|
||||
place /= 26;
|
||||
place *= 26;
|
||||
}
|
||||
|
||||
return column_index;
|
||||
|
@ -811,10 +812,68 @@ cell &cell::operator=(double value)
|
|||
return *this;
|
||||
}
|
||||
|
||||
cell &cell::operator=(bool value)
|
||||
{
|
||||
root_->type = type::boolean;
|
||||
root_->bool_value = value;
|
||||
return *this;
|
||||
}
|
||||
|
||||
cell &cell::operator=(const std::string &value)
|
||||
{
|
||||
if(value == "")
|
||||
{
|
||||
root_->type = type::null;
|
||||
return *this;
|
||||
}
|
||||
|
||||
if(value[0] == '=')
|
||||
{
|
||||
root_->type = type::formula;
|
||||
root_->formula_value = value;
|
||||
return *this;
|
||||
}
|
||||
|
||||
if(value[0] == '0')
|
||||
{
|
||||
if(value.length() > 1)
|
||||
{
|
||||
if(value[1] == '.')
|
||||
{
|
||||
try
|
||||
{
|
||||
double double_value = std::stod(value);
|
||||
*this = double_value;
|
||||
return *this;
|
||||
}
|
||||
catch(std::invalid_argument)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
root_->type = type::numeric;
|
||||
root_->numeric_value = 0;
|
||||
return *this;
|
||||
}
|
||||
|
||||
root_->type = type::string;
|
||||
root_->string_value = value;
|
||||
return *this;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
double double_value = std::stod(value);
|
||||
*this = double_value;
|
||||
}
|
||||
catch(std::invalid_argument)
|
||||
{
|
||||
root_->type = type::string;
|
||||
root_->string_value = value;
|
||||
}
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
|
|
@ -816,6 +816,7 @@ public:
|
|||
cell &operator=(double value);
|
||||
cell &operator=(const std::string &value);
|
||||
cell &operator=(const char *value);
|
||||
cell &operator=(bool value);
|
||||
cell &operator=(const tm &value);
|
||||
|
||||
friend bool operator==(const std::string &comparand, const cell &cell);
|
||||
|
|
Loading…
Reference in New Issue
Block a user