xref: /aoo4110/main/sc/source/core/data/dbdocutl.cxx (revision b1cdbd2c)
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