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 5 : XFRow::XFRow()
65 : : m_pOwnerTable(NULL)
66 : , m_nRepeat(0)
67 5 : , m_nRow(0)
68 : {
69 5 : }
70 :
71 0 : XFRow::XFRow(const XFRow& other):XFContent(other)
72 : {
73 0 : m_pOwnerTable = NULL;
74 0 : m_nRepeat = other.m_nRepeat;
75 0 : m_nRow = other.m_nRow;
76 :
77 0 : for( int i=1; i<=other.GetCellCount(); i++ )
78 : {
79 0 : XFCell *pCell = new XFCell;
80 0 : *pCell = *other.GetCell(i);
81 0 : AddCell(pCell);
82 : }
83 0 : }
84 :
85 0 : XFRow& XFRow::operator=(const XFRow& other)
86 : {
87 0 : m_pOwnerTable = NULL;
88 0 : m_nRepeat = other.m_nRepeat;
89 0 : m_nRow = other.m_nRow;
90 :
91 0 : for( int i=1; i<=other.GetCellCount(); i++ )
92 : {
93 0 : XFCell *pCell = new XFCell;
94 0 : *pCell = *other.GetCell(i);
95 0 : AddCell(pCell);
96 : }
97 0 : return *this;
98 : }
99 :
100 15 : XFRow::~XFRow()
101 : {
102 5 : std::map<sal_Int32,XFCell*>::iterator it;
103 25 : for( it=m_aCells.begin(); it!=m_aCells.end(); ++it )
104 : {
105 20 : XFCell *pCell = (*it).second;
106 20 : if( pCell )
107 20 : delete pCell;
108 : }
109 10 : }
110 :
111 20 : void XFRow::AddCell(XFCell *pCell)
112 : {
113 20 : if( !pCell )
114 20 : 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 20 : sal_Int32 col = m_aCells.size()+1;
126 20 : pCell->SetCol(col);
127 20 : pCell->SetOwnerRow(this);
128 20 : 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 5 : void XFRow::ToXml(IXFStream *pStrm)
145 : {
146 5 : sal_Int32 lastCol = 0;
147 5 : IXFAttrList *pAttrList = pStrm->GetAttrList();
148 :
149 5 : pAttrList->Clear();
150 5 : if( !GetStyleName().isEmpty() )
151 5 : pAttrList->AddAttribute( "table:style-name", GetStyleName() );
152 5 : if( m_nRepeat )
153 0 : pAttrList->AddAttribute( "table:number-rows-repeated", OUString::number(m_nRepeat) );
154 5 : pStrm->StartElement( "table:table-row" );
155 :
156 5 : std::map<sal_Int32,XFCell*>::iterator it = m_aCells.begin();
157 25 : for( ; it!=m_aCells.end(); ++it )
158 : {
159 20 : int col = (*it).first;
160 20 : XFCell *pCell = (*it).second;
161 20 : if( !pCell )
162 0 : continue;
163 20 : 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 20 : pCell->ToXml(pStrm);
171 20 : lastCol = col;
172 : }
173 :
174 5 : pStrm->EndElement( "table:table-row" );
175 5 : }
176 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|