365 lines
10 KiB
C++
365 lines
10 KiB
C++
![]() |
/*************************************************************************
|
||
|
*
|
||
|
* $RCSfile: flddat.cxx,v $
|
||
|
*
|
||
|
* $Revision: 1.1.1.1 $
|
||
|
*
|
||
|
* last change: $Author: hr $ $Date: 2000-09-19 00:08:19 $
|
||
|
*
|
||
|
* The Contents of this file are made available subject to the terms of
|
||
|
* either of the following licenses
|
||
|
*
|
||
|
* - GNU Lesser General Public License Version 2.1
|
||
|
* - Sun Industry Standards Source License Version 1.1
|
||
|
*
|
||
|
* Sun Microsystems Inc., October, 2000
|
||
|
*
|
||
|
* GNU Lesser General Public License Version 2.1
|
||
|
* =============================================
|
||
|
* Copyright 2000 by Sun Microsystems, Inc.
|
||
|
* 901 San Antonio Road, Palo Alto, CA 94303, USA
|
||
|
*
|
||
|
* This library is free software; you can redistribute it and/or
|
||
|
* modify it under the terms of the GNU Lesser General Public
|
||
|
* License version 2.1, as published by the Free Software Foundation.
|
||
|
*
|
||
|
* This library 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 for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU Lesser General Public
|
||
|
* License along with this library; if not, write to the Free Software
|
||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
||
|
* MA 02111-1307 USA
|
||
|
*
|
||
|
*
|
||
|
* Sun Industry Standards Source License Version 1.1
|
||
|
* =================================================
|
||
|
* The contents of this file are subject to the Sun Industry Standards
|
||
|
* Source License Version 1.1 (the "License"); You may not use this file
|
||
|
* except in compliance with the License. You may obtain a copy of the
|
||
|
* License at http://www.openoffice.org/license.html.
|
||
|
*
|
||
|
* Software provided under this License is provided on an "AS IS" basis,
|
||
|
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
|
||
|
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
|
||
|
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
|
||
|
* See the License for the specific provisions governing your rights and
|
||
|
* obligations concerning the Software.
|
||
|
*
|
||
|
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
|
||
|
*
|
||
|
* Copyright: 2000 by Sun Microsystems, Inc.
|
||
|
*
|
||
|
* All Rights Reserved.
|
||
|
*
|
||
|
* Contributor(s): _______________________________________
|
||
|
*
|
||
|
*
|
||
|
************************************************************************/
|
||
|
|
||
|
#ifdef PRECOMPILED
|
||
|
#include "core_pch.hxx"
|
||
|
#endif
|
||
|
|
||
|
#pragma hdrstop
|
||
|
|
||
|
#include <math.h>
|
||
|
|
||
|
#ifndef _DATE_HXX //autogen
|
||
|
#include <tools/date.hxx>
|
||
|
#endif
|
||
|
#ifndef _TOOLS_TIME_HXX //autogen
|
||
|
#include <tools/time.hxx>
|
||
|
#endif
|
||
|
#ifndef _ZFORLIST_HXX //autogen
|
||
|
#include <svtools/zforlist.hxx>
|
||
|
#endif
|
||
|
|
||
|
#ifndef _UNOPRNMS_HXX
|
||
|
#include <unoprnms.hxx>
|
||
|
#endif
|
||
|
#include "doc.hxx"
|
||
|
#include "fldbas.hxx"
|
||
|
#include "flddat.hxx"
|
||
|
|
||
|
using namespace ::com::sun::star;
|
||
|
/*--------------------------------------------------
|
||
|
Beschreibung: Datum/Zeit-Typ
|
||
|
---------------------------------------------------*/
|
||
|
|
||
|
SwDateTimeFieldType::SwDateTimeFieldType(SwDoc* pDoc)
|
||
|
: SwValueFieldType( pDoc, RES_DATETIMEFLD )
|
||
|
{}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
SwFieldType* SwDateTimeFieldType::Copy() const
|
||
|
{
|
||
|
SwDateTimeFieldType *pTmp = new SwDateTimeFieldType(GetDoc());
|
||
|
return pTmp;
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung: Datum/Zeit-Feld
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
SwDateTimeField::SwDateTimeField(SwDateTimeFieldType* pType, USHORT nSub, ULONG nFmt, USHORT nLng)
|
||
|
: SwValueField(pType, nFmt, nLng, 0.0),
|
||
|
nSubType(nSub),
|
||
|
nOffset(0)
|
||
|
{
|
||
|
if (!nFmt)
|
||
|
{
|
||
|
SvNumberFormatter* pFormatter = GetDoc()->GetNumberFormatter();
|
||
|
if (nSubType & DATEFLD)
|
||
|
ChangeFormat(pFormatter->GetFormatIndex(NF_DATE_SYSTEM_SHORT, GetLanguage()));
|
||
|
else
|
||
|
ChangeFormat(pFormatter->GetFormatIndex(NF_TIME_HHMMSS, GetLanguage()));
|
||
|
}
|
||
|
if (IsFixed())
|
||
|
{
|
||
|
Time aTime;
|
||
|
Date aDate;
|
||
|
SetDateTime(aDate.GetDate(), aTime.GetTime());
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
String SwDateTimeField::Expand() const
|
||
|
{
|
||
|
double fVal;
|
||
|
|
||
|
if (!(IsFixed()))
|
||
|
{
|
||
|
Time aTime;
|
||
|
Date aDate;
|
||
|
fVal = GetDateTime(GetDoc(), aDate.GetDate(), aTime.GetTime());
|
||
|
}
|
||
|
else
|
||
|
fVal = GetValue();
|
||
|
|
||
|
if (nOffset)
|
||
|
fVal += (double)(nOffset * 60L) / 86400.0;
|
||
|
|
||
|
return ExpandValue(fVal, GetFormat(), GetLanguage());
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
SwField* SwDateTimeField::Copy() const
|
||
|
{
|
||
|
SwDateTimeField *pTmp =
|
||
|
new SwDateTimeField((SwDateTimeFieldType*)GetTyp(), nSubType,
|
||
|
GetFormat(), GetLanguage());
|
||
|
|
||
|
pTmp->SetValue(GetValue());
|
||
|
pTmp->SetOffset(nOffset);
|
||
|
|
||
|
return pTmp;
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
USHORT SwDateTimeField::GetSubType() const
|
||
|
{
|
||
|
return nSubType;
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
void SwDateTimeField::SetSubType(USHORT nType)
|
||
|
{
|
||
|
nSubType = nType;
|
||
|
}
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
void SwDateTimeField::SetPar2(const String& rStr)
|
||
|
{
|
||
|
nOffset = rStr.ToInt32();
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
String SwDateTimeField::GetPar2() const
|
||
|
{
|
||
|
if (nOffset)
|
||
|
return String::CreateFromInt32(nOffset);
|
||
|
else
|
||
|
return aEmptyStr;
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
void SwDateTimeField::SetDateTime(ULONG nDate, ULONG nTime)
|
||
|
{
|
||
|
SetValue(GetDateTime(GetDoc(), nDate, nTime));
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
double SwDateTimeField::GetDateTime(SwDoc* pDoc, ULONG nDate, ULONG nTime)
|
||
|
{
|
||
|
Date aDate(nDate);
|
||
|
SvNumberFormatter* pFormatter = pDoc->GetNumberFormatter();
|
||
|
Date* pNullDate = pFormatter->GetNullDate();
|
||
|
|
||
|
if (!nDate) // Damit wirklich das Jahr auf 0 gesetzt wird...
|
||
|
aDate.SetDate(pNullDate->GetDate());
|
||
|
|
||
|
double fResult = aDate - *pNullDate;
|
||
|
|
||
|
Time aTime(nTime);
|
||
|
|
||
|
ULONG nNumFmtTime = (ULONG)aTime.GetSec() + (ULONG)aTime.GetMin() * 60L +
|
||
|
(ULONG)aTime.GetHour() * 3600L;
|
||
|
|
||
|
return fResult + ((double)nNumFmtTime + 0.5) / 86400.0;
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
double SwDateTimeField::GetValue() const
|
||
|
{
|
||
|
if (IsFixed())
|
||
|
return SwValueField::GetValue();
|
||
|
else
|
||
|
return GetDateTime(GetDoc(), Date().GetDate(), Time().GetTime());
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
ULONG SwDateTimeField::GetDate(BOOL bUseOffset) const
|
||
|
{
|
||
|
SvNumberFormatter* pFormatter = GetDoc()->GetNumberFormatter();
|
||
|
Date* pNullDate = pFormatter->GetNullDate();
|
||
|
|
||
|
long nVal = GetValue();
|
||
|
|
||
|
if (bUseOffset && nOffset)
|
||
|
nVal += nOffset / 60 / 24;
|
||
|
|
||
|
Date aDate = *pNullDate + nVal;
|
||
|
|
||
|
return aDate.GetDate();
|
||
|
}
|
||
|
|
||
|
/*--------------------------------------------------------------------
|
||
|
Beschreibung:
|
||
|
--------------------------------------------------------------------*/
|
||
|
|
||
|
ULONG SwDateTimeField::GetTime(BOOL bUseOffset) const
|
||
|
{
|
||
|
double fDummy;
|
||
|
double fFract = modf(GetValue(), &fDummy);
|
||
|
|
||
|
ULONG nTime = (ULONG)(fFract * 86400.0);
|
||
|
ULONG nHour = nTime / 3600L;
|
||
|
ULONG nMin = (nTime - 3600L * nHour) / 60L;
|
||
|
ULONG nSec = nTime - 3600L * nHour - 60L * nMin;
|
||
|
|
||
|
if (bUseOffset)
|
||
|
nMin += nOffset;
|
||
|
|
||
|
Time aTime(nHour, nMin, nSec);
|
||
|
|
||
|
return aTime.GetTime();
|
||
|
}
|
||
|
|
||
|
/*-----------------04.03.98 11:05-------------------
|
||
|
|
||
|
--------------------------------------------------*/
|
||
|
BOOL SwDateTimeField::QueryValue( uno::Any& rVal, const String& rProperty ) const
|
||
|
{
|
||
|
if(rProperty.EqualsAscii(UNO_NAME_DATETIME))
|
||
|
rVal <<= GetValue();
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_IS_FIXED ))
|
||
|
{
|
||
|
BOOL bTmp = IsFixed();
|
||
|
rVal.setValue(&bTmp, ::getCppuBooleanType());
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_NUMBER_FORMAT))
|
||
|
rVal <<= (sal_Int32)GetFormat();
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_IS_DATE))
|
||
|
{
|
||
|
BOOL bTmp = IsDate();
|
||
|
rVal.setValue(&bTmp, ::getCppuBooleanType());
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_ADJUST))
|
||
|
rVal <<= (sal_Int32)nOffset;
|
||
|
|
||
|
#ifdef DBG_UTIL
|
||
|
else
|
||
|
DBG_ERROR("Was war das fuer ein Typ?")
|
||
|
#endif
|
||
|
return TRUE;
|
||
|
}
|
||
|
/*-----------------04.03.98 11:05-------------------
|
||
|
|
||
|
--------------------------------------------------*/
|
||
|
BOOL SwDateTimeField::PutValue( const uno::Any& rVal, const String& rProperty )
|
||
|
{
|
||
|
if(rProperty.EqualsAscii(UNO_NAME_DATETIME))
|
||
|
{
|
||
|
SetValue(*(Double*)rVal.getValue());
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_IS_FIXED))
|
||
|
{
|
||
|
BOOL bFix = *(sal_Bool*)rVal.getValue();
|
||
|
if(bFix)
|
||
|
nSubType |= FIXEDFLD;
|
||
|
else
|
||
|
nSubType &= ~FIXEDFLD;
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_NUMBER_FORMAT))
|
||
|
{
|
||
|
sal_Int32 nTmp;
|
||
|
rVal >>= nTmp;
|
||
|
ChangeFormat(nTmp);
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_IS_DATE))
|
||
|
{
|
||
|
BOOL bDate = *(sal_Bool*)rVal.getValue();
|
||
|
nSubType &= ~(DATEFLD|TIMEFLD);
|
||
|
nSubType |= bDate ? DATEFLD : TIMEFLD;
|
||
|
}
|
||
|
else if(rProperty.EqualsAscii(UNO_NAME_ADJUST))
|
||
|
{
|
||
|
sal_Int32 nVal;
|
||
|
rVal >>= nVal;
|
||
|
nOffset = nVal;
|
||
|
}
|
||
|
#ifdef DBG_UTIL
|
||
|
else
|
||
|
{
|
||
|
DBG_ERROR("was war das fuer ein Typ?");
|
||
|
}
|
||
|
#endif
|
||
|
return TRUE;
|
||
|
}
|
||
|
|