Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
onlyoffice_core
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boris Kocherov
onlyoffice_core
Commits
691042c5
Commit
691042c5
authored
Aug 08, 2017
by
ElenaSubbotina
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
OdfFormatReader - convert pilot tables
parent
d8f34224
Changes
20
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
773 additions
and
227 deletions
+773
-227
ASCOfficeOdfFile/linux/OdfFileReaderLib.pro
ASCOfficeOdfFile/linux/OdfFileReaderLib.pro
+1
-0
ASCOfficeOdfFile/linux/odffilereaderlib_oox.cpp
ASCOfficeOdfFile/linux/odffilereaderlib_oox.cpp
+1
-0
ASCOfficeOdfFile/src/docx/xlsx_output_xml.cpp
ASCOfficeOdfFile/src/docx/xlsx_output_xml.cpp
+4
-8
ASCOfficeOdfFile/src/docx/xlsx_output_xml.h
ASCOfficeOdfFile/src/docx/xlsx_output_xml.h
+4
-5
ASCOfficeOdfFile/src/docx/xlsx_package.cpp
ASCOfficeOdfFile/src/docx/xlsx_package.cpp
+197
-73
ASCOfficeOdfFile/src/docx/xlsx_package.h
ASCOfficeOdfFile/src/docx/xlsx_package.h
+91
-28
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
+240
-0
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
+83
-0
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.cpp
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.cpp
+51
-5
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.h
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.h
+3
-0
ASCOfficeOdfFile/src/odf/office_spreadsheet.cpp
ASCOfficeOdfFile/src/odf/office_spreadsheet.cpp
+22
-21
ASCOfficeOdfFile/src/odf/office_spreadsheet.h
ASCOfficeOdfFile/src/odf/office_spreadsheet.h
+17
-16
ASCOfficeOdfFile/src/odf/table.cpp
ASCOfficeOdfFile/src/odf/table.cpp
+1
-1
ASCOfficeOdfFile/src/odf/table.h
ASCOfficeOdfFile/src/odf/table.h
+1
-42
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
+35
-12
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
+3
-2
ASCOfficeOdfFile/win32/cpodf.vcproj
ASCOfficeOdfFile/win32/cpodf.vcproj
+8
-0
ASCOfficeXlsFile2/source/XlsXlsxConverter/oox_package.h
ASCOfficeXlsFile2/source/XlsXlsxConverter/oox_package.h
+3
-1
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.cpp
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.cpp
+5
-4
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.h
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.h
+3
-9
No files found.
ASCOfficeOdfFile/linux/OdfFileReaderLib.pro
View file @
691042c5
...
...
@@ -286,6 +286,7 @@ SOURCES += \
..
/
src
/
docx
/
xlsx_table_metrics
.
cpp
\
..
/
src
/
docx
/
xlsx_table_state
.
cpp
\
..
/
src
/
docx
/
xlsx_textcontext
.
cpp
\
..
/
src
/
docx
/
xlsx_pivots_context
.
cpp
\
..
/
src
/
docx
/
xlsx_utils
.
cpp
\
..
/
src
/
docx
/
xlsx_xf
.
cpp
}
...
...
ASCOfficeOdfFile/linux/odffilereaderlib_oox.cpp
View file @
691042c5
...
...
@@ -100,3 +100,4 @@
#include "../src/docx/xlsx_textcontext.cpp"
#include "../src/docx/xlsx_utils.cpp"
#include "../src/docx/xlsx_xf.cpp"
#include "../src/docx/xlsx_pivots_context.cpp"
ASCOfficeOdfFile/src/docx/xlsx_output_xml.cpp
View file @
691042c5
...
...
@@ -57,8 +57,7 @@ public:
std
::
wstringstream
ole_objects_
;
std
::
wstringstream
page_props_
;
rels
hyperlinks_rels_
;
rels
ole_objects_rels_
;
rels
sheet_rels_
;
std
::
wstring
drawingName_
;
std
::
wstring
drawingId_
;
...
...
@@ -141,14 +140,11 @@ std::wostream & xlsx_xml_worksheet::page_properties()
}
//---------------------------------------------------------------------------------------
rels
&
xlsx_xml_worksheet
::
hyperlinks
_rels
()
rels
&
xlsx_xml_worksheet
::
sheet
_rels
()
{
return
impl_
->
hyperlinks_rels_
;
}
rels
&
xlsx_xml_worksheet
::
ole_objects_rels
()
{
return
impl_
->
ole_objects_rels_
;
return
impl_
->
sheet_rels_
;
}
void
xlsx_xml_worksheet
::
write_to
(
std
::
wostream
&
strm
)
{
CP_XML_WRITER
(
strm
)
...
...
ASCOfficeOdfFile/src/docx/xlsx_output_xml.h
View file @
691042c5
...
...
@@ -49,8 +49,8 @@ class xlsx_xml_worksheet: noncopyable
public:
xlsx_xml_worksheet
(
std
::
wstring
const
&
name
);
~
xlsx_xml_worksheet
();
public:
std
::
wstring
name
()
const
;
std
::
wstring
name
()
const
;
std
::
wostream
&
cols
();
std
::
wostream
&
sheetFormat
();
...
...
@@ -65,9 +65,8 @@ public:
std
::
wostream
&
ole_objects
();
std
::
wostream
&
page_properties
();
rels
&
hyperlinks_rels
();
rels
&
ole_objects_rels
();
rels
&
sheet_rels
();
//hyperlink, background image, external, media ...
void
write_to
(
std
::
wostream
&
strm
);
void
set_drawing_link
(
std
::
wstring
const
&
fileName
,
std
::
wstring
const
&
id
);
...
...
ASCOfficeOdfFile/src/docx/xlsx_package.cpp
View file @
691042c5
This diff is collapsed.
Click to expand it.
ASCOfficeOdfFile/src/docx/xlsx_package.h
View file @
691042c5
...
...
@@ -50,9 +50,6 @@ public:
xlsx_content_types_file
();
};
class
sheet_content
;
typedef
_CP_PTR
(
sheet_content
)
sheet_content_ptr
;
class
sheet_content
:
noncopyable
{
public:
...
...
@@ -68,8 +65,49 @@ private:
std
::
wstringstream
content_
;
rels_file_ptr
rels_
;
};
typedef
_CP_PTR
(
sheet_content
)
sheet_content_ptr
;
//------------------------------------------------------------------------
class
pivot_cache_content
;
typedef
_CP_PTR
(
pivot_cache_content
)
pivot_cache_content_ptr
;
class
pivot_cache_content
:
boost
::
noncopyable
{
public:
pivot_cache_content
();
static
_CP_PTR
(
pivot_cache_content
)
create
();
// sheets_files
std
::
wostream
&
definitions
()
{
return
definitions_
;
}
std
::
wostream
&
records
()
{
return
records_
;
}
rels
&
get_rels
()
{
return
definitions_rels_file_
->
get_rels
();
}
std
::
wstring
str_d
()
{
return
definitions_
.
str
();
}
std
::
wstring
str_r
()
{
return
records_
.
str
();
}
friend
class
xl_pivot_cache_files
;
private:
std
::
wstringstream
records_
;
std
::
wstringstream
definitions_
;
rels_file_ptr
definitions_rels_file_
;
};
//------------------------------------------------------------------------
class
pivot_table_content
;
typedef
_CP_PTR
(
pivot_table_content
)
pivot_table_content_ptr
;
class
pivot_table_content
:
boost
::
noncopyable
{
public:
pivot_table_content
();
static
_CP_PTR
(
pivot_table_content
)
create
();
std
::
wostream
&
content
()
{
return
content_
;
}
rels
&
get_rels
()
{
return
rels_file_
->
get_rels
();
}
std
::
wstring
str
()
{
return
content_
.
str
();
}
friend
class
xl_pivot_table_files
;
private:
std
::
wstringstream
content_
;
rels_file_ptr
rels_file_
;
};
//------------------------------------------------------------------------
class
sheets_files
:
public
element
{
public:
...
...
@@ -90,7 +128,7 @@ public:
};
// xl_charts_files
class
xl_charts_files
:
public
element
{
public:
...
...
@@ -102,12 +140,37 @@ public:
std
::
vector
<
chart_content_ptr
>
charts_
;
};
///////////////////////////////////////////////////////////
class
xl_pivot_table_files
:
public
element
{
public:
xl_pivot_table_files
(){}
void
add_pivot_table
(
pivot_table_content_ptr
pivot_table
);
virtual
void
write
(
const
std
::
wstring
&
RootPath
);
std
::
vector
<
pivot_table_content_ptr
>
pivot_tables_
;
};
class
xl_pivot_cache_files
:
public
element
{
public:
xl_pivot_cache_files
(){}
void
set_rels
(
rels_files
*
rels
)
{
rels_
=
rels
;
}
void
add_pivot_cache
(
pivot_cache_content_ptr
pivot_cache
);
virtual
void
write
(
const
std
::
wstring
&
RootPath
);
std
::
vector
<
pivot_cache_content_ptr
>
pivot_caches_
;
rels_files
*
rels_
;
};
//-------------------------------------------------------------------------------------------------------------
class
xl_comments
;
typedef
_CP_PTR
(
xl_comments
)
xl_comments_ptr
;
// xl_comments
class
xl_comments
:
public
element
{
public:
...
...
@@ -121,13 +184,10 @@ public:
private:
const
std
::
vector
<
comment_elm
>
&
comments_
;
};
//-----------------------------------------------------------------------------------------------------
class
xl_drawings
;
typedef
_CP_PTR
(
xl_drawings
)
xl_drawings_ptr
;
// xl_drawings
class
xl_drawings
:
public
element
{
public:
...
...
@@ -146,10 +206,9 @@ public:
private:
const
std
::
vector
<
drawing_elm
>
&
drawings_
;
rels_files
*
rels_
;
};
//----------------------------------------------------------------------------------------------------------
// xl_files
class
xl_files
:
public
element
{
public:
...
...
@@ -158,20 +217,25 @@ public:
public:
virtual
void
write
(
const
std
::
wstring
&
RootPath
);
void
set_workbook
(
element_ptr
Element
);
void
set_styles
(
element_ptr
Element
);
void
set_sharedStrings
(
element_ptr
Element
);
void
add_sheet
(
sheet_content_ptr
sheet
);
void
set_media
(
mediaitems
&
_Mediaitems
,
CApplicationFonts
*
pAppFonts
);
void
set_drawings
(
element_ptr
Element
);
void
set_vml_drawings
(
element_ptr
Element
);
void
set_comments
(
element_ptr
Element
);
void
add_charts
(
chart_content_ptr
chart
);
void
set_workbook
(
element_ptr
Element
);
void
set_styles
(
element_ptr
Element
);
void
set_sharedStrings
(
element_ptr
Element
);
void
set_connections
(
element_ptr
Element
);
void
add_sheet
(
sheet_content_ptr
sheet
);
void
set_media
(
mediaitems
&
_Mediaitems
,
CApplicationFonts
*
pAppFonts
);
void
set_drawings
(
element_ptr
Element
);
void
set_vml_drawings
(
element_ptr
Element
);
void
set_comments
(
element_ptr
Element
);
void
add_charts
(
chart_content_ptr
chart
);
void
add_pivot_cache
(
pivot_cache_content_ptr
cache
);
void
add_pivot_table
(
pivot_table_content_ptr
table
);
private:
rels_files
rels_files_
;
sheets_files
sheets_files_
;
xl_charts_files
charts_files_
;
rels_files
rels_files_
;
sheets_files
sheets_files_
;
xl_charts_files
charts_files_
;
xl_pivot_cache_files
pivot_cache_files_
;
xl_pivot_table_files
pivot_table_files_
;
element_ptr
theme_
;
element_ptr
workbook_
;
...
...
@@ -183,10 +247,9 @@ private:
element_ptr
drawings_
;
element_ptr
vml_drawings_
;
element_ptr
comments_
;
element_ptr
connections_
;
};
// xlsx_document
class
xlsx_document
:
public
document
{
public:
...
...
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
0 → 100644
View file @
691042c5
/*
* (c) Copyright Ascensio System SIA 2010-2017
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
#include "xlsx_pivots_context.h"
#include <boost/make_shared.hpp>
#include <cpdoccore/xml/simple_xml_writer.h>
namespace
cpdoccore
{
namespace
oox
{
class
xlsx_pivots_context
::
Impl
{
public:
struct
_pivot_cache
{
std
::
wstring
definitionsData_
;
std
::
wstring
recordsData_
;
};
struct
_pivot_view
{
std
::
wstring
data_
;
int
indexCache_
;
};
struct
_pivot_field
{
std
::
wstring
view_
;
std
::
wstring
cache_
;
};
Impl
()
{}
std
::
vector
<
_pivot_cache
>
caches_
;
std
::
vector
<
_pivot_view
>
views_
;
std
::
wstring
connections_
;
std
::
vector
<
_pivot_field
>
fields_
;
std
::
wstringstream
view_
;
std
::
wstringstream
cache_
;
};
xlsx_pivots_context
::
xlsx_pivots_context
()
:
impl_
(
new
xlsx_pivots_context
::
Impl
())
{
}
void
xlsx_pivots_context
::
add_cache
(
std
::
wstring
definitions
,
std
::
wstring
records
)
{
Impl
::
_pivot_cache
c
=
{
definitions
,
records
};
impl_
->
caches_
.
push_back
(
c
);
}
int
xlsx_pivots_context
::
get_cache_count
()
{
return
(
int
)
impl_
->
caches_
.
size
();
}
bool
xlsx_pivots_context
::
is_connections
()
{
return
!
impl_
->
connections_
.
empty
();
}
void
xlsx_pivots_context
::
dump_rels_cache
(
int
index
,
rels
&
Rels
)
{
if
(
impl_
->
caches_
[
index
].
recordsData_
.
empty
()
==
false
)
{
Rels
.
add
(
relationship
(
L"rId1"
,
L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/pivotCacheRecords"
,
L"pivotCacheRecords"
+
std
::
to_wstring
(
index
+
1
)
+
L".xml"
,
L""
));
}
}
void
xlsx_pivots_context
::
dump_rels_view
(
int
index
,
rels
&
Rels
)
{
if
(
impl_
->
views_
[
index
].
indexCache_
>=
0
)
{
Rels
.
add
(
relationship
(
L"rId1"
,
L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/pivotCacheDefinition"
,
L"../pivotCache/pivotCacheDefinition"
+
std
::
to_wstring
(
impl_
->
views_
[
index
].
indexCache_
+
1
)
+
L".xml"
,
L""
));
}
}
void
xlsx_pivots_context
::
write_cache_definitions_to
(
int
index
,
std
::
wostream
&
strm
)
{
strm
<<
impl_
->
caches_
[
index
].
definitionsData_
;
}
void
xlsx_pivots_context
::
write_connections_to
(
std
::
wostream
&
strm
)
{
CP_XML_WRITER
(
strm
)
{
CP_XML_NODE
(
L"connections"
)
{
CP_XML_ATTR
(
L"xmlns"
,
L"http://schemas.openxmlformats.org/spreadsheetml/2006/main"
);
CP_XML_STREAM
()
<<
impl_
->
connections_
;
}
}
}
void
xlsx_pivots_context
::
write_cache_records_to
(
int
index
,
std
::
wostream
&
strm
)
{
strm
<<
impl_
->
caches_
[
index
].
recordsData_
;
}
void
xlsx_pivots_context
::
write_table_view_to
(
int
index
,
std
::
wostream
&
strm
)
{
strm
<<
impl_
->
views_
[
index
].
data_
;
}
void
xlsx_pivots_context
::
start_table
()
{
impl_
->
fields_
.
clear
();
}
int
xlsx_pivots_context
::
end_table
()
{
std
::
wstringstream
strm
;
CP_XML_WRITER
(
strm
)
{
CP_XML_NODE
(
L"pivotTableDefinition"
)
{
CP_XML_ATTR
(
L"xmlns"
,
L"http://schemas.openxmlformats.org/spreadsheetml/2006/main"
);
//CP_XML_ATTR(L"name", view->stTable.value());
//CP_XML_ATTR(L"cacheId", view->iCache);
//CP_XML_ATTR(L"dataOnRows", view->sxaxis4Data.bRw);
//CP_XML_ATTR(L"applyNumberFormats", view->fAtrNum);
//CP_XML_ATTR(L"applyBorderFormats", view->fAtrBdr);
//CP_XML_ATTR(L"applyFontFormats", view->fAtrFnt);
//CP_XML_ATTR(L"applyPatternFormats", view->fAtrPat);
//CP_XML_ATTR(L"applyAlignmentFormats", view->fAtrAlc);
//CP_XML_ATTR(L"applyWidthHeightFormats", view->fAtrProc);
//if (!view->stData.value().empty())
//{
// CP_XML_ATTR(L"dataCaption", view->stData.value());
//}
//CP_XML_ATTR(L"asteriskTotals", 1);
//CP_XML_ATTR(L"showMemberPropertyTips", 0);
//CP_XML_ATTR(L"useAutoFormatting", view->fAutoFormat);
//CP_XML_ATTR(L"autoFormatId", view->itblAutoFmt);
CP_XML_ATTR
(
L"itemPrintTitles"
,
1
);
CP_XML_ATTR
(
L"indent"
,
0
);
CP_XML_ATTR
(
L"compact"
,
0
);
CP_XML_ATTR
(
L"compactData"
,
0
);
CP_XML_ATTR
(
L"gridDropZones"
,
1
);
CP_XML_NODE
(
L"location"
)
{
//CP_XML_ATTR(L"ref", view->ref.toString());
//CP_XML_ATTR(L"firstHeaderRow", view->rwFirstHead - view->ref.rowFirst );
//CP_XML_ATTR(L"firstDataRow", view->rwFirstData - view->ref.rowFirst);
//CP_XML_ATTR(L"firstDataCol", view->colFirstData - view->ref.columnFirst);
CP_XML_ATTR
(
L"rowPageCount"
,
1
);
CP_XML_ATTR
(
L"colPageCount"
,
1
);
}
CP_XML_NODE
(
L"pivotFields"
)
{
CP_XML_ATTR
(
L"count"
,
impl_
->
fields_
.
size
());
for
(
size_t
i
=
0
;
i
<
impl_
->
fields_
.
size
();
i
++
)
{
impl_
->
fields_
[
i
].
view_
;
}
}
}
}
Impl
::
_pivot_view
v
=
{
strm
.
str
(),
impl_
->
views_
.
size
()
+
1
};
impl_
->
views_
.
push_back
(
v
);
return
impl_
->
views_
.
size
();
}
void
xlsx_pivots_context
::
start_field
()
{
}
void
xlsx_pivots_context
::
end_field
()
{
std
::
wstringstream
strm
;
CP_XML_WRITER
(
strm
)
{
CP_XML_NODE
(
L"pivotField"
)
{
}
}
Impl
::
_pivot_field
f
=
{
strm
.
str
(),
L""
};
impl_
->
fields_
.
push_back
(
f
);
}
void
xlsx_pivots_context
::
add_connections
(
std
::
wstring
connections
)
{
if
(
connections
.
empty
())
return
;
impl_
->
connections_
=
connections
;
}
int
xlsx_pivots_context
::
get_view_count
()
{
return
(
int
)
impl_
->
views_
.
size
();
}
xlsx_pivots_context
::~
xlsx_pivots_context
()
{
}
std
::
wostream
&
xlsx_pivots_context
::
stream_view
()
{
return
impl_
->
view_
;
}
std
::
wostream
&
xlsx_pivots_context
::
stream_cache
()
{
return
impl_
->
cache_
;
}
}
}
\ No newline at end of file
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
0 → 100644
View file @
691042c5
/*
* (c) Copyright Ascensio System SIA 2010-2017
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
#pragma once
#include "oox_package.h"
#include <cpdoccore/CPScopedPtr.h>
#include <cpdoccore/CPOptional.h>
namespace
cpdoccore
{
namespace
oox
{
class
xlsx_pivot_cache_context
;
typedef
_CP_PTR
(
xlsx_pivot_cache_context
)
xlsx_pivot_cache_context_ptr
;
class
xlsx_pivots_context
{
public:
xlsx_pivots_context
();
~
xlsx_pivots_context
();
void
start_table
();
int
end_table
();
void
start_field
();
void
end_field
();
//int add_view(int indexCache);
int
get_view_count
();
void
add_cache
(
std
::
wstring
definitions
,
std
::
wstring
records
);
int
get_cache_count
();
void
write_cache_definitions_to
(
int
index
,
std
::
wostream
&
strm
);
void
write_cache_records_to
(
int
index
,
std
::
wostream
&
strm
);
void
write_connections_to
(
std
::
wostream
&
strm
);
void
write_table_view_to
(
int
index
,
std
::
wostream
&
strm
);
void
dump_rels_cache
(
int
index
,
rels
&
Rels
);
void
dump_rels_view
(
int
index
,
rels
&
Rels
);
void
add_connections
(
std
::
wstring
connections
);
bool
is_connections
();
std
::
wostream
&
stream_view
();
std
::
wostream
&
stream_cache
();
private:
class
Impl
;
_CP_PTR
(
Impl
)
impl_
;
};
}
}
\ No newline at end of file
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.cpp
View file @
691042c5
...
...
@@ -152,8 +152,7 @@ void xlsx_conversion_context::end_document()
content
->
add_rel
(
relationship
(
dId
,
kType
,
dName
));
}
//////////////////////////////////////////////////////////////////////////////////////////////////
content
->
add_rels
(
sheet
->
hyperlinks_rels
());
content
->
add_rels
(
sheet
->
ole_objects_rels
());
content
->
add_rels
(
sheet
->
sheet_rels
());
/////////////////////////////////////////////////////////////////////////////////////////////////
const
std
::
pair
<
std
::
wstring
,
std
::
wstring
>
p2
=
sheet
->
get_comments_link
();
if
(
!
p2
.
first
.
empty
())
...
...
@@ -232,6 +231,54 @@ void xlsx_conversion_context::end_document()
}
get_xlsx_defined_names
().
xlsx_serialize
(
CP_XML_STREAM
());
int
pivot_cache_count
=
xlsx_pivots_context_
.
get_cache_count
();
if
(
pivot_cache_count
>
0
)
{
CP_XML_NODE
(
L"pivotCaches"
)
{
for
(
int
i
=
0
;
i
<
pivot_cache_count
;
i
++
)
{
std
::
wstring
rId
=
L"pcId"
+
std
::
to_wstring
(
i
+
1
);
static
const
std
::
wstring
sType
=
L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/pivotCacheDefinition"
;
const
std
::
wstring
sName
=
std
::
wstring
(
L"../pivotCache/pivotCacheDefinition"
+
std
::
to_wstring
(
i
+
1
)
+
L".xml"
);
package
::
pivot_cache_content_ptr
content
=
package
::
pivot_cache_content
::
create
();
CP_XML_NODE
(
L"pivotCache"
)
{
CP_XML_ATTR
(
L"cacheId"
,
std
::
to_wstring
(
i
));
CP_XML_ATTR
(
L"r:id"
,
rId
);
}
xlsx_pivots_context_
.
dump_rels_cache
(
i
,
content
->
get_rels
());
xlsx_pivots_context_
.
write_cache_definitions_to
(
i
,
content
->
definitions
());
xlsx_pivots_context_
.
write_cache_records_to
(
i
,
content
->
records
());
output_document_
->
get_xl_files
().
add_pivot_cache
(
content
);
}
}
}
int
pivot_view_count
=
xlsx_pivots_context_
.
get_view_count
();
if
(
pivot_view_count
>
0
)
{
for
(
int
i
=
0
;
i
<
pivot_view_count
;
i
++
)
{
package
::
pivot_table_content_ptr
content
=
package
::
pivot_table_content
::
create
();
xlsx_pivots_context_
.
dump_rels_view
(
i
,
content
->
get_rels
());
xlsx_pivots_context_
.
write_table_view_to
(
i
,
content
->
content
());
output_document_
->
get_xl_files
().
add_pivot_table
(
content
);
}
}
if
(
xlsx_pivots_context_
.
is_connections
())
{
std
::
wstringstream
strm
;
xlsx_pivots_context_
.
write_connections_to
(
strm
);
output_document_
->
get_xl_files
().
set_connections
(
package
::
simple_element
::
create
(
L"connections.xml"
,
strm
.
str
())
);
}
}
}
...
...
@@ -381,9 +428,8 @@ void xlsx_conversion_context::end_table()
get_table_context
().
serialize_hyperlinks
(
current_sheet
().
hyperlinks
());
get_table_context
().
serialize_ole_objects
(
current_sheet
().
ole_objects
());
get_table_context
().
dump_rels_hyperlinks
(
current_sheet
().
hyperlinks_rels
());
get_table_context
().
dump_rels_ole_objects
(
current_sheet
().
ole_objects_rels
());
get_table_context
().
dump_rels_hyperlinks
(
current_sheet
().
sheet_rels
());
get_table_context
().
dump_rels_ole_objects
(
current_sheet
().
sheet_rels
());
if
(
!
get_drawing_context
().
empty
())
{
...
...
ASCOfficeOdfFile/src/docx/xlsxconversioncontext.h
View file @
691042c5
...
...
@@ -48,6 +48,7 @@
#include "xlsx_comments_context.h"
#include "xlsx_defined_names.h"
#include "xlsx_table_metrics.h"
#include "xlsx_pivots_context.h"
#include "oox_chart_context.h"
#include "mediaitems.h"
...
...
@@ -168,6 +169,7 @@ public:
num_format_context
&
get_num_format_context
()
{
return
num_format_context_
;
}
size_t
get_default_cell_style
()
const
{
return
default_style_
;
}
xlsx_defined_names
&
get_xlsx_defined_names
()
{
return
xlsx_defined_names_
;
}
xlsx_pivots_context
&
get_pivots_context
()
{
return
xlsx_pivots_context_
;}
xlsx_table_metrics
&
get_table_metrics
();
xlsx_drawing_context
&
get_drawing_context
();
xlsx_drawing_context_handle
&
get_drawing_context_handle
();
...
...
@@ -202,6 +204,7 @@ private:
xlsx_table_context
xlsx_table_context_
;
xlsx_text_context
xlsx_text_context_
;
math_context
math_context_
;
xlsx_pivots_context
xlsx_pivots_context_
;
xlsx_drawing_context_handle
xlsx_drawing_context_handle_
;
xlsx_comments_context_handle
xlsx_comments_context_handle_
;
};
...
...
ASCOfficeOdfFile/src/odf/office_spreadsheet.cpp
View file @
691042c5
...
...
@@ -48,26 +48,25 @@ const wchar_t * office_spreadsheet::name = L"spreadsheet";
void
office_spreadsheet
::
add_child_element
(
xml
::
sax
*
Reader
,
const
std
::
wstring
&
Ns
,
const
std
::
wstring
&
Name
)
{
if
CP_CHECK_NAME
(
L"table"
,
L"database-ranges"
)
{
CP_CREATE_ELEMENT
(
database_ranges_
);
}
else
if
CP_CHECK_NAME
(
L"table"
,
L"named-expressions"
)
{
CP_CREATE_ELEMENT
(
table_database_range
s_
);
CP_CREATE_ELEMENT
(
named_expression
s_
);
}
else
if
CP_CHECK_NAME
(
L"table"
,
L"data-pilot-tables"
)
{
CP_CREATE_ELEMENT
(
table_data_pilot_tables_
);
CP_CREATE_ELEMENT
(
data_pilot_tables_
);
}
else
if
CP_CHECK_NAME
(
L"table"
,
L"tracked-changes"
)
{
CP_CREATE_ELEMENT
(
tracked_changes_
);
}
else
CP_CREATE_ELEMENT
(
content_
);
}
void
office_spreadsheet
::
add_text
(
const
std
::
wstring
&
Text
)
{
// TODO : error
}
void
office_spreadsheet
::
add_attributes
(
const
xml
::
attributes_wc_ptr
&
Attributes
)
{
}
void
office_spreadsheet
::
docx_convert
(
oox
::
docx_conversion_context
&
Context
)
{
Context
.
start_office_text
();
...
...
@@ -81,21 +80,23 @@ void office_spreadsheet::docx_convert(oox::docx_conversion_context & Context)
void
office_spreadsheet
::
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
)
{
Context
.
start_office_spreadsheet
(
this
);
_CP_LOG
<<
L"[info][xlsx] process spreadsheet ("
<<
content_
.
size
()
<<
L"
elmement
s)"
<<
std
::
endl
;
_CP_LOG
<<
L"[info][xlsx] process spreadsheet ("
<<
content_
.
size
()
<<
L"
table
s)"
<<
std
::
endl
;
for
(
size_t
i
=
0
;
i
<
table_database_ranges_
.
size
();
i
++
)
{
table_database_ranges_
[
i
]
->
xlsx_convert
(
Context
);
}
if
(
named_expressions_
)
named_expressions_
->
xlsx_convert
(
Context
);
if
(
database_ranges_
)
database_ranges_
->
xlsx_convert
(
Context
);
for
(
size_t
i
=
0
;
i
<
content_
.
size
();
i
++
)
{
content_
[
i
]
->
xlsx_convert
(
Context
);
}
for
(
size_t
i
=
0
;
i
<
table_data_pilot_tables_
.
size
();
i
++
)
{
table_data_pilot_tables_
[
i
]
->
xlsx_convert
(
Context
);
}
Context
.
end_office_spreadsheet
();
if
(
data_pilot_tables_
)
data_pilot_tables_
->
xlsx_convert
(
Context
);
Context
.
end_office_spreadsheet
();
}
}
...
...
ASCOfficeOdfFile/src/odf/office_spreadsheet.h
View file @
691042c5
...
...
@@ -41,7 +41,6 @@
namespace
cpdoccore
{
namespace
odf_reader
{
// office:spreadsheet
class
office_spreadsheet
:
public
office_element_impl
<
office_spreadsheet
>
{
public:
...
...
@@ -55,27 +54,29 @@ public:
virtual
void
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
);
private:
virtual
void
add_attributes
(
const
xml
::
attributes_wc_ptr
&
Attributes
);
virtual
void
add_attributes
(
const
xml
::
attributes_wc_ptr
&
Attributes
){}
virtual
void
add_child_element
(
xml
::
sax
*
Reader
,
const
std
::
wstring
&
Ns
,
const
std
::
wstring
&
Name
);
virtual
void
add_text
(
const
std
::
wstring
&
Text
);
public:
// TODO: office-text-content-prelude:
// TODO: office-forms
// TODO: text-decls
// TODO: table-decls
office_element_ptr
named_expressions_
;
office_element_ptr
database_ranges_
;
office_element_ptr
data_pilot_tables_
;
office_element_ptr
tracked_changes_
;
office_element_ptr_array
table_database_ranges_
;
office_element_ptr_array
table_data_pilot_tables_
;
office_element_ptr
tracked_changes_
;
//??
office_element_ptr_array
content_
;
// TODO: text-page-sequence
// TODO: office-text-content-epilogue:
// TODO: table-functions
// table:calculation-settings
// table:consolidation
// table:content-validations
// table:dde-links
// table:label-ranges
// text:alphabetical-index-auto-mark-file
// text:ddeconnection-decls
// text:sequence-decls
// text:user-fielddecls
// text:variable-decls
};
CP_REGISTER_OFFICE_ELEMENT2
(
office_spreadsheet
);
}
...
...
ASCOfficeOdfFile/src/odf/table.cpp
View file @
691042c5
...
...
@@ -172,7 +172,7 @@ void table_table::add_child_element( xml::sax * Reader, const std::wstring & Ns,
CP_CREATE_ELEMENT
(
table_shapes_
);
}
else
if
(
CP_CHECK_NAME
(
L"table"
,
L"named-expressions"
)
||
CP_CHECK_NAME
(
L"table"
,
L"named-range"
)
)
CP_CHECK_NAME
(
L"table"
,
L"named-range"
)
)
//???
{
CP_CREATE_ELEMENT
(
table_named_
);
}
...
...
ASCOfficeOdfFile/src/odf/table.h
View file @
691042c5
...
...
@@ -51,7 +51,6 @@
namespace
cpdoccore
{
namespace
odf_reader
{
// table:table-attlist
class
table_table_attlist
{
public:
...
...
@@ -75,7 +74,6 @@ public:
friend
class
table_table
;
};
// table:table-row-attlist
class
table_table_row_attlist
{
public:
...
...
@@ -88,7 +86,6 @@ public:
};
// table:table-cell-attlist
class
table_table_cell_attlist
{
public:
...
...
@@ -105,7 +102,6 @@ public:
};
// table:table-cell-attlist-extra
class
table_table_cell_attlist_extra
{
public:
...
...
@@ -119,7 +115,6 @@ public:
};
// table-table-source-attlist
class
table_table_source_attlist
{
public:
...
...
@@ -130,7 +125,6 @@ public:
};
// table:linked-source-attlist
class
table_linked_source_attlist
{
public:
...
...
@@ -144,7 +138,6 @@ public:
};
// table:table-source
class
table_table_source
:
public
office_element_impl
<
table_table_source
>
{
public:
...
...
@@ -165,7 +158,6 @@ private:
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_source
);
// table:columns
class
table_columns
{
public:
...
...
@@ -180,7 +172,6 @@ public:
};
// table:columns-no-group
class
table_columns_no_group
:
public
office_element
{
public:
...
...
@@ -212,7 +203,6 @@ public:
table_columns
table_columns_2_
;
};
// table:columns-and-groups
class
table_columns_and_groups
{
public:
...
...
@@ -226,11 +216,10 @@ public:
// office_element_ptr table_table_column_group_;
// table_columns_no_group table_columns_no_group_;
office_element_ptr_array
content_
;
office_element_ptr_array
content_
;
};
// table:table-column-attlist
class
table_table_column_attlist
{
public:
...
...
@@ -243,7 +232,6 @@ public:
};
// table:table-column
class
table_table_column
:
public
office_element_impl
<
table_table_column
>
{
public:
...
...
@@ -266,10 +254,8 @@ public:
table_table_column_attlist
table_table_column_attlist_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_column
);
// table:table-columns
class
table_table_columns
:
public
office_element_impl
<
table_table_columns
>
{
public:
...
...
@@ -291,11 +277,8 @@ public:
office_element_ptr_array
table_table_column_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_columns
);
// table:table-header-columns
class
table_table_header_columns
:
public
office_element_impl
<
table_table_header_columns
>
{
public:
...
...
@@ -318,10 +301,8 @@ public:
office_element_ptr_array
table_table_column_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_header_columns
);
// table:table-column-group-attlist
class
table_table_column_group_attlist
{
public:
...
...
@@ -331,7 +312,6 @@ public:
};
// table:table-column-group
class
table_table_column_group
:
public
office_element_impl
<
table_table_column_group
>
{
public:
...
...
@@ -358,10 +338,8 @@ public:
table_table_column_group_attlist
table_table_column_group_attlist_
;
table_columns_and_groups
table_columns_and_groups_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_column_group
);
// table:table-row
class
table_table_row
:
public
office_element_impl
<
table_table_row
>
{
public:
...
...
@@ -387,10 +365,8 @@ public:
office_element_ptr_array
content_
;
// table-table-cell or table-covered-table-cell
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_row
);
// table:table-cell-content
class
table_table_cell_content
{
public:
...
...
@@ -407,8 +383,6 @@ public:
// TODO table-detective
};
// table:table-cell
class
table_table_cell
:
public
office_element_impl
<
table_table_cell
>
{
public:
...
...
@@ -443,7 +417,6 @@ public:
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_cell
);
// table:covered-table-cell
class
table_covered_table_cell
:
public
office_element_impl
<
table_covered_table_cell
>
{
public:
...
...
@@ -479,7 +452,6 @@ public:
CP_REGISTER_OFFICE_ELEMENT2
(
table_covered_table_cell
);
// table:table-rows
class
table_table_rows
:
public
office_element_impl
<
table_table_rows
>
{
public:
...
...
@@ -507,10 +479,8 @@ public:
office_element_ptr_array
table_table_row_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_rows
);
// table:table-header-rows
class
table_table_header_rows
:
public
office_element_impl
<
table_table_header_rows
>
{
public:
...
...
@@ -536,10 +506,8 @@ public:
office_element_ptr_array
table_table_row_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_header_rows
);
// table:rows
class
table_rows
{
public:
...
...
@@ -556,7 +524,6 @@ public:
void
remove_equals_empty
();
};
// table:rows-no-group
class
table_rows_no_group
:
public
office_element
{
public:
...
...
@@ -591,7 +558,6 @@ public:
};
// table:rows-and-groups
class
table_rows_and_groups
{
public:
...
...
@@ -611,7 +577,6 @@ public:
};
// table:table-row-group-attlist
class
table_table_row_group_attlist
{
public:
...
...
@@ -621,7 +586,6 @@ public:
};
// table:table-row-group
class
table_table_row_group
:
public
office_element_impl
<
table_table_row_group
>
{
public:
...
...
@@ -647,10 +611,8 @@ public:
table_rows_and_groups
table_rows_and_groups_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table_row_group
);
// table:table
class
table_table
:
public
office_element_impl
<
table_table
>
{
public:
...
...
@@ -685,10 +647,8 @@ public:
//table-scenario
//office-forms
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_table
);
// table:shapes
class
table_shapes
:
public
office_element_impl
<
table_shapes
>
{
public:
...
...
@@ -710,7 +670,6 @@ private:
office_element_ptr_array
content_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_shapes
);
}
...
...
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
View file @
691042c5
...
...
@@ -71,21 +71,40 @@ void table_data_pilot_table::add_attributes( const xml::attributes_wc_ptr & Attr
CP_APPLY_ATTR
(
L"table:grand-total"
,
table_grand_total_
);
CP_APPLY_ATTR
(
L"table:identify-categories"
,
table_identify_categories_
);
CP_APPLY_ATTR
(
L"table:ignore-empty-rows"
,
table_ignore_empty_rows_
);
CP_APPLY_ATTR
(
L"table:show-filter
button"
,
table_show_filter
button_
);
CP_APPLY_ATTR
(
L"table:show-filter
-button"
,
table_show_filter_
button_
);
CP_APPLY_ATTR
(
L"table:show-target-range-address"
,
table_show_target_range_address_
);
}
void
table_data_pilot_table
::
add_child_element
(
xml
::
sax
*
Reader
,
const
std
::
wstring
&
Ns
,
const
std
::
wstring
&
Name
)
{
CP_CREATE_ELEMENT
(
content_
);
if
(
L"table"
==
Ns
&&
L"data-pilot-field"
==
Name
)
CP_CREATE_ELEMENT
(
fields_
);
else
CP_CREATE_ELEMENT
(
source_
);
}
void
table_data_pilot_table
::
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
)
{
for
(
size_t
i
=
0
;
i
<
content_
.
size
();
i
++
)
{
content_
[
i
]
->
xlsx_convert
(
Context
);
}
if
(
!
source_
)
return
;
Context
.
get_pivots_context
().
start_table
();
source_
->
xlsx_convert
(
Context
);
for
(
size_t
i
=
0
;
i
<
fields_
.
size
();
i
++
)
{
fields_
[
i
]
->
xlsx_convert
(
Context
);
}
int
index_view
=
Context
.
get_pivots_context
().
end_table
();
if
(
index_view
>
0
)
{
Context
.
current_sheet
().
sheet_rels
().
add
(
oox
::
relationship
(
L"pvId"
+
std
::
to_wstring
(
index_view
),
L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/pivotTable"
,
L"../pivotTables/pivotTable"
+
std
::
to_wstring
(
index_view
)
+
L".xml"
));
}
}
//-------------------------------------------------------------------------------------------------
const
wchar_t
*
table_data_pilot_field
::
ns
=
L"table"
;
...
...
@@ -108,10 +127,14 @@ void table_data_pilot_field::add_child_element( xml::sax * Reader, const std::ws
}
void
table_data_pilot_field
::
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
)
{
for
(
size_t
i
=
0
;
i
<
content_
.
size
();
i
++
)
{
Context
.
get_pivots_context
().
start_field
();
for
(
size_t
i
=
0
;
i
<
content_
.
size
();
i
++
)
{
content_
[
i
]
->
xlsx_convert
(
Context
);
}
}
Context
.
get_pivots_context
().
end_field
();
}
//-------------------------------------------------------------------------------------------------
const
wchar_t
*
table_data_pilot_field_reference
::
ns
=
L"table"
;
...
...
@@ -120,8 +143,8 @@ const wchar_t * table_data_pilot_field_reference::name = L"data-pilot-field-refe
void
table_data_pilot_field_reference
::
add_attributes
(
const
xml
::
attributes_wc_ptr
&
Attributes
)
{
CP_APPLY_ATTR
(
L"table:field-name"
,
table_field_name_
);
CP_APPLY_ATTR
(
L"table:member
_
name"
,
table_member_name_
);
CP_APPLY_ATTR
(
L"table:member
_
type"
,
table_member_type_
);
CP_APPLY_ATTR
(
L"table:member
-
name"
,
table_member_name_
);
CP_APPLY_ATTR
(
L"table:member
-
type"
,
table_member_type_
);
CP_APPLY_ATTR
(
L"table:type"
,
table_type_
);
}
...
...
@@ -166,7 +189,7 @@ void table_database_source_sql::add_attributes( const xml::attributes_wc_ptr & A
{
CP_APPLY_ATTR
(
L"table:database-name"
,
table_database_name_
);
CP_APPLY_ATTR
(
L"table:parse-sql-statement"
,
table_parse_sql_statement_
);
CP_APPLY_ATTR
(
L"table:sql
statement"
,
table_sql_statement_
);
CP_APPLY_ATTR
(
L"table:sql
-statement"
,
table_sql_statement_
);
}
void
table_database_source_sql
::
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
)
...
...
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
View file @
691042c5
...
...
@@ -94,10 +94,11 @@ private:
_CP_OPT
(
odf_types
::
grand_total
)
table_grand_total_
;
_CP_OPT
(
odf_types
::
Bool
)
table_identify_categories_
;
_CP_OPT
(
odf_types
::
Bool
)
table_ignore_empty_rows_
;
_CP_OPT
(
odf_types
::
Bool
)
table_show_filterbutton_
;
_CP_OPT
(
odf_types
::
Bool
)
table_show_filter
_
button_
;
_CP_OPT
(
odf_types
::
Bool
)
table_show_target_range_address_
;
office_element_ptr_array
content_
;
office_element_ptr
source_
;
office_element_ptr_array
fields_
;
};
CP_REGISTER_OFFICE_ELEMENT2
(
table_data_pilot_table
);
...
...
ASCOfficeOdfFile/win32/cpodf.vcproj
View file @
691042c5
...
...
@@ -718,6 +718,14 @@
RelativePath=
"..\src\docx\xlsx_package.h"
>
</File>
<File
RelativePath=
"..\src\docx\xlsx_pivots_context.cpp"
>
</File>
<File
RelativePath=
"..\src\docx\xlsx_pivots_context.h"
>
</File>
<File
RelativePath=
"..\src\docx\xlsx_row_spanned.h"
>
...
...
ASCOfficeXlsFile2/source/XlsXlsxConverter/oox_package.h
View file @
691042c5
...
...
@@ -80,8 +80,10 @@ class content_types_file : public element
{
public:
content_types_file
();
virtual
void
write
(
const
std
::
wstring
&
RootPath
);
virtual
void
write
(
const
std
::
wstring
&
RootPath
);
content_type
&
get_content_type
()
{
return
content_type_
;
}
bool
add_or_find_default
(
const
std
::
wstring
&
extension
);
void
set_media
(
external_items
&
_Mediaitems
);
...
...
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.cpp
View file @
691042c5
...
...
@@ -184,10 +184,11 @@ void xl_files::write(const std::wstring & RootPath)
pivot_table_files_
.
set_main_document
(
get_main_document
());
pivot_table_files_
.
write
(
path
);
}
sheets_files_
.
set_rels
(
&
rels_files_
);
sheets_files_
.
set_main_document
(
this
->
get_main_document
()
);
sheets_files_
.
write
(
path
);
{
sheets_files_
.
set_rels
(
&
rels_files_
);
sheets_files_
.
set_main_document
(
this
->
get_main_document
()
);
sheets_files_
.
write
(
path
);
}
if
(
sharedStrings_
)
{
...
...
ASCOfficeXlsFile2/source/XlsXlsxConverter/xlsx_package.h
View file @
691042c5
...
...
@@ -47,9 +47,6 @@ public:
xlsx_content_types_file
();
};
//------------------------------------------------------------------------
class
sheet_content
;
typedef
_CP_PTR
(
sheet_content
)
sheet_content_ptr
;
class
sheet_content
:
boost
::
noncopyable
{
public:
...
...
@@ -65,10 +62,8 @@ private:
std
::
wstringstream
content_
;
rels_file_ptr
rels_
;
};
typedef
_CP_PTR
(
sheet_content
)
sheet_content_ptr
;
//------------------------------------------------------------------------
class
pivot_cache_content
;
typedef
_CP_PTR
(
pivot_cache_content
)
pivot_cache_content_ptr
;
class
pivot_cache_content
:
boost
::
noncopyable
{
public:
...
...
@@ -88,10 +83,8 @@ private:
std
::
wstringstream
definitions_
;
rels_file_ptr
definitions_rels_file_
;
};
typedef
_CP_PTR
(
pivot_cache_content
)
pivot_cache_content_ptr
;
//------------------------------------------------------------------------
class
pivot_table_content
;
typedef
_CP_PTR
(
pivot_table_content
)
pivot_table_content_ptr
;
class
pivot_table_content
:
boost
::
noncopyable
{
public:
...
...
@@ -108,6 +101,7 @@ private:
std
::
wstringstream
content_
;
rels_file_ptr
rels_file_
;
};
typedef
_CP_PTR
(
pivot_table_content
)
pivot_table_content_ptr
;
//------------------------------------------------------------------------
class
sheets_files
:
public
element
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment