1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*************************************************************************
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
10 * Sun Microsystems Inc., October, 2000
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
46 * The Initial Developer of the Original Code is: IBM Corporation
48 * Copyright: 2008 by IBM Corporation
50 * All Rights Reserved.
52 * Contributor(s): _______________________________________
55 ************************************************************************/
57 #include "lwpfribtable.hxx"
58 #include "lwppara.hxx"
59 #include "lwptablelayout.hxx"
60 #include <lwpchangemgr.hxx>
61 #include <lwpglobalmgr.hxx>
62 #include <xfilter/xfstylemanager.hxx>
63 #include <xfilter/xfchange.hxx>
66 * @short: Read table frib
68 void LwpFribTable::Read(LwpObjectStream
* pObjStrm
, sal_uInt16
/*len*/)
70 m_objTable
.ReadIndexed(pObjStrm
);
73 LwpSuperTableLayout
* LwpFribTable::GetSuperTable()
75 return dynamic_cast<LwpSuperTableLayout
*>(m_objTable
.obj().get());
78 void LwpFribTable::RegisterNewStyle()
80 LwpSuperTableLayout
* pSuper
= GetSuperTable();
82 pSuper
->RegisterNewStyle();
83 XFParaStyle
* pOldStyle
= m_pPara
->GetXFParaStyle();
86 if (pOldStyle
->GetMasterPage().isEmpty())
87 m_StyleName
= pOldStyle
->GetStyleName();
90 std::unique_ptr
<XFParaStyle
> xParaStyle(new XFParaStyle
);
91 *xParaStyle
= *pOldStyle
;
92 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
93 m_StyleName
= pXFStyleManager
->AddStyle(std::move(xParaStyle
)).m_pStyle
->GetStyleName();
98 void LwpFribTable::XFConvert(XFContentContainer
* pCont
)
100 XFContentContainer
* pXFContentContainer
= pCont
;
101 LwpSuperTableLayout
* pSuper
= GetSuperTable();
104 sal_uInt8 nType
= pSuper
->GetRelativeType();
105 rtl::Reference
<LwpVirtualLayout
> xContainer(pSuper
->GetContainerLayout());
106 if (!xContainer
.is())
108 if (LwpLayoutRelativityGuts::LAY_INLINE_NEWLINE
== nType
&& !xContainer
->IsCell())
110 pXFContentContainer
= m_pPara
->GetXFContainer();
111 //delete the additional blank para
112 XFParagraph
* pCurrPara
= m_pPara
->GetFribs().GetXFPara();
113 if (pXFContentContainer
&& !pCurrPara
->HasContents())
115 if (pXFContentContainer
->GetLastContent() == pCurrPara
)
117 pXFContentContainer
->RemoveLastContent();
121 else if (LwpLayoutRelativityGuts::LAY_PARA_RELATIVE
== nType
)
123 //same page as text and in frame
124 if (xContainer
->IsFrame())
126 pXFContentContainer
= m_pPara
->GetXFContainer();
128 else if (xContainer
->IsCell())
130 //same page as text and in cell, get the first xfpara
131 rtl::Reference
<XFContent
> first(pCont
->FindFirstContent(enumXFContentPara
));
132 XFContentContainer
* pXFFirtPara
= static_cast<XFContentContainer
*>(first
.get());
134 pXFContentContainer
= pXFFirtPara
;
140 LwpGlobalMgr
* pGlobal
= LwpGlobalMgr::GetInstance();
141 LwpChangeMgr
* pChangeMgr
= pGlobal
->GetLwpChangeMgr();
142 sChangeID
= pChangeMgr
->GetChangeID(this);
143 if (!sChangeID
.isEmpty() && pXFContentContainer
)
145 rtl::Reference
<XFChangeStart
> xChangeStart(new XFChangeStart
);
146 xChangeStart
->SetChangeID(sChangeID
);
147 pXFContentContainer
->Add(xChangeStart
.get());
151 if (pXFContentContainer
)
152 pSuper
->XFConvert(pXFContentContainer
);
156 if (!sChangeID
.isEmpty() && pXFContentContainer
)
158 rtl::Reference
<XFChangeEnd
> xChangeEnd(new XFChangeEnd
);
159 xChangeEnd
->SetChangeID(sChangeID
);
160 pXFContentContainer
->Add(xChangeEnd
.get());
164 if (LwpLayoutRelativityGuts::LAY_INLINE_NEWLINE
== nType
&& HasNextFrib())
166 rtl::Reference
<XFParagraph
> xXFPara(new XFParagraph
);
167 xXFPara
->SetStyleName(m_StyleName
);
168 m_pPara
->AddXFContent(xXFPara
.get());
169 m_pPara
->GetFribs().SetXFPara(xXFPara
.get());
173 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */