Branch data Line data Source code
1 : : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : : /*************************************************************************
3 : : *
4 : : * The Contents of this file are made available subject to the terms of
5 : : * either of the following licenses
6 : : *
7 : : * - GNU Lesser General Public License Version 2.1
8 : : * - Sun Industry Standards Source License Version 1.1
9 : : *
10 : : * Sun Microsystems Inc., October, 2000
11 : : *
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
16 : : *
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.
20 : : *
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.
25 : : *
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,
29 : : * MA 02111-1307 USA
30 : : *
31 : : *
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.
38 : : *
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.
45 : : *
46 : : * The Initial Developer of the Original Code is: IBM Corporation
47 : : *
48 : : * Copyright: 2008 by IBM Corporation
49 : : *
50 : : * All Rights Reserved.
51 : : *
52 : : * Contributor(s): _______________________________________
53 : : *
54 : : *
55 : : ************************************************************************/
56 : : /*************************************************************************
57 : : * @file
58 : : * Table object.
59 : : ************************************************************************/
60 : : #include "xfrow.hxx"
61 : : #include "xfcell.hxx"
62 : : #include "xftable.hxx"
63 : :
64 [ + - ]: 25 : XFRow::XFRow()
65 : : {
66 : 25 : m_nRepeat = 0;
67 : 25 : m_nRow = 0;
68 : 25 : }
69 : :
70 [ # # ]: 0 : XFRow::XFRow(const XFRow& other):XFContent(other)
71 : : {
72 : 0 : m_pOwnerTable = NULL;
73 : 0 : m_nRepeat = other.m_nRepeat;
74 : 0 : m_nRow = other.m_nRow;
75 : :
76 [ # # ]: 0 : for( int i=1; i<=other.GetCellCount(); i++ )
77 : : {
78 [ # # ][ # # ]: 0 : XFCell *pCell = new XFCell;
79 [ # # ][ # # ]: 0 : *pCell = *other.GetCell(i);
80 [ # # ]: 0 : AddCell(pCell);
81 : : }
82 : 0 : }
83 : :
84 : 0 : XFRow& XFRow::operator=(const XFRow& other)
85 : : {
86 : 0 : m_pOwnerTable = NULL;
87 : 0 : m_nRepeat = other.m_nRepeat;
88 : 0 : m_nRow = other.m_nRow;
89 : :
90 [ # # ]: 0 : for( int i=1; i<=other.GetCellCount(); i++ )
91 : : {
92 [ # # ]: 0 : XFCell *pCell = new XFCell;
93 : 0 : *pCell = *other.GetCell(i);
94 : 0 : AddCell(pCell);
95 : : }
96 : 0 : return *this;
97 : : }
98 : :
99 : :
100 : 25 : XFRow::~XFRow()
101 : : {
102 : 25 : std::map<sal_Int32,XFCell*>::iterator it;
103 [ + + ]: 125 : for( it=m_aCells.begin(); it!=m_aCells.end(); ++it )
104 : : {
105 : 100 : XFCell *pCell = (*it).second;
106 [ + - ]: 100 : if( pCell )
107 [ + - ][ + - ]: 100 : delete pCell;
108 : : }
109 [ - + ]: 50 : }
110 : :
111 : 100 : void XFRow::AddCell(XFCell *pCell)
112 : : {
113 [ + - ]: 100 : if( !pCell )
114 : 100 : return;
115 : : /* sal_Int32 col = pCell->GetCol();
116 : : if( col<1 )
117 : : {
118 : : pCell->SetCol(m_aCells.size()+1);
119 : : }
120 : :
121 : : col = pCell->GetCol();
122 : : if( m_aCells.find(col) != m_aCells.end() )
123 : : delete m_aCells[col];
124 : : */
125 : 100 : sal_Int32 col = m_aCells.size()+1;
126 : 100 : pCell->SetCol(col);
127 : 100 : pCell->SetOwnerRow(this);
128 [ + - ]: 100 : m_aCells[col]=pCell;
129 : : }
130 : :
131 : 0 : sal_Int32 XFRow::GetCellCount() const
132 : : {
133 : 0 : return m_aCells.size();
134 : : }
135 : :
136 : 0 : XFCell* XFRow::GetCell(sal_Int32 col) const
137 : : {
138 [ # # ][ # # ]: 0 : if( m_aCells.find(col) == m_aCells.end() )
139 : 0 : return NULL;
140 : : else
141 : 0 : return m_aCells.find(col)->second;
142 : : }
143 : :
144 : 25 : void XFRow::ToXml(IXFStream *pStrm)
145 : : {
146 : 25 : sal_Int32 lastCol = 0;
147 [ + - ]: 25 : IXFAttrList *pAttrList = pStrm->GetAttrList();
148 : :
149 [ + - ]: 25 : pAttrList->Clear();
150 [ + - ][ + - ]: 25 : if( !GetStyleName().isEmpty() )
151 [ + - ][ + - ]: 25 : pAttrList->AddAttribute( A2OUSTR("table:style-name"), GetStyleName() );
152 [ - + ]: 25 : if( m_nRepeat )
153 [ # # ][ # # ]: 0 : pAttrList->AddAttribute( A2OUSTR("table:number-rows-repeated"), Int32ToOUString(m_nRepeat) );
154 [ + - ]: 25 : pStrm->StartElement( A2OUSTR("table:table-row") );
155 : :
156 : 25 : std::map<sal_Int32,XFCell*>::iterator it = m_aCells.begin();
157 [ + + ]: 125 : for( ; it!=m_aCells.end(); ++it )
158 : : {
159 : 100 : int col = (*it).first;
160 : 100 : XFCell *pCell = (*it).second;
161 [ - + ]: 100 : if( !pCell )
162 : 0 : continue;
163 [ - + ]: 100 : if( col>lastCol+1 )
164 : : {
165 [ # # ][ # # ]: 0 : XFCell *pNULLCell = new XFCell();
166 [ # # ]: 0 : if( col>lastCol+2 )
167 : 0 : pNULLCell->SetRepeated(col-lastCol-1);
168 [ # # ]: 0 : pNULLCell->ToXml(pStrm);
169 : : }
170 [ + - ]: 100 : pCell->ToXml(pStrm);
171 : 100 : lastCol = col;
172 : : }
173 : :
174 [ + - ]: 25 : pStrm->EndElement( A2OUSTR("table:table-row") );
175 : 25 : }
176 : : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|