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
47c1e6f6
Commit
47c1e6f6
authored
Aug 14, 2017
by
Alexey Golubev
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'develop' of github.com:ONLYOFFICE/core into develop
parents
d465e29a
f5284c96
Changes
25
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
25 changed files
with
919 additions
and
53 deletions
+919
-53
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
+96
-2
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
+1
-1
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
+6
-5
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
+1
-1
ASCOfficePPTXFile/Editor/BinaryFileReaderWriter.cpp
ASCOfficePPTXFile/Editor/BinaryFileReaderWriter.cpp
+2
-1
ASCOfficePPTXFile/PPTXFormat/FileFactory.cpp
ASCOfficePPTXFile/PPTXFormat/FileFactory.cpp
+1
-0
ASCOfficePPTXFile/PPTXFormat/Logic/Pic.cpp
ASCOfficePPTXFile/PPTXFormat/Logic/Pic.cpp
+1
-0
Common/DocxFormat/Projects/DocxFormat2005.vcproj
Common/DocxFormat/Projects/DocxFormat2005.vcproj
+10
-2
Common/DocxFormat/Source/DocxFormat/Docx.h
Common/DocxFormat/Source/DocxFormat/Docx.h
+1
-0
Common/DocxFormat/Source/DocxFormat/FileFactory.cpp
Common/DocxFormat/Source/DocxFormat/FileFactory.cpp
+18
-0
Common/DocxFormat/Source/DocxFormat/FileTypes.h
Common/DocxFormat/Source/DocxFormat/FileTypes.h
+16
-0
Common/DocxFormat/Source/DocxFormat/Footnote.h
Common/DocxFormat/Source/DocxFormat/Footnote.h
+1
-8
Common/DocxFormat/Source/DocxFormat/IFileContainer.cpp
Common/DocxFormat/Source/DocxFormat/IFileContainer.cpp
+17
-1
Common/DocxFormat/Source/DocxFormat/IFileContainer.h
Common/DocxFormat/Source/DocxFormat/IFileContainer.h
+4
-0
Common/DocxFormat/Source/DocxFormat/Logic/SectionProperty.h
Common/DocxFormat/Source/DocxFormat/Logic/SectionProperty.h
+2
-3
Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h
Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h
+239
-0
Common/DocxFormat/Source/DocxFormat/Media/VbaProject.h
Common/DocxFormat/Source/DocxFormat/Media/VbaProject.h
+76
-0
Common/DocxFormat/Source/DocxFormat/WritingElement.h
Common/DocxFormat/Source/DocxFormat/WritingElement.h
+5
-1
Common/DocxFormat/Source/XlsxFormat/Controls/Controls.h
Common/DocxFormat/Source/XlsxFormat/Controls/Controls.h
+395
-0
Common/DocxFormat/Source/XlsxFormat/FileFactory_Spreadsheet.cpp
.../DocxFormat/Source/XlsxFormat/FileFactory_Spreadsheet.cpp
+8
-1
Common/DocxFormat/Source/XlsxFormat/Ole/OleObjects.h
Common/DocxFormat/Source/XlsxFormat/Ole/OleObjects.h
+8
-8
Common/DocxFormat/Source/XlsxFormat/Workbook.h
Common/DocxFormat/Source/XlsxFormat/Workbook.h
+2
-11
Common/DocxFormat/Source/XlsxFormat/Worksheets/ConditionalFormatting.h
...rmat/Source/XlsxFormat/Worksheets/ConditionalFormatting.h
+0
-2
Common/DocxFormat/Source/XlsxFormat/Worksheets/Worksheet.h
Common/DocxFormat/Source/XlsxFormat/Worksheets/Worksheet.h
+7
-5
XlsxSerializerCom/Reader/BinaryWriter.h
XlsxSerializerCom/Reader/BinaryWriter.h
+2
-1
No files found.
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.cpp
View file @
47c1e6f6
...
...
@@ -78,6 +78,7 @@ public:
std
::
wstring
name
;
std
::
wstring
location_ref
;
std
::
wstring
source_ref
;
std
::
wstring
source_table_name
;
std
::
vector
<
_field
>
fields
;
std
::
vector
<
int
>
row_fields
;
std
::
vector
<
int
>
page_fields
;
...
...
@@ -86,6 +87,7 @@ public:
}
current_
;
void
serialize_view
(
std
::
wostream
&
strm
);
void
serialize_cache
(
std
::
wostream
&
strm
);
};
xlsx_pivots_context
::
xlsx_pivots_context
()
:
impl_
(
new
xlsx_pivots_context
::
Impl
())
...
...
@@ -217,6 +219,96 @@ void xlsx_pivots_context::Impl::serialize_view(std::wostream & strm)
}
}
void
xlsx_pivots_context
::
Impl
::
serialize_cache
(
std
::
wostream
&
strm
)
{
CP_XML_WRITER
(
strm
)
{
CP_XML_NODE
(
L"pivotCacheDefinition"
)
{
CP_XML_ATTR
(
L"xmlns"
,
L"http://schemas.openxmlformats.org/spreadsheetml/2006/main"
);
CP_XML_ATTR
(
L"xmlns:r"
,
L"http://schemas.openxmlformats.org/officeDocument/2006/relationships"
);
//{ records file
// CP_XML_ATTR(L"r:id", L"rId1" );
//}
CP_XML_ATTR
(
L"enableRefresh"
,
1
);
//CP_XML_ATTR(L"refreshedBy", db->rgb.value());
//CP_XML_ATTR(L"refreshedDate", db_ex->numDate.data.value);
CP_XML_ATTR
(
L"recordCount"
,
0
);
//createdVersion="1"
//refreshedVersion="2"
//upgradeOnRefresh="1">
if
(
true
)
{
CP_XML_NODE
(
L"cacheSource"
)
{
CP_XML_ATTR
(
L"type"
,
L"worksheet"
);
CP_XML_NODE
(
L"worksheetSource"
)
{
CP_XML_ATTR
(
L"ref"
,
current_
.
source_ref
);
CP_XML_ATTR
(
L"sheet"
,
current_
.
source_table_name
);
}
}
}
if
(
current_
.
fields
.
empty
()
==
false
)
{
CP_XML_NODE
(
L"cacheFields"
)
{
CP_XML_ATTR
(
L"count"
,
current_
.
fields
.
size
());
for
(
size_t
i
=
0
;
i
<
current_
.
fields
.
size
();
i
++
)
{
CP_XML_NODE
(
L"cacheField"
)
{
CP_XML_ATTR
(
L"name"
,
current_
.
fields
[
i
].
name
);
CP_XML_ATTR
(
L"numFmtId"
,
0
);
if
(
current_
.
fields
[
i
].
caches
.
empty
()
==
false
)
{
CP_XML_NODE
(
L"sharedItems"
)
{
CP_XML_ATTR
(
L"count"
,
current_
.
fields
[
i
].
caches
.
size
());
//CP_XML_ATTR(L"containsSemiMixedTypes", );
CP_XML_ATTR
(
L"containsNonDate"
,
1
);
CP_XML_ATTR
(
L"containsDate"
,
0
);
CP_XML_ATTR
(
L"containsBlank"
,
0
);
//CP_XML_ATTR(L"containsString", );
for
(
size_t
j
=
0
;
j
<
current_
.
fields
[
i
].
caches
.
size
();
j
++
)
{
std
::
wstring
node_name
=
L"s"
;
//switch(current_.fields[i].caches[j].type)
//{
//}
CP_XML_NODE
(
node_name
)
{
CP_XML_ATTR
(
L"v"
,
current_
.
fields
[
i
].
caches
[
j
]);
}
}
}
}
}
}
}
}
//if (pivot_cache->m_arSXFORMULA.empty() == false)
//{
// CP_XML_NODE(L"calculatedItems")
// {
// CP_XML_ATTR(L"count", pivot_cache->m_arSXFORMULA.size());
// for (size_t i = 0; i < pivot_cache->m_arSXFORMULA.size(); i++)
// {
// pivot_cache->m_arSXFORMULA[i]->serialize(CP_XML_STREAM());
// }
// }
//}
}
}
}
int
xlsx_pivots_context
::
get_count
()
{
return
(
int
)
impl_
->
pivot_xmls_
.
size
();
...
...
@@ -278,6 +370,7 @@ int xlsx_pivots_context::end_table()
std
::
wstringstream
rec_strm
;
impl_
->
serialize_view
(
view_strm
);
impl_
->
serialize_cache
(
cache_strm
);
Impl
::
_pivot_xml
v
=
{
cache_strm
.
str
(),
rec_strm
.
str
(),
view_strm
.
str
()};
...
...
@@ -340,9 +433,10 @@ void xlsx_pivots_context::end_field()
{
}
void
xlsx_pivots_context
::
set_source_range
(
std
::
wstring
ref
)
void
xlsx_pivots_context
::
set_source_range
(
std
::
wstring
table_name
,
std
::
wstring
ref
)
{
impl_
->
current_
.
source_ref
=
ref
;
impl_
->
current_
.
source_table_name
=
table_name
;
impl_
->
current_
.
source_ref
=
ref
;
}
void
xlsx_pivots_context
::
add_connections
(
std
::
wstring
connections
)
...
...
ASCOfficeOdfFile/src/docx/xlsx_pivots_context.h
View file @
47c1e6f6
...
...
@@ -63,7 +63,7 @@ public:
void
set_view_name
(
std
::
wstring
name
);
void
set_view_target_range
(
std
::
wstring
ref
);
void
set_source_range
(
std
::
wstring
ref
);
void
set_source_range
(
std
::
wstring
table_name
,
std
::
wstring
ref
);
void
write_cache_definitions_to
(
int
index
,
std
::
wostream
&
strm
);
void
write_cache_records_to
(
int
index
,
std
::
wostream
&
strm
);
...
...
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.cpp
View file @
47c1e6f6
...
...
@@ -93,6 +93,8 @@ void table_data_pilot_table::xlsx_convert(oox::xlsx_conversion_context & Context
Context
.
get_pivots_context
().
start_table
();
source_
->
xlsx_convert
(
Context
);
if
(
table_name_
)
Context
.
get_pivots_context
().
set_view_name
(
*
table_name_
);
if
(
table_target_range_address_
)
{
...
...
@@ -106,7 +108,6 @@ void table_data_pilot_table::xlsx_convert(oox::xlsx_conversion_context & Context
Context
.
get_pivots_context
().
set_view_target_range
(
ref
);
//Context.get_pivots_context().set_view_target_table(table_index);
}
source_
->
xlsx_convert
(
Context
);
for
(
size_t
i
=
0
;
i
<
fields_
.
size
();
i
++
)
{
...
...
@@ -239,7 +240,7 @@ const wchar_t * table_source_cell_range::name = L"source-cell-range";
void
table_source_cell_range
::
add_attributes
(
const
xml
::
attributes_wc_ptr
&
Attributes
)
{
CP_APPLY_ATTR
(
L"table:cell
range-address"
,
table_cell
range_address_
);
CP_APPLY_ATTR
(
L"table:cell
-range-address"
,
table_cell_
range_address_
);
}
void
table_source_cell_range
::
add_child_element
(
xml
::
sax
*
Reader
,
const
std
::
wstring
&
Ns
,
const
std
::
wstring
&
Name
)
...
...
@@ -248,14 +249,14 @@ void table_source_cell_range::add_child_element( xml::sax * Reader, const std::w
}
void
table_source_cell_range
::
xlsx_convert
(
oox
::
xlsx_conversion_context
&
Context
)
{
if
(
table_cellrange_address_
)
if
(
table_cell
_
range_address_
)
{
formulasconvert
::
odf2oox_converter
formulas_converter
;
std
::
wstring
ref
=
formulas_converter
.
convert_named_ref
(
*
table_cellrange_address_
,
false
);
std
::
wstring
ref
=
formulas_converter
.
convert_named_ref
(
*
table_cell
_
range_address_
,
false
);
std
::
wstring
table_name
=
formulas_converter
.
get_table_name
();
Context
.
get_pivots_context
().
set_source_range
(
ref
);
Context
.
get_pivots_context
().
set_source_range
(
table_name
,
ref
);
}
}
//-------------------------------------------------------------------------------------------------
...
...
ASCOfficeOdfFile/src/odf/table_data_pilot_tables.h
View file @
47c1e6f6
...
...
@@ -247,7 +247,7 @@ private:
virtual
void
add_child_element
(
xml
::
sax
*
Reader
,
const
std
::
wstring
&
Ns
,
const
std
::
wstring
&
Name
);
public:
_CP_OPT
(
std
::
wstring
)
table_cellrange_address_
;
_CP_OPT
(
std
::
wstring
)
table_cell
_
range_address_
;
office_element_ptr_array
content_
;
//filters
};
...
...
ASCOfficePPTXFile/Editor/BinaryFileReaderWriter.cpp
View file @
47c1e6f6
...
...
@@ -36,8 +36,9 @@
#include "../../Common/DocxFormat/Source/DocxFormat/WritingElement.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/OleObject.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/A
udio
.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/A
ctiveX
.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/Video.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/Audio.h"
#include "../../Common/Base64.h"
...
...
ASCOfficePPTXFile/PPTXFormat/FileFactory.cpp
View file @
47c1e6f6
...
...
@@ -62,6 +62,7 @@
#include "../../Common/DocxFormat/Source/DocxFormat/Media/Audio.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/Video.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/OleObject.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h"
#include "../../Common/DocxFormat/Source/DocxFormat/External/HyperLink.h"
#include "../../Common/DocxFormat/Source/DocxFormat/External/ExternalImage.h"
#include "../../Common/DocxFormat/Source/DocxFormat/External/ExternalAudio.h"
...
...
ASCOfficePPTXFile/PPTXFormat/Logic/Pic.cpp
View file @
47c1e6f6
...
...
@@ -44,6 +44,7 @@
#include "../../../Common/DocxFormat/Source/DocxFormat/Media/Audio.h"
#include "../../../Common/DocxFormat/Source/DocxFormat/Media/Video.h"
#include "../../../Common/DocxFormat/Source/DocxFormat/Media/OleObject.h"
#include "../../../Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h"
#include "../../../Common/DocxFormat/Source/MathEquation/MathEquation.h"
...
...
Common/DocxFormat/Projects/DocxFormat2005.vcproj
View file @
47c1e6f6
...
...
@@ -1183,6 +1183,10 @@
<Filter
Name=
"Media"
>
<File
RelativePath=
"..\Source\DocxFormat\Media\ActiveX.h"
>
</File>
<File
RelativePath=
"..\Source\DocxFormat\Media\Audio.h"
>
...
...
@@ -1514,6 +1518,10 @@
RelativePath=
"..\Source\XlsxFormat\Drawing\CellAnchor.h"
>
</File>
<File
RelativePath=
"..\Source\XlsxFormat\Controls\Controls.h"
>
</File>
<File
RelativePath=
"..\Source\XlsxFormat\Drawing\Drawing.h"
>
...
...
@@ -1523,11 +1531,11 @@
>
</File>
<File
RelativePath=
"..\Source\XlsxFormat\
Ole\oleobject
s.h"
RelativePath=
"..\Source\XlsxFormat\
Drawing\Po
s.h"
>
</File>
<File
RelativePath=
"..\Source\
XlsxFormat\Drawing\Pos
.h"
RelativePath=
"..\Source\
DocxFormat\Media\VbaProject
.h"
>
</File>
</Filter>
...
...
Common/DocxFormat/Source/DocxFormat/Docx.h
View file @
47c1e6f6
...
...
@@ -52,6 +52,7 @@
#include "External/HyperLink.h"
#include "Media/Image.h"
#include "Media/OleObject.h"
#include "Media/ActiveX.h"
#include "HeaderFooter.h"
#include "../../../../ASCOfficePPTXFile/PPTXFormat/Theme.h"
...
...
Common/DocxFormat/Source/DocxFormat/FileFactory.cpp
View file @
47c1e6f6
...
...
@@ -44,9 +44,11 @@
#include "Footnote.h"
#include "Endnote.h"
#include "Media/Image.h"
#include "Media/ActiveX.h"
#include "Media/OleObject.h"
#include "Media/Audio.h"
#include "Media/Video.h"
#include "Media/VbaProject.h"
#include "External/HyperLink.h"
#include "External/ExternalVideo.h"
#include "External/ExternalAudio.h"
...
...
@@ -136,6 +138,14 @@ namespace OOX
return
smart_ptr
<
OOX
::
File
>
(
new
CVmlDrawing
(
oRootPath
,
oFileName
));
else
if
(
oRelation
.
Type
()
==
OOX
::
FileTypes
::
Chart
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
Spreadsheet
::
CChartSpace
(
oRootPath
,
oFileName
));
else
if
(
oRelation
.
Type
()
==
OOX
::
FileTypes
::
ActiveX_xml
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
ActiveX_xml
(
oRootPath
,
oFileName
));
else
if
(
oRelation
.
Type
()
==
OOX
::
FileTypes
::
ActiveX_bin
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
ActiveX_bin
(
oFileName
));
else
if
(
oRelation
.
Type
()
==
OOX
::
FileTypes
::
VbaProject
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
VbaProject
(
oRootPath
,
oFileName
));
//else if ( oRelation.Type() == OOX::FileTypes::VbaData)
// return smart_ptr<OOX::File>(new OOX::VbaData( oFileName ));
return
smart_ptr
<
OOX
::
File
>
(
new
UnknowTypeFile
()
);
}
...
...
@@ -220,6 +230,14 @@ namespace OOX
return
smart_ptr
<
OOX
::
File
>
(
new
OleObject
(
oFileName
,
true
));
else
if
(
pRelation
->
Type
()
==
OOX
::
FileTypes
::
Chart
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
Spreadsheet
::
CChartSpace
(
oRootPath
,
oFileName
));
else
if
(
pRelation
->
Type
()
==
FileTypes
::
ActiveX_xml
)
return
smart_ptr
<
OOX
::
File
>
(
new
ActiveX_xml
(
oRootPath
,
oFileName
));
else
if
(
pRelation
->
Type
()
==
FileTypes
::
ActiveX_bin
)
return
smart_ptr
<
OOX
::
File
>
(
new
ActiveX_bin
(
oFileName
));
else
if
(
pRelation
->
Type
()
==
FileTypes
::
VbaProject
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
VbaProject
(
oRootPath
,
oFileName
));
//else if ( pRelation->Type() == FileTypes::VbaData)
// return smart_ptr<OOX::File>(new OOX::VbaData( oFileName ));
return
smart_ptr
<
OOX
::
File
>
(
new
UnknowTypeFile
()
);
}
...
...
Common/DocxFormat/Source/DocxFormat/FileTypes.h
View file @
47c1e6f6
...
...
@@ -172,6 +172,22 @@ namespace OOX
_T
(
"application/vnd.openxmlformats-officedocument.drawingml.chart+xml"
),
_T
(
"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart"
),
true
,
true
);
const
FileType
ActiveX_xml
(
L"activeX"
,
L""
,
_T
(
"application/vnd.ms-office.activeX+xml"
),
_T
(
"http://schemas.openxmlformats.org/officeDocument/2006/relationships/control"
));
const
FileType
ActiveX_bin
(
L"activeX"
,
L""
,
_T
(
"application/vnd.ms-office.activeX"
),
_T
(
"http://schemas.microsoft.com/office/2006/relationships/activeXControlBinary"
));
const
FileType
VbaProject
(
L""
,
L"vbaProject.bin"
,
_T
(
"application/vnd.ms-office.vbaProject"
),
_T
(
"http://schemas.microsoft.com/office/2006/relationships/vbaProject"
));
const
FileType
VbaData
(
L""
,
L"vbaData.xml"
,
_T
(
"application/vnd.ms-word.vbaData+xml"
),
_T
(
"http://schemas.microsoft.com/office/2006/relationships/wordVbaData"
));
const
FileType
MicrosoftOfficeUnknown
(
L"embeddings"
,
L""
,
_T
(
""
),
_T
(
"http://schemas.openxmlformats.org/officeDocument/2006/relationships/package"
));
...
...
Common/DocxFormat/Source/DocxFormat/Footnote.h
View file @
47c1e6f6
...
...
@@ -64,8 +64,6 @@ namespace OOX
m_arrFootnote
.
clear
();
}
public:
virtual
void
read
(
const
CPath
&
oPath
)
{
//don't use this. use read(const CPath& oRootPath, const CPath& oFilePath)
...
...
@@ -118,8 +116,6 @@ namespace OOX
oContent
.
Registration
(
type
().
OverrideType
(),
oDirectory
,
oPath
);
IFileContainer
::
Write
(
oPath
,
oDirectory
,
oContent
);
}
public:
virtual
const
OOX
::
FileType
type
()
const
{
return
FileTypes
::
FootNote
;
...
...
@@ -133,8 +129,6 @@ namespace OOX
return
type
().
DefaultFileName
();
}
public:
OOX
::
CFtnEdn
*
Find
(
const
OOX
::
Logic
::
CFootnoteReference
&
oReference
)
const
{
if
(
!
oReference
.
m_oId
.
IsInit
()
)
...
...
@@ -157,10 +151,9 @@ namespace OOX
return
(
unsigned
int
)
m_arrFootnote
.
size
();
}
public:
CPath
m_oReadPath
;
std
::
vector
<
OOX
::
CFtnEdn
*>
m_arrFootnote
;
std
::
vector
<
std
::
wstring
>
m_arrShapeTypes
;
std
::
vector
<
std
::
wstring
>
m_arrShapeTypes
;
};
}
// namespace OOX
...
...
Common/DocxFormat/Source/DocxFormat/IFileContainer.cpp
View file @
47c1e6f6
...
...
@@ -41,6 +41,8 @@
#include "External/HyperLink.h"
#include "Media/Image.h"
#include "Media/OleObject.h"
#include "Media/ActiveX.h"
#include "../../../../ASCOfficePPTXFile/PPTXFormat/LegacyDiagramText.h"
#include "../XlsxFormat/FileFactory_Spreadsheet.h"
...
...
@@ -259,7 +261,21 @@ namespace OOX
return
smart_ptr
<
HyperLink
>
();
return
pPair
->
second
.
smart_dynamic_cast
<
HyperLink
>
();
}
smart_ptr
<
ActiveX_xml
>
IFileContainer
::
GetActiveX_xml
(
const
RId
&
rId
)
const
{
std
::
map
<
std
::
wstring
,
smart_ptr
<
OOX
::
File
>>::
const_iterator
pPair
=
m_mContainer
.
find
(
rId
.
get
());
if
(
pPair
==
m_mContainer
.
end
())
return
smart_ptr
<
ActiveX_xml
>
();
return
pPair
->
second
.
smart_dynamic_cast
<
ActiveX_xml
>
();
}
smart_ptr
<
ActiveX_bin
>
IFileContainer
::
GetActiveX_bin
(
const
RId
&
rId
)
const
{
std
::
map
<
std
::
wstring
,
smart_ptr
<
OOX
::
File
>>::
const_iterator
pPair
=
m_mContainer
.
find
(
rId
.
get
());
if
(
pPair
==
m_mContainer
.
end
())
return
smart_ptr
<
ActiveX_bin
>
();
return
pPair
->
second
.
smart_dynamic_cast
<
ActiveX_bin
>
();
}
smart_ptr
<
OleObject
>
IFileContainer
::
GetOleObject
(
const
RId
&
rId
)
const
{
std
::
map
<
std
::
wstring
,
smart_ptr
<
OOX
::
File
>>::
const_iterator
pPair
=
m_mContainer
.
find
(
rId
.
get
());
...
...
Common/DocxFormat/Source/DocxFormat/IFileContainer.h
View file @
47c1e6f6
...
...
@@ -48,6 +48,8 @@ namespace OOX
class
Image
;
class
HyperLink
;
class
OleObject
;
class
ActiveX_xml
;
class
ActiveX_bin
;
}
namespace
PPTX
...
...
@@ -85,6 +87,8 @@ namespace OOX
virtual
smart_ptr
<
Image
>
GetImage
(
const
RId
&
rId
)
const
;
virtual
smart_ptr
<
HyperLink
>
GetHyperlink
(
const
RId
&
rId
)
const
;
virtual
smart_ptr
<
OleObject
>
GetOleObject
(
const
RId
&
rId
)
const
;
virtual
smart_ptr
<
ActiveX_xml
>
GetActiveX_xml
(
const
RId
&
rId
)
const
;
virtual
smart_ptr
<
ActiveX_bin
>
GetActiveX_bin
(
const
RId
&
rId
)
const
;
virtual
smart_ptr
<
PPTX
::
LegacyDiagramText
>
GetLegacyDiagramText
(
const
OOX
::
RId
&
rId
)
const
;
OOX
::
CRels
*
GetCurRls
()
...
...
Common/DocxFormat/Source/DocxFormat/Logic/SectionProperty.h
View file @
47c1e6f6
...
...
@@ -227,10 +227,9 @@ namespace ComplexTypes
void
ReadAttributes
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
// Читаем атрибуты
WritingElement_ReadAttributes_Start
(
oReader
)
WritingElement_ReadAttributes_Read_if
(
oReader
,
(
L"r:id"
),
m_oId
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
(
L"w:type"
),
m_oType
)
WritingElement_ReadAttributes_Read_if
(
oReader
,
(
L"r:id"
),
m_oId
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
(
L"w:type"
),
m_oType
)
WritingElement_ReadAttributes_End
(
oReader
)
}
...
...
Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h
0 → 100644
View file @
47c1e6f6
/*
* (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
#ifndef OOX_ACTIVEX_INCLUDE_H_
#define OOX_ACTIVEX_INCLUDE_H_
#include "Media.h"
#include "../../XlsxFormat/FileTypes_Spreadsheet.h"
#include "../../Common/SimpleTypes_Shared.h"
#include "../IFileContainer.h"
namespace
OOX
{
class
COcxPr
:
public
WritingElement
{
public:
WritingElement_AdditionConstructors
(
COcxPr
)
COcxPr
()
{
}
virtual
~
COcxPr
()
{
}
virtual
void
fromXML
(
XmlUtils
::
CXmlNode
&
node
)
{
}
virtual
std
::
wstring
toXML
()
const
{
return
_T
(
""
);
}
virtual
void
toXML
(
NSStringUtils
::
CStringBuilder
&
writer
)
const
{
writer
.
WriteString
(
_T
(
"<ocxPr>"
));
writer
.
WriteString
(
_T
(
"</ocxPr>"
));
}
virtual
void
fromXML
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
ReadAttributes
(
oReader
);
if
(
!
oReader
.
IsEmptyNode
()
)
oReader
.
ReadTillEnd
();
}
virtual
EElementType
getType
()
const
{
return
et_x_OcxPr
;
}
void
ReadAttributes
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
WritingElement_ReadAttributes_Start
(
oReader
)
WritingElement_ReadAttributes_Read_if
(
oReader
,
_T
(
"ax:name"
)
,
m_oName
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
_T
(
"ax:value"
)
,
m_oValue
)
WritingElement_ReadAttributes_End
(
oReader
)
}
nullable
<
std
::
wstring
>
m_oName
;
nullable
<
std
::
wstring
>
m_oValue
;
//font
//picture
};
class
ActiveX_xml
:
public
File
,
public
OOX
::
IFileContainer
{
public:
ActiveX_xml
()
{
m_bDocument
=
false
;
}
ActiveX_xml
(
const
CPath
&
oRootPath
,
const
CPath
&
filename
)
{
m_bDocument
=
false
;
read
(
oRootPath
,
filename
);
}
virtual
~
ActiveX_xml
()
{
ClearItems
();
}
void
ClearItems
()
{
for
(
size_t
nIndex
=
0
;
nIndex
<
m_arrOcxPr
.
size
();
++
nIndex
)
{
delete
m_arrOcxPr
[
nIndex
];
}
m_arrOcxPr
.
clear
();
}
virtual
void
read
(
const
CPath
&
oPath
)
{
CPath
oRootPath
;
read
(
oRootPath
,
oPath
);
}
virtual
void
read
(
const
CPath
&
oRootPath
,
const
CPath
&
oPath
)
{
m_oReadPath
=
oPath
;
IFileContainer
::
Read
(
oRootPath
,
oPath
);
XmlUtils
::
CXmlLiteReader
oReader
;
if
(
!
oReader
.
FromFile
(
oPath
.
GetPath
()
)
)
return
;
if
(
!
oReader
.
ReadNextNode
()
)
return
;
std
::
wstring
sName
=
XmlUtils
::
GetNameNoNS
(
oReader
.
GetName
());
if
(
_T
(
"ocx"
)
==
sName
)
{
ReadAttributes
(
oReader
);
if
(
!
oReader
.
IsEmptyNode
()
)
{
int
nDocumentDepth
=
oReader
.
GetDepth
();
while
(
oReader
.
ReadNextSiblingNode
(
nDocumentDepth
)
)
{
sName
=
XmlUtils
::
GetNameNoNS
(
oReader
.
GetName
());
if
(
_T
(
"ocxPr"
)
==
sName
)
{
COcxPr
*
pOcxPr
=
new
COcxPr
(
oReader
);
m_arrOcxPr
.
push_back
(
pOcxPr
);
}
}
}
}
}
void
ReadAttributes
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
WritingElement_ReadAttributes_Start
(
oReader
)
WritingElement_ReadAttributes_Read_if
(
oReader
,
L"ax:classid"
,
m_oClassId
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
L"ax:persistence"
,
m_oPersistence
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
L"r:id"
,
m_oId
)
WritingElement_ReadAttributes_Read_else_if
(
oReader
,
L"ax:license"
,
m_oLicense
)
WritingElement_ReadAttributes_End
(
oReader
)
}
virtual
void
write
(
const
OOX
::
CPath
&
filename
,
const
OOX
::
CPath
&
directory
,
CContentTypes
&
content
)
const
{
}
virtual
const
FileType
type
()
const
{
return
OOX
::
FileTypes
::
ActiveX_xml
;
}
virtual
const
CPath
DefaultDirectory
()
const
{
if
(
m_bDocument
)
return
type
().
DefaultDirectory
();
else
return
L"../"
+
type
().
DefaultDirectory
();
}
virtual
const
CPath
DefaultFileName
()
const
{
return
type
().
DefaultFileName
();
}
bool
m_bDocument
;
protected:
CPath
m_oReadPath
;
nullable
<
std
::
wstring
>
m_oClassId
;
nullable
<
std
::
wstring
>
m_oLicense
;
nullable
<
std
::
wstring
>
m_oPersistence
;
//(§3.6.2.1, ST_Persistence).
nullable
<
SimpleTypes
::
CRelationshipId
>
m_oId
;
std
::
vector
<
OOX
::
COcxPr
*>
m_arrOcxPr
;
};
class
ActiveX_bin
:
public
Media
{
public:
ActiveX_bin
(
bool
bDocument
=
true
)
:
Media
(
bDocument
)
{
}
ActiveX_bin
(
const
OOX
::
CPath
&
filename
)
{
read
(
filename
);
}
virtual
void
write
(
const
OOX
::
CPath
&
filename
,
const
OOX
::
CPath
&
directory
,
CContentTypes
&
content
)
const
{
}
virtual
const
FileType
type
()
const
{
return
OOX
::
FileTypes
::
ActiveX_bin
;
}
virtual
const
CPath
DefaultDirectory
()
const
{
if
(
m_bDocument
)
return
type
().
DefaultDirectory
();
else
return
L"../"
+
type
().
DefaultDirectory
();
}
virtual
const
CPath
DefaultFileName
()
const
{
return
m_filename
.
GetFilename
();
}
void
set_filename_cache
(
const
std
::
wstring
&
file_path
)
{
m_filenameCache
=
file_path
;
}
void
set_filename_cache
(
CPath
&
file_path
)
{
m_filenameCache
=
file_path
;
}
CPath
filename_cache
()
{
return
m_filenameCache
;
}
protected:
CPath
m_filenameCache
;
//image
};
}
// namespace OOX
#endif // OOX_ACTIVEX_INCLUDE_H_
Common/DocxFormat/Source/DocxFormat/Media/VbaProject.h
0 → 100644
View file @
47c1e6f6
/*
* (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
#ifndef OOX_VBA_PROJECT_INCLUDE_H_
#define OOX_VBA_PROJECT_INCLUDE_H_
#include "Media.h"
#include "../../XlsxFormat/FileTypes_Spreadsheet.h"
namespace
OOX
{
class
VbaProject
:
public
Media
,
public
OOX
::
IFileContainer
{
public:
VbaProject
(
)
{
}
VbaProject
(
const
CPath
&
oRootPath
,
const
CPath
&
filename
)
{
read
(
oRootPath
,
filename
);
}
virtual
void
read
(
const
CPath
&
oRootPath
,
const
CPath
&
oPath
)
{
IFileContainer
::
Read
(
oRootPath
,
oPath
);
Media
::
read
(
oPath
);
}
virtual
void
write
(
const
OOX
::
CPath
&
filename
,
const
OOX
::
CPath
&
directory
,
CContentTypes
&
content
)
const
{
}
virtual
const
FileType
type
()
const
{
return
OOX
::
FileTypes
::
VbaProject
;
}
virtual
const
CPath
DefaultDirectory
()
const
{
return
type
().
DefaultDirectory
();
}
virtual
const
CPath
DefaultFileName
()
const
{
return
m_filename
.
GetFilename
();
}
protected:
};
}
// namespace OOX
#endif // OOX_VBA_PROJECT_INCLUDE_H_
Common/DocxFormat/Source/DocxFormat/WritingElement.h
View file @
47c1e6f6
...
...
@@ -1063,7 +1063,11 @@ namespace OOX
et_x_OleObjects
,
et_x_OleObject
,
et_x_OleObjectPr
,
et_x_OleObjectAnchor
,
et_x_ExtAnchor
,
et_x_Controls
,
et_x_Control
,
et_x_ControlPr
,
et_x_OcxPr
,
et_x_TableParts
,
et_x_TablePart
,
et_x_Table
,
...
...
Common/DocxFormat/Source/XlsxFormat/Controls/Controls.h
0 → 100644
View file @
47c1e6f6
This diff is collapsed.
Click to expand it.
Common/DocxFormat/Source/XlsxFormat/FileFactory_Spreadsheet.cpp
View file @
47c1e6f6
...
...
@@ -36,7 +36,8 @@
#include "../../../../ASCOfficePPTXFile/PPTXFormat/Theme.h"
#include "../DocxFormat/VmlDrawing.h"
#include "../DocxFormat/Media/OleObject.h"
#include "../DocxFormat/Media/ActiveX.h"
#include "../DocxFormat/Media/VbaProject.h"
#include "SharedStrings/SharedStrings.h"
#include "Styles/Styles.h"
...
...
@@ -177,6 +178,12 @@ namespace OOX
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
CDiagramDrawing
(
oRootPath
,
oFileName
));
else
if
(
pRelation
->
Type
()
==
OOX
::
FileTypes
::
MicrosoftOfficeUnknown
)
//ms package
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
OleObject
(
oFileName
,
true
));
else
if
(
pRelation
->
Type
()
==
OOX
::
FileTypes
::
ActiveX_xml
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
ActiveX_xml
(
oRootPath
,
oFileName
));
else
if
(
pRelation
->
Type
()
==
OOX
::
FileTypes
::
ActiveX_bin
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
ActiveX_bin
(
oFileName
));
else
if
(
pRelation
->
Type
()
==
OOX
::
FileTypes
::
VbaProject
)
return
smart_ptr
<
OOX
::
File
>
(
new
OOX
::
VbaProject
(
oRootPath
,
oFileName
));
return
smart_ptr
<
OOX
::
File
>
(
new
UnknowTypeFile
()
);
}
...
...
Common/DocxFormat/Source/XlsxFormat/Ole/OleObjects.h
View file @
47c1e6f6
...
...
@@ -40,14 +40,14 @@ namespace OOX
{
namespace
Spreadsheet
{
class
C
OleObjec
tAnchor
:
public
WritingElement
class
C
Ex
tAnchor
:
public
WritingElement
{
public:
WritingElement_AdditionConstructors
(
C
OleObjec
tAnchor
)
C
OleObjec
tAnchor
()
WritingElement_AdditionConstructors
(
C
Ex
tAnchor
)
C
Ex
tAnchor
()
{
}
virtual
~
C
OleObjec
tAnchor
()
virtual
~
C
Ex
tAnchor
()
{
}
...
...
@@ -100,7 +100,7 @@ namespace OOX
virtual
EElementType
getType
()
const
{
return
et_x_
OleObjec
tAnchor
;
return
et_x_
Ex
tAnchor
;
}
private:
...
...
@@ -219,7 +219,7 @@ namespace OOX
nullable
<
SimpleTypes
::
COnOff
<>>
m_oPrint
;
nullable
<
SimpleTypes
::
COnOff
<>>
m_oUiObject
;
nullable
<
C
OleObjec
tAnchor
>
m_oAnchor
;
nullable
<
C
Ex
tAnchor
>
m_oAnchor
;
};
class
COleObject
:
public
WritingElement
...
...
@@ -255,7 +255,7 @@ namespace OOX
toXML2
(
writer
,
true
);
}
}
virtual
void
toXML2
(
NSStringUtils
::
CStringBuilder
&
writer
,
bool
ObjectPr
)
const
virtual
void
toXML2
(
NSStringUtils
::
CStringBuilder
&
writer
,
bool
b
ObjectPr
)
const
{
writer
.
WriteString
(
L"<oleObject"
);
WritingStringNullableAttrEncodeXmlString
(
L"progId"
,
m_oProgId
,
m_oProgId
.
get
());
...
...
@@ -265,7 +265,7 @@ namespace OOX
WritingStringNullableAttrBool
(
L"autoLoad"
,
m_oAutoLoad
);
WritingStringNullableAttrInt
(
L"shapeId"
,
m_oShapeId
,
m_oShapeId
->
GetValue
());
WritingStringNullableAttrString
(
L"r:id"
,
m_oRid
,
m_oRid
->
ToString
());
if
(
ObjectPr
&&
m_oObjectPr
.
IsInit
())
if
(
b
ObjectPr
&&
m_oObjectPr
.
IsInit
())
{
writer
.
WriteString
(
L">"
);
m_oObjectPr
->
toXML
(
writer
);
...
...
Common/DocxFormat/Source/XlsxFormat/Workbook.h
View file @
47c1e6f6
...
...
@@ -53,8 +53,6 @@ namespace OOX
virtual
~
CWorkbook
()
{
}
public:
virtual
void
read
(
const
CPath
&
oPath
)
{
}
...
...
@@ -77,26 +75,19 @@ namespace OOX
{
return
m_oReadPath
;
}
public:
void
ClearItems
()
{
}
std
::
vector
<
WritingElement
*>
m_arrItems
;
private:
CPath
m_oReadPath
;
CPath
m_oReadPath
;
void
ReadAttributes
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
// Читаем атрибуты
WritingElement_ReadAttributes_Start
(
oReader
)
WritingElement_ReadAttributes_ReadSingle
(
oReader
,
_T
(
"w:conformance"
),
m_oConformance
)
WritingElement_ReadAttributes_End
(
oReader
)
}
public:
std
::
vector
<
WritingElement
*>
m_arrItems
;
};
}
//Spreadsheet
}
// namespace OOX
...
...
Common/DocxFormat/Source/XlsxFormat/Worksheets/ConditionalFormatting.h
View file @
47c1e6f6
...
...
@@ -225,7 +225,6 @@ namespace OOX
void
ReadAttributes
(
XmlUtils
::
CXmlLiteReader
&
oReader
)
{
// Читаем атрибуты
WritingElement_ReadAttributes_Start
(
oReader
)
WritingElement_ReadAttributes_Read_if
(
oReader
,
_T
(
"maxLength"
)
,
m_oMaxLength
)
...
...
@@ -279,7 +278,6 @@ namespace OOX
return
et_x_FormulaCF
;
}
public:
std
::
wstring
m_sText
;
};
...
...
Common/DocxFormat/Source/XlsxFormat/Worksheets/Worksheet.h
View file @
47c1e6f6
...
...
@@ -51,6 +51,8 @@
#include "../Table/Table.h"
#include "../Comments/Comments.h"
#include "../Ole/OleObjects.h"
#include "../Controls/Controls.h"
#include "../../../../../DesktopEditor/common/String.h"
namespace
OOX
...
...
@@ -60,12 +62,10 @@ namespace OOX
//необработанные child:
//<cellWatches>
//<colBreaks>
//<controls>
//<customProperties>
//<dataConsolidate>
//<dataValidations>
//<extLst>
//<oleObjects>
//<phoneticPr>
//<protectedRanges>
//<rowBreaks>
...
...
@@ -92,8 +92,6 @@ namespace OOX
{
ClearItems
();
}
public:
virtual
void
read
(
const
CPath
&
oPath
)
{
//don't use this. instead use read(const CPath& oRootPath, const CPath& oFilePath)
...
...
@@ -157,6 +155,8 @@ namespace OOX
m_oLegacyDrawingHF
=
oReader
;
else
if
(
_T
(
"oleObjects"
)
==
sName
)
m_oOleObjects
=
oReader
;
else
if
(
_T
(
"controls"
)
==
sName
)
m_oControls
=
oReader
;
else
if
(
_T
(
"headerFooter"
)
==
sName
)
m_oHeaderFooter
=
oReader
;
else
if
(
_T
(
"sheetPr"
)
==
sName
)
...
...
@@ -379,6 +379,8 @@ namespace OOX
m_oLegacyDrawingHF
->
toXML
(
sXml
);
if
(
m_oOleObjects
.
IsInit
())
m_oOleObjects
->
toXML
(
sXml
);
if
(
m_oControls
.
IsInit
())
m_oControls
->
toXML
(
sXml
);
if
(
m_oTableParts
.
IsInit
())
m_oTableParts
->
toXML
(
sXml
);
if
(
m_oExtLst
.
IsInit
())
...
...
@@ -441,7 +443,6 @@ namespace OOX
}
m_arrConditionalFormatting
.
clear
();
}
private:
CPath
m_oReadPath
;
public:
...
...
@@ -460,6 +461,7 @@ namespace OOX
nullable
<
OOX
::
Spreadsheet
::
CTableParts
>
m_oTableParts
;
nullable
<
OOX
::
Spreadsheet
::
CLegacyDrawingWorksheet
>
m_oLegacyDrawing
;
nullable
<
OOX
::
Spreadsheet
::
COleObjects
>
m_oOleObjects
;
nullable
<
OOX
::
Spreadsheet
::
CControls
>
m_oControls
;
std
::
map
<
std
::
wstring
,
CCommentItem
*>
m_mapComments
;
std
::
vector
<
OOX
::
Spreadsheet
::
CConditionalFormatting
*>
m_arrConditionalFormatting
;
nullable
<
OOX
::
Spreadsheet
::
CSheetPr
>
m_oSheetPr
;
...
...
XlsxSerializerCom/Reader/BinaryWriter.h
View file @
47c1e6f6
...
...
@@ -37,6 +37,7 @@
#include "../../Common/DocxFormat/Source/SystemUtility/SystemUtility.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/OleObject.h"
#include "../../Common/DocxFormat/Source/DocxFormat/Media/ActiveX.h"
#include "../../Common/OfficeFileFormats.h"
#include "../../Common/Base64.h"
...
...
@@ -2959,7 +2960,7 @@ namespace BinXlsxRW
bool
bSetAnchor
=
false
;
if
(
pOleObject
->
m_oObjectPr
.
IsInit
()
&&
pOleObject
->
m_oObjectPr
->
m_oAnchor
.
IsInit
()
&&
pOleObject
->
m_oObjectPr
->
m_oRid
.
IsInit
())
{
const
OOX
::
Spreadsheet
::
C
OleObjec
tAnchor
&
oAnchor
=
pOleObject
->
m_oObjectPr
->
m_oAnchor
.
get
();
const
OOX
::
Spreadsheet
::
C
Ex
tAnchor
&
oAnchor
=
pOleObject
->
m_oObjectPr
->
m_oAnchor
.
get
();
SimpleTypes
::
Spreadsheet
::
CCellAnchorType
<>
eAnchorType
;
eAnchorType
.
SetValue
(
SimpleTypes
::
Spreadsheet
::
cellanchorTwoCell
);
...
...
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