2010-10-12 15:59:00 +02:00
|
|
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
|
2000-10-26 17:56:42 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
2008-04-10 18:21:26 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2000-10-26 17:56:42 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
#include <com/sun/star/sdbc/DataType.hpp>
|
|
|
|
#include <com/sun/star/sdbc/XRow.hpp>
|
|
|
|
|
2009-10-16 00:05:16 +02:00
|
|
|
#include <svl/zforlist.hxx>
|
2000-10-26 17:56:42 +00:00
|
|
|
|
|
|
|
#include "dbdocutl.hxx"
|
|
|
|
#include "document.hxx"
|
|
|
|
#include "cell.hxx"
|
CWS-TOOLING: integrate CWS frmdlg
2008-12-18 09:13:09 +0100 oj r265667 : merge from odff05
2008-12-18 07:58:16 +0100 oj r265658 : #i94555# patch from <regina>, ODFF:
Add GAMMA, CHISQDIST, CHISQINV.
Make the 'cumulative' parameter of GAMMADIST optional.
Adapt the domain of CHIDIST to allow negative x.
Remove the constraint "degrees of freedom < 1.0E5" from CHIDIST and CHIINV.
Plus a mechanism to write the now optional parameter of GAMMADIST to PODF and
ODFF if omitted, for backwards compatibility.
2008-12-15 14:06:11 +0100 oj r265490 : CWS-TOOLING: rebase CWS frmdlg to trunk@264807 (milestone: DEV300:m37)
2008-12-15 13:55:28 +0100 oj r265488 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:55:07 +0100 oj r265487 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:54:48 +0100 oj r265486 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:54:36 +0100 oj r265485 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:54:24 +0100 oj r265484 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:48:11 +0100 oj r265483 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:31:12 +0100 oj r265479 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:13:58 +0100 oj r265477 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:10:09 +0100 oj r265476 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 13:05:11 +0100 oj r265475 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 10:47:17 +0100 oj r265467 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 10:46:19 +0100 oj r265466 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 10:45:47 +0100 oj r265465 : CWS-TOOLING: do not delete this file, it's needed for 'cws rebase -C'
CWS: frmdlg
New MWS: DEV300
New milestone: m37
2008-12-15 07:35:07 +0100 oj r265458 : add dependency to formula
2008-12-15 07:34:24 +0100 oj r265457 : add dependency to formula
2008-12-12 13:22:00 +0100 msc r265413 : #i97089#
2008-12-12 13:20:25 +0100 msc r265412 : #i97089#
2008-12-12 12:35:12 +0100 msc r265406 : #i97089#
2008-12-12 12:34:16 +0100 msc r265405 : #i97089#
2008-12-12 12:33:05 +0100 msc r265404 : #i97089#
2008-12-12 12:31:11 +0100 msc r265403 : #i97089#
2008-12-08 11:59:10 +0100 oj r264981 : insert RTL_LOG
2008-12-08 11:50:17 +0100 oj r264980 : some small changes
2008-12-05 12:57:57 +0100 oj r264902 : eof changed
2008-12-05 12:56:46 +0100 oj r264901 : eof changed
2008-12-05 12:28:47 +0100 oj r264899 : wrong var used
2008-12-05 10:08:57 +0100 oj r264890 : token order reversed
2008-12-04 13:49:22 +0100 oc r264843 : #i96688: Adapt autotests because of outsourced functionwizard
2008-12-04 13:45:27 +0100 oc r264842 : #i96688: Adapt autotests because of outsourced functionwizard
2008-12-04 13:42:54 +0100 oc r264841 : #i96688: Adapt autotests because of outsourced functionwizard
2008-12-04 13:37:41 +0100 oc r264840 : #i96688: Adapt autotests because of outsourced functionwizard
2008-12-04 13:34:11 +0100 oc r264839 : #i96688: Adapt autotests because of outsourced functionwizard
2008-12-04 12:35:31 +0100 oj r264835 : new help ids for struct and function tabpage
2008-12-04 12:00:35 +0100 oj r264828 : set explicit help id
2008-12-03 14:53:27 +0100 oj r264786 : #i96845# change ref button
2008-12-03 14:51:49 +0100 oj r264785 : #i96845# change ref button
2008-12-03 08:51:57 +0100 oj r264746 : convert dos to unix lineends
2008-12-03 08:50:45 +0100 oj r264745 : convert dos to unix lineends
2008-12-03 08:50:05 +0100 oj r264744 : convert dos to unix lineends
2008-12-02 12:28:33 +0100 oj r264686 : clear help text when new helpid is set
2008-12-02 12:28:02 +0100 oj r264685 : set help id for listbox category
2008-12-02 07:15:56 +0100 oj r264655 : remove define to auto generate help ids
2008-12-01 14:36:43 +0100 oj r264604 : use temp var
2008-12-01 14:18:31 +0100 oj r264601 : moved ScJumpToken to formula
2008-12-01 14:18:11 +0100 oj r264600 : moved ScJumpToken to formula
2008-12-01 14:14:35 +0100 oj r264599 : moved ScJumpToken from sc
2008-12-01 10:48:51 +0100 oj r264589 : change quickhelptext from Shrink to Select
2008-12-01 10:28:41 +0100 oj r264588 : fix opcode data, has to be Any.Void
2008-11-28 11:16:48 +0100 oj r264532 : add help ids
2008-11-28 10:16:56 +0100 oj r264529 : set help id
2008-11-28 10:16:43 +0100 oj r264528 : set help id
2008-11-26 13:55:04 +0100 oj r264381 : #94535# use of optional instead of deleting a string myself and some small changes
2008-11-26 09:53:20 +0100 oj r264346 : compile error with debug/without debug
2008-11-25 07:41:28 +0100 oj r264271 : put static into the method which make use of them
2008-11-24 08:16:07 +0100 oj r264196 : removed not needed classes for op code
2008-11-24 08:13:44 +0100 oj r264195 : removed not needed classes for op code
2008-11-21 14:05:53 +0100 oj r264135 : make GetOpCode inline
2008-11-21 12:35:27 +0100 oj r264124 : hold symbols
2008-11-20 09:27:27 +0100 oj r264028 : merged code from DEV300_m35 which got lost
2008-11-19 20:42:12 +0100 oj r264022 : more changes for formula dialog remove
2008-11-19 20:37:41 +0100 oj r264021 : removed unused var
2008-11-19 20:35:35 +0100 oj r264020 : some more changes at token
2008-11-19 10:59:47 +0100 oj r263967 : deleted
2008-11-19 10:58:24 +0100 oj r263966 : add forui and for res files
2008-11-18 15:27:36 +0100 oj r263777 : unused para removed
2008-11-18 15:23:23 +0100 oj r263775 : add insert button to add field dlg
2008-11-18 13:39:53 +0100 oj r263764 : enable the formula dialog as well for conditional print as for conditional formatting
2008-11-18 12:03:25 +0100 oj r263760 : rename isRef in IsRef
2008-11-17 11:46:16 +0100 oj r263711 : patches for function handling
2008-11-17 11:36:22 +0100 oj r263710 : add new for forui and res file
2008-11-17 09:21:12 +0100 oj r263704 : patches for some resource for libformula
2008-11-15 12:45:30 +0100 oj r263701 : changes for formula editor extraction
2008-11-07 08:23:27 +0100 oj r263416 : merge from DEV300:m35
2008-11-07 08:22:35 +0100 oj r263415 : merge from DEV300:m35
2008-11-07 08:22:16 +0100 oj r263414 : merge from DEV300:m35
2008-11-07 08:21:41 +0100 oj r263413 : merge from DEV300:m35
2008-11-07 08:21:31 +0100 oj r263412 : merge from DEV300:m35
2008-11-07 08:20:38 +0100 oj r263411 : merge from DEV300:m35
2008-11-07 08:20:00 +0100 oj r263410 : merge from DEV300:m35
2008-11-07 08:18:50 +0100 oj r263409 : merge from DEV300:m35
2008-11-07 08:18:19 +0100 oj r263408 : merge from DEV300:m35
2008-11-07 08:10:27 +0100 oj r263407 : merge from DEV300:m35
2008-10-21 07:43:46 +0200 oj r262560 : some compile errors resolved
2008-10-17 16:40:01 +0200 oj r262291 : dep for 1st target
2008-10-07 10:08:39 +0200 oj r262077 : copy
2008-10-07 09:45:31 +0200 oj r262076 : #i94535#
2008-10-07 09:44:26 +0200 oj r262075 : #i94535# new base class
2008-10-07 09:43:21 +0200 oj r262074 : moved to formula
2008-10-07 09:41:51 +0200 oj r262073 : new images
2008-10-07 09:03:01 +0200 oj r262072 : new ids for formula
2008-10-02 08:46:27 +0200 oj r262024 : #i94535# move the formula compiler to formula
2008-10-02 08:08:54 +0200 oj r262023 : #i94535#
2008-10-02 08:06:28 +0200 oj r262022 : #i94535#
2008-10-02 08:05:52 +0200 oj r262021 : #i94535#
2008-10-01 17:15:29 +0200 oj r262014 : #i94535#
2008-10-01 17:12:40 +0200 oj r262013 : new module formula
2008-10-01 17:04:55 +0200 oj r262012 : #i94535#
2008-10-01 16:49:03 +0200 oj r262010 : #i94535#
2008-10-01 16:46:59 +0200 oj r262009 : #i94535#
2009-01-08 10:47:13 +00:00
|
|
|
#include "formula/errorcodes.hxx"
|
2000-10-26 17:56:42 +00:00
|
|
|
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
|
|
|
|
#define D_TIMEFACTOR 86400.0
|
|
|
|
|
2010-10-01 22:30:59 -04:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
ScDatabaseDocUtil::StrData::StrData() :
|
|
|
|
mbSimpleText(true), mnStrLength(0)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
2000-10-26 17:56:42 +00:00
|
|
|
|
2004-06-04 09:21:21 +00:00
|
|
|
void ScDatabaseDocUtil::PutData( ScDocument* pDoc, SCCOL nCol, SCROW nRow, SCTAB nTab,
|
2000-10-26 17:56:42 +00:00
|
|
|
const uno::Reference<sdbc::XRow>& xRow, long nRowPos,
|
2011-03-10 16:55:21 -05:00
|
|
|
long nType, sal_Bool bCurrency, StrData* pStrData )
|
2000-10-26 17:56:42 +00:00
|
|
|
{
|
|
|
|
String aString;
|
|
|
|
double nVal = 0.0;
|
2011-03-10 16:55:21 -05:00
|
|
|
sal_Bool bValue = false;
|
|
|
|
sal_Bool bEmptyFlag = false;
|
|
|
|
sal_Bool bError = false;
|
2011-01-17 13:20:22 +01:00
|
|
|
sal_uLong nFormatIndex = 0;
|
2000-10-26 17:56:42 +00:00
|
|
|
|
|
|
|
//! wasNull calls only if null value was found?
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
switch ( nType )
|
|
|
|
{
|
|
|
|
case sdbc::DataType::BIT:
|
2005-02-17 10:17:51 +00:00
|
|
|
case sdbc::DataType::BOOLEAN:
|
2000-10-26 17:56:42 +00:00
|
|
|
//! use language from doc (here, date/time and currency)?
|
|
|
|
nFormatIndex = pDoc->GetFormatTable()->GetStandardFormat(
|
|
|
|
NUMBERFORMAT_LOGICAL, ScGlobal::eLnge );
|
|
|
|
nVal = (xRow->getBoolean(nRowPos) ? 1 : 0);
|
|
|
|
bEmptyFlag = ( nVal == 0.0 ) && xRow->wasNull();
|
2011-01-17 13:20:22 +01:00
|
|
|
bValue = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::TINYINT:
|
|
|
|
case sdbc::DataType::SMALLINT:
|
|
|
|
case sdbc::DataType::INTEGER:
|
|
|
|
case sdbc::DataType::BIGINT:
|
|
|
|
case sdbc::DataType::FLOAT:
|
|
|
|
case sdbc::DataType::REAL:
|
|
|
|
case sdbc::DataType::DOUBLE:
|
|
|
|
case sdbc::DataType::NUMERIC:
|
|
|
|
case sdbc::DataType::DECIMAL:
|
|
|
|
//! do the conversion here?
|
|
|
|
nVal = xRow->getDouble(nRowPos);
|
|
|
|
bEmptyFlag = ( nVal == 0.0 ) && xRow->wasNull();
|
2011-01-17 13:20:22 +01:00
|
|
|
bValue = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::CHAR:
|
|
|
|
case sdbc::DataType::VARCHAR:
|
|
|
|
case sdbc::DataType::LONGVARCHAR:
|
|
|
|
aString = xRow->getString(nRowPos);
|
|
|
|
bEmptyFlag = ( aString.Len() == 0 ) && xRow->wasNull();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::DATE:
|
|
|
|
{
|
|
|
|
SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
|
|
|
|
nFormatIndex = pFormTable->GetStandardFormat(
|
|
|
|
NUMBERFORMAT_DATE, ScGlobal::eLnge );
|
|
|
|
|
|
|
|
util::Date aDate = xRow->getDate(nRowPos);
|
|
|
|
nVal = Date( aDate.Day, aDate.Month, aDate.Year ) -
|
|
|
|
*pFormTable->GetNullDate();
|
|
|
|
bEmptyFlag = xRow->wasNull();
|
2011-01-17 13:20:22 +01:00
|
|
|
bValue = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::TIME:
|
|
|
|
{
|
|
|
|
SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
|
|
|
|
nFormatIndex = pFormTable->GetStandardFormat(
|
|
|
|
NUMBERFORMAT_TIME, ScGlobal::eLnge );
|
|
|
|
|
|
|
|
util::Time aTime = xRow->getTime(nRowPos);
|
|
|
|
nVal = ( aTime.Hours * 3600 + aTime.Minutes * 60 +
|
|
|
|
aTime.Seconds + aTime.HundredthSeconds / 100.0 ) / D_TIMEFACTOR;
|
|
|
|
bEmptyFlag = xRow->wasNull();
|
2011-01-17 13:20:22 +01:00
|
|
|
bValue = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::TIMESTAMP:
|
|
|
|
{
|
|
|
|
SvNumberFormatter* pFormTable = pDoc->GetFormatTable();
|
|
|
|
nFormatIndex = pFormTable->GetStandardFormat(
|
|
|
|
NUMBERFORMAT_DATETIME, ScGlobal::eLnge );
|
|
|
|
|
|
|
|
util::DateTime aStamp = xRow->getTimestamp(nRowPos);
|
|
|
|
nVal = ( Date( aStamp.Day, aStamp.Month, aStamp.Year ) -
|
|
|
|
*pFormTable->GetNullDate() ) +
|
|
|
|
( aStamp.Hours * 3600 + aStamp.Minutes * 60 +
|
|
|
|
aStamp.Seconds + aStamp.HundredthSeconds / 100.0 ) / D_TIMEFACTOR;
|
|
|
|
bEmptyFlag = xRow->wasNull();
|
2011-01-17 13:20:22 +01:00
|
|
|
bValue = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::SQLNULL:
|
2011-01-17 13:20:22 +01:00
|
|
|
bEmptyFlag = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case sdbc::DataType::BINARY:
|
|
|
|
case sdbc::DataType::VARBINARY:
|
|
|
|
case sdbc::DataType::LONGVARBINARY:
|
|
|
|
default:
|
2011-01-17 13:20:22 +01:00
|
|
|
bError = sal_True; // unknown type
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
catch ( uno::Exception& )
|
|
|
|
{
|
2011-01-17 13:20:22 +01:00
|
|
|
bError = sal_True;
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if ( bValue && bCurrency )
|
|
|
|
nFormatIndex = pDoc->GetFormatTable()->GetStandardFormat(
|
|
|
|
NUMBERFORMAT_CURRENCY, ScGlobal::eLnge );
|
|
|
|
|
|
|
|
ScBaseCell* pCell;
|
|
|
|
if (bEmptyFlag)
|
|
|
|
{
|
|
|
|
pCell = NULL;
|
|
|
|
pDoc->PutCell( nCol, nRow, nTab, pCell );
|
|
|
|
}
|
|
|
|
else if (bError)
|
|
|
|
{
|
2007-07-06 11:32:51 +00:00
|
|
|
pDoc->SetError( nCol, nRow, nTab, NOTAVAILABLE );
|
2000-10-26 17:56:42 +00:00
|
|
|
}
|
|
|
|
else if (bValue)
|
|
|
|
{
|
|
|
|
pCell = new ScValueCell( nVal );
|
|
|
|
if (nFormatIndex == 0)
|
|
|
|
pDoc->PutCell( nCol, nRow, nTab, pCell );
|
|
|
|
else
|
|
|
|
pDoc->PutCell( nCol, nRow, nTab, pCell, nFormatIndex );
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2000-11-03 18:22:09 +00:00
|
|
|
if (aString.Len())
|
|
|
|
{
|
|
|
|
pCell = ScBaseCell::CreateTextCell( aString, pDoc );
|
2010-10-01 22:30:59 -04:00
|
|
|
if (pStrData)
|
|
|
|
{
|
|
|
|
pStrData->mbSimpleText = pCell->GetCellType() != CELLTYPE_EDIT;
|
|
|
|
pStrData->mnStrLength = aString.Len();
|
|
|
|
}
|
2000-11-03 18:22:09 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
pCell = NULL;
|
2000-10-26 17:56:42 +00:00
|
|
|
pDoc->PutCell( nCol, nRow, nTab, pCell );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-10-12 15:59:00 +02:00
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|