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 ************************************************************************/
56 /*************************************************************************
58 * For LWP filter architecture prototype
59 ************************************************************************/
60 /*************************************************************************
63 ************************************************************************/
64 #include "lwpfribbreaks.hxx"
65 #include "lwpstory.hxx"
66 #include "xfilter/xfstylemanager.hxx"
67 #include "xfilter/xfsectionstyle.hxx"
68 #include "lwpsection.hxx"
69 #include "xfilter/xfsection.hxx"
70 #include "lwpglobalmgr.hxx"
72 void LwpFribColumnBreak::RegisterBreakStyle(LwpPara
* pPara
)
74 // XFParaStyle* pBaseStyle = static_cast<XFParaStyle*>(pFoundry->GetStyleManager()->GetStyle(styleID));
75 XFParaStyle
* pBaseStyle
= pPara
->GetXFParaStyle();
76 if (pBaseStyle
== NULL
) return;
77 // m_StyleName = pBaseStyle->GetStyleName();
79 XFParaStyle
* pOverStyle
= new XFParaStyle
;
80 *pOverStyle
= *pBaseStyle
;
81 pOverStyle
->SetStyleName(A2OUSTR(""));
84 //if (static_cast<LwpStory*>(pPara->GetStoryID()->obj())
85 // ->GetCurrentLayout()->GetNumCols() == 1)
87 LwpStory
* pStory
= static_cast<LwpStory
*>(pPara
->GetStoryID()->obj());
88 LwpPageLayout
* pCurLayout
= pStory
? pStory
->GetCurrentLayout() : NULL
;
89 if( pCurLayout
&& (pCurLayout
->GetNumCols() == 1) )
92 // if (!GetNext() || GetNext()->GetType()==FRIB_TAG_EOP)
93 pOverStyle
->SetBreaks(enumXFBreakBefPage
);
95 // pOverStyle->SetBreaks(enumXFBreakBefPage);
99 if (!GetNext() || GetNext()->GetType()==FRIB_TAG_EOP
)
100 pOverStyle
->SetBreaks(enumXFBreakAftColumn
);
102 pOverStyle
->SetBreaks(enumXFBreakBefColumn
);
104 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
105 m_StyleName
= pXFStyleManager
->AddStyle(pOverStyle
)->GetStyleName();
108 LwpFribPageBreak::LwpFribPageBreak( LwpPara
* pPara
)
109 : LwpFrib(pPara
), m_bLastFrib(sal_False
), m_pMasterPage(NULL
)
113 LwpFribPageBreak::~LwpFribPageBreak()
117 delete m_pMasterPage
;
118 m_pMasterPage
= NULL
;
122 void LwpFribPageBreak::Read(LwpObjectStream
* pObjStrm
, sal_uInt16
/*len*/)
124 m_Layout
.ReadIndexed(pObjStrm
);
128 void LwpFribPageBreak::RegisterBreakStyle(LwpPara
* pPara
)
130 XFParaStyle
* pBaseStyle
= pPara
->GetXFParaStyle();
131 if (pBaseStyle
== NULL
) return;
133 LwpPageLayout
* pLayout
= static_cast<LwpPageLayout
*>(m_Layout
.obj());
136 m_pMasterPage
= new LwpMasterPage(pPara
, pLayout
);
137 m_pMasterPage
->RegisterMasterPage(this);
141 XFParaStyle
* pOverStyle
= new XFParaStyle
;
142 *pOverStyle
= *pBaseStyle
;
143 pOverStyle
->SetStyleName(A2OUSTR(""));
144 pOverStyle
->SetMasterPage(pBaseStyle
->GetMasterPage());
146 if (!GetNext() || GetNext()->GetType()==FRIB_TAG_EOP
)
147 m_bLastFrib
= sal_True
;
149 m_bLastFrib
= sal_False
;
151 if (m_bLastFrib
== sal_True
)
152 pOverStyle
->SetBreaks(enumXFBreakAftPage
);
154 pOverStyle
->SetBreaks(enumXFBreakBefPage
);
156 XFStyleManager
* pXFStyleManager
= LwpGlobalMgr::GetInstance()->GetXFStyleManager();
157 m_StyleName
= pXFStyleManager
->AddStyle(pOverStyle
)->GetStyleName();
160 void LwpFribPageBreak::ParseLayout()
164 m_pMasterPage
->ParseSection(this);
168 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */