1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_sc.hxx"
26*b1cdbd2cSJim Jagielski
27*b1cdbd2cSJim Jagielski
28*b1cdbd2cSJim Jagielski
29*b1cdbd2cSJim Jagielski // INCLUDE ---------------------------------------------------------------
30*b1cdbd2cSJim Jagielski
31*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/DataType.hpp>
32*b1cdbd2cSJim Jagielski #include <com/sun/star/sdbc/XRow.hpp>
33*b1cdbd2cSJim Jagielski
34*b1cdbd2cSJim Jagielski #include <svl/zforlist.hxx>
35*b1cdbd2cSJim Jagielski
36*b1cdbd2cSJim Jagielski #include "dbdocutl.hxx"
37*b1cdbd2cSJim Jagielski #include "document.hxx"
38*b1cdbd2cSJim Jagielski #include "cell.hxx"
39*b1cdbd2cSJim Jagielski #include "formula/errorcodes.hxx"
40*b1cdbd2cSJim Jagielski
41*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
42*b1cdbd2cSJim Jagielski
43*b1cdbd2cSJim Jagielski #define D_TIMEFACTOR 86400.0
44*b1cdbd2cSJim Jagielski
45*b1cdbd2cSJim Jagielski // -----------------------------------------------------------------------
46*b1cdbd2cSJim Jagielski
47*b1cdbd2cSJim Jagielski // static
PutData(ScDocument * pDoc,SCCOL nCol,SCROW nRow,SCTAB nTab,const uno::Reference<sdbc::XRow> & xRow,long nRowPos,long nType,sal_Bool bCurrency,sal_Bool * pSimpleFlag)48*b1cdbd2cSJim Jagielski void ScDatabaseDocUtil::PutData( ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB nTab,
49*b1cdbd2cSJim Jagielski const uno::Reference<sdbc::XRow>& xRow, long nRowPos,
50*b1cdbd2cSJim Jagielski long nType, sal_Bool bCurrency, sal_Bool* pSimpleFlag )
51*b1cdbd2cSJim Jagielski {
52*b1cdbd2cSJim Jagielski String aString;
53*b1cdbd2cSJim Jagielski double nVal = 0.0;
54*b1cdbd2cSJim Jagielski sal_Bool bValue = sal_False;
55*b1cdbd2cSJim Jagielski sal_Bool bEmptyFlag = sal_False;
56*b1cdbd2cSJim Jagielski sal_Bool bError = sal_False;
57*b1cdbd2cSJim Jagielski sal_uLong nFormatIndex = 0;
58*b1cdbd2cSJim Jagielski
59*b1cdbd2cSJim Jagielski //! wasNull calls only if null value was found?
60*b1cdbd2cSJim Jagielski
61*b1cdbd2cSJim Jagielski try
62*b1cdbd2cSJim Jagielski {
63*b1cdbd2cSJim Jagielski switch ( nType )
64*b1cdbd2cSJim Jagielski {
65*b1cdbd2cSJim Jagielski case sdbc::DataType::BIT:
66*b1cdbd2cSJim Jagielski case sdbc::DataType::BOOLEAN:
67*b1cdbd2cSJim Jagielski //! use language from doc (here, date/time and currency)?
68*b1cdbd2cSJim Jagielski nFormatIndex = pDoc->GetFormatTable()->GetStandardFormat(
69*b1cdbd2cSJim Jagielski NUMBERFORMAT_LOGICAL, ScGlobal::eLnge );
70*b1cdbd2cSJim Jagielski nVal = (xRow->getBoolean(nRowPos) ? 1 : 0);
71*b1cdbd2cSJim Jagielski bEmptyFlag = ( nVal == 0.0 ) && xRow->wasNull();
72*b1cdbd2cSJim Jagielski bValue = sal_True;
73*b1cdbd2cSJim Jagielski break;
74*b1cdbd2cSJim Jagielski
75*b1cdbd2cSJim Jagielski case sdbc::DataType::TINYINT:
76*b1cdbd2cSJim Jagielski case sdbc::DataType::SMALLINT:
77*b1cdbd2cSJim Jagielski case sdbc::DataType::INTEGER:
78*b1cdbd2cSJim Jagielski case sdbc::DataType::BIGINT:
79*b1cdbd2cSJim Jagielski case sdbc::DataType::FLOAT:
80*b1cdbd2cSJim Jagielski case sdbc::DataType::REAL:
81*b1cdbd2cSJim Jagielski case sdbc::DataType::DOUBLE:
82*b1cdbd2cSJim Jagielski case sdbc::DataType::NUMERIC:
83*b1cdbd2cSJim Jagielski case sdbc::DataType::DECIMAL:
84*b1cdbd2cSJim Jagielski //! do the conversion here?
85*b1cdbd2cSJim Jagielski nVal = xRow->getDouble(nRowPos);
86*b1cdbd2cSJim Jagielski bEmptyFlag = ( nVal == 0.0 ) && xRow->wasNull();
87*b1cdbd2cSJim Jagielski bValue = sal_True;
88*b1cdbd2cSJim Jagielski break;
89*b1cdbd2cSJim Jagielski
90*b1cdbd2cSJim Jagielski case sdbc::DataType::CHAR:
91*b1cdbd2cSJim Jagielski case sdbc::DataType::VARCHAR:
92*b1cdbd2cSJim Jagielski case sdbc::DataType::LONGVARCHAR:
93*b1cdbd2cSJim Jagielski aString = xRow->getString(nRowPos);
94*b1cdbd2cSJim Jagielski bEmptyFlag = ( aString.Len() == 0 ) && xRow->wasNull();
95*b1cdbd2cSJim Jagielski break;
96*b1cdbd2cSJim Jagielski
97*b1cdbd2cSJim Jagielski case sdbc::DataType::DATE:
98*b1cdbd2cSJim Jagielski {
99*b1cdbd2cSJim Jagielski SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
100*b1cdbd2cSJim Jagielski nFormatIndex = pFormTable->GetStandardFormat(
101*b1cdbd2cSJim Jagielski NUMBERFORMAT_DATE, ScGlobal::eLnge );
102*b1cdbd2cSJim Jagielski
103*b1cdbd2cSJim Jagielski util::Date aDate = xRow->getDate(nRowPos);
104*b1cdbd2cSJim Jagielski nVal = Date( aDate.Day, aDate.Month, aDate.Year ) -
105*b1cdbd2cSJim Jagielski *pFormTable->GetNullDate();
106*b1cdbd2cSJim Jagielski bEmptyFlag = xRow->wasNull();
107*b1cdbd2cSJim Jagielski bValue = sal_True;
108*b1cdbd2cSJim Jagielski }
109*b1cdbd2cSJim Jagielski break;
110*b1cdbd2cSJim Jagielski
111*b1cdbd2cSJim Jagielski case sdbc::DataType::TIME:
112*b1cdbd2cSJim Jagielski {
113*b1cdbd2cSJim Jagielski SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
114*b1cdbd2cSJim Jagielski nFormatIndex = pFormTable->GetStandardFormat(
115*b1cdbd2cSJim Jagielski NUMBERFORMAT_TIME, ScGlobal::eLnge );
116*b1cdbd2cSJim Jagielski
117*b1cdbd2cSJim Jagielski util::Time aTime = xRow->getTime(nRowPos);
118*b1cdbd2cSJim Jagielski nVal = ( aTime.Hours * 3600 + aTime.Minutes * 60 +
119*b1cdbd2cSJim Jagielski aTime.Seconds + aTime.HundredthSeconds / 100.0 ) / D_TIMEFACTOR;
120*b1cdbd2cSJim Jagielski bEmptyFlag = xRow->wasNull();
121*b1cdbd2cSJim Jagielski bValue = sal_True;
122*b1cdbd2cSJim Jagielski }
123*b1cdbd2cSJim Jagielski break;
124*b1cdbd2cSJim Jagielski
125*b1cdbd2cSJim Jagielski case sdbc::DataType::TIMESTAMP:
126*b1cdbd2cSJim Jagielski {
127*b1cdbd2cSJim Jagielski SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
128*b1cdbd2cSJim Jagielski nFormatIndex = pFormTable->GetStandardFormat(
129*b1cdbd2cSJim Jagielski NUMBERFORMAT_DATETIME, ScGlobal::eLnge );
130*b1cdbd2cSJim Jagielski
131*b1cdbd2cSJim Jagielski util::DateTime aStamp = xRow->getTimestamp(nRowPos);
132*b1cdbd2cSJim Jagielski nVal = ( Date( aStamp.Day, aStamp.Month, aStamp.Year ) -
133*b1cdbd2cSJim Jagielski *pFormTable->GetNullDate() ) +
134*b1cdbd2cSJim Jagielski ( aStamp.Hours * 3600 + aStamp.Minutes * 60 +
135*b1cdbd2cSJim Jagielski aStamp.Seconds + aStamp.HundredthSeconds / 100.0 ) / D_TIMEFACTOR;
136*b1cdbd2cSJim Jagielski bEmptyFlag = xRow->wasNull();
137*b1cdbd2cSJim Jagielski bValue = sal_True;
138*b1cdbd2cSJim Jagielski }
139*b1cdbd2cSJim Jagielski break;
140*b1cdbd2cSJim Jagielski
141*b1cdbd2cSJim Jagielski case sdbc::DataType::SQLNULL:
142*b1cdbd2cSJim Jagielski bEmptyFlag = sal_True;
143*b1cdbd2cSJim Jagielski break;
144*b1cdbd2cSJim Jagielski
145*b1cdbd2cSJim Jagielski case sdbc::DataType::BINARY:
146*b1cdbd2cSJim Jagielski case sdbc::DataType::VARBINARY:
147*b1cdbd2cSJim Jagielski case sdbc::DataType::LONGVARBINARY:
148*b1cdbd2cSJim Jagielski default:
149*b1cdbd2cSJim Jagielski bError = sal_True; // unknown type
150*b1cdbd2cSJim Jagielski }
151*b1cdbd2cSJim Jagielski }
152*b1cdbd2cSJim Jagielski catch ( uno::Exception& )
153*b1cdbd2cSJim Jagielski {
154*b1cdbd2cSJim Jagielski bError = sal_True;
155*b1cdbd2cSJim Jagielski }
156*b1cdbd2cSJim Jagielski
157*b1cdbd2cSJim Jagielski if ( bValue && bCurrency )
158*b1cdbd2cSJim Jagielski nFormatIndex = pDoc->GetFormatTable()->GetStandardFormat(
159*b1cdbd2cSJim Jagielski NUMBERFORMAT_CURRENCY, ScGlobal::eLnge );
160*b1cdbd2cSJim Jagielski
161*b1cdbd2cSJim Jagielski ScBaseCell* pCell;
162*b1cdbd2cSJim Jagielski if (bEmptyFlag)
163*b1cdbd2cSJim Jagielski {
164*b1cdbd2cSJim Jagielski pCell = NULL;
165*b1cdbd2cSJim Jagielski pDoc->PutCell( nCol, nRow, nTab, pCell );
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski else if (bError)
168*b1cdbd2cSJim Jagielski {
169*b1cdbd2cSJim Jagielski pDoc->SetError( nCol, nRow, nTab, NOTAVAILABLE );
170*b1cdbd2cSJim Jagielski }
171*b1cdbd2cSJim Jagielski else if (bValue)
172*b1cdbd2cSJim Jagielski {
173*b1cdbd2cSJim Jagielski pCell = new ScValueCell( nVal );
174*b1cdbd2cSJim Jagielski if (nFormatIndex == 0)
175*b1cdbd2cSJim Jagielski pDoc->PutCell( nCol, nRow, nTab, pCell );
176*b1cdbd2cSJim Jagielski else
177*b1cdbd2cSJim Jagielski pDoc->PutCell( nCol, nRow, nTab, pCell, nFormatIndex );
178*b1cdbd2cSJim Jagielski }
179*b1cdbd2cSJim Jagielski else
180*b1cdbd2cSJim Jagielski {
181*b1cdbd2cSJim Jagielski if (aString.Len())
182*b1cdbd2cSJim Jagielski {
183*b1cdbd2cSJim Jagielski pCell = ScBaseCell::CreateTextCell( aString, pDoc );
184*b1cdbd2cSJim Jagielski if ( pSimpleFlag && pCell->GetCellType() == CELLTYPE_EDIT )
185*b1cdbd2cSJim Jagielski *pSimpleFlag = sal_False;
186*b1cdbd2cSJim Jagielski }
187*b1cdbd2cSJim Jagielski else
188*b1cdbd2cSJim Jagielski pCell = NULL;
189*b1cdbd2cSJim Jagielski pDoc->PutCell( nCol, nRow, nTab, pCell );
190*b1cdbd2cSJim Jagielski }
191*b1cdbd2cSJim Jagielski }
192*b1cdbd2cSJim Jagielski
193*b1cdbd2cSJim Jagielski
194