1 /*************************************************************************
3 * The Contents of this file are made available subject to the terms of
4 * either of the following licenses
6 * - GNU Lesser General Public License Version 2.1
7 * - Sun Industry Standards Source License Version 1.1
9 * Sun Microsystems Inc., October, 2000
11 * GNU Lesser General Public License Version 2.1
12 * =============================================
13 * Copyright 2000 by Sun Microsystems, Inc.
14 * 901 San Antonio Road, Palo Alto, CA 94303, USA
16 * This library is free software; you can redistribute it and/or
17 * modify it under the terms of the GNU Lesser General Public
18 * License version 2.1, as published by the Free Software Foundation.
20 * This library is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
23 * Lesser General Public License for more details.
25 * You should have received a copy of the GNU Lesser General Public
26 * License along with this library; if not, write to the Free Software
27 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
31 * Sun Industry Standards Source License Version 1.1
32 * =================================================
33 * The contents of this file are subject to the Sun Industry Standards
34 * Source License Version 1.1 (the "License"); You may not use this file
35 * except in compliance with the License. You may obtain a copy of the
36 * License at http://www.openoffice.org/license.html.
38 * Software provided under this License is provided on an "AS IS" basis,
39 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
40 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
41 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
42 * See the License for the specific provisions governing your rights and
43 * obligations concerning the Software.
45 * The Initial Developer of the Original Code is: IBM Corporation
47 * Copyright: 2008 by IBM Corporation
49 * All Rights Reserved.
51 * Contributor(s): _______________________________________
54 ************************************************************************/
55 /*************************************************************************
57 * to provide basic utilities for word pro filter
58 ************************************************************************/
59 /*************************************************************************
62 ************************************************************************/
67 #include "lwpheader.hxx"
68 #include "lwpobjstrm.hxx"
69 #include "localtime.hxx"
70 #include "xfilter/xfdatestyle.hxx"
71 #include "xfilter/xftimestyle.hxx"
72 #include <rtl/textenc.h>
75 const sal_uInt32 UNITS_PER_INCH
= 65536L * 72L;
76 const double CM_PER_INCH
= 2.54;
77 const double INCHT_PER_CM
= (1.0 / CM_PER_INCH
);
80 const double POINTS_PER_INCH
= 72.27;
81 const double TWIPS_PER_POINT
= 20.0;
82 const double TWIPS_PER_INCH
= (TWIPS_PER_POINT
* POINTS_PER_INCH
);
83 const double TWIPS_PER_CM
= (TWIPS_PER_INCH
/CM_PER_INCH
);
85 * @brief tool class (unicode, conversion) for lwp filter.
91 static sal_uInt16
QuickReadUnicode( LwpObjectStream
* pObjStrm
,
92 OUString
& str
, sal_uInt16 strlen
, rtl_TextEncoding aEncoding
);
93 static BOOL
IsUnicodePacked(LwpObjectStream
* pObjStrm
, sal_uInt16 len
);
96 inline static double ConvertFromUnits(const sal_Int32
& nUnits
);
97 inline static double ConvertToMetric(const double& fInch
);
98 inline static double ConvertFromMetric(const double& fCM
);
99 inline static double ConvertFromUnitsToMetric(const sal_Int32
& nUnits
);
102 //add by , 03/11/2005
103 inline static sal_Int32
ConvertToUnits(const double& fInch
);
107 inline static sal_Bool
IsOddNumber(sal_uInt16
& nNumber
);
108 inline static sal_Bool
IsEvenNumber(sal_uInt16
& nNumber
);
110 static sal_Bool
isFileUrl(const OString
& fileName
);
111 static OUString
convertToFileUrl(const OString
& fileName
);
112 static rtl::OUString
DateTimeToOUString(LtTm
& dt
);
115 static XFDateStyle
* GetSystemDateStyle(sal_Bool bLongFormat
);
116 static XFTimeStyle
* GetSystemTimeStyle();
119 inline double LwpTools::ConvertFromUnits(const sal_Int32
& nUnits
)
121 return (double)nUnits
/UNITS_PER_INCH
;
123 inline double LwpTools::ConvertToMetric(const double& fInch
)
125 return fInch
*CM_PER_INCH
;
127 inline double LwpTools::ConvertFromMetric(const double& fCM
)
129 return fCM
/CM_PER_INCH
;
131 inline double LwpTools::ConvertFromUnitsToMetric(const sal_Int32
& nUnits
)
133 double fInch
= ConvertFromUnits(nUnits
);
134 return ConvertToMetric(fInch
);
136 inline sal_Int32
LwpTools::ConvertToUnits(const double& fInch
)
138 return (sal_Int32
)fInch
*UNITS_PER_INCH
;
140 inline sal_Bool
LwpTools::IsOddNumber(sal_uInt16
& nNumber
)
142 return nNumber
%2? sal_True
: sal_False
;
144 inline sal_Bool
LwpTools::IsEvenNumber(sal_uInt16
& nNumber
)
146 return nNumber
%2? sal_False
: sal_True
;