1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*************************************************************************
4 * The Contents of this file are made available subject to the terms of
5 * either of the following licenses
7 * - GNU Lesser General Public License Version 2.1
8 * - Sun Industry Standards Source License Version 1.1
10 * Sun Microsystems Inc., October, 2000
12 * GNU Lesser General Public License Version 2.1
13 * =============================================
14 * Copyright 2000 by Sun Microsystems, Inc.
15 * 901 San Antonio Road, Palo Alto, CA 94303, USA
17 * This library is free software; you can redistribute it and/or
18 * modify it under the terms of the GNU Lesser General Public
19 * License version 2.1, as published by the Free Software Foundation.
21 * This library is distributed in the hope that it will be useful,
22 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24 * Lesser General Public License for more details.
26 * You should have received a copy of the GNU Lesser General Public
27 * License along with this library; if not, write to the Free Software
28 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
32 * Sun Industry Standards Source License Version 1.1
33 * =================================================
34 * The contents of this file are subject to the Sun Industry Standards
35 * Source License Version 1.1 (the "License"); You may not use this file
36 * except in compliance with the License. You may obtain a copy of the
37 * License at http://www.openoffice.org/license.html.
39 * Software provided under this License is provided on an "AS IS" basis,
40 * WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
41 * WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
42 * MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
43 * See the License for the specific provisions governing your rights and
44 * obligations concerning the Software.
46 * The Initial Developer of the Original Code is: IBM Corporation
48 * Copyright: 2008 by IBM Corporation
50 * All Rights Reserved.
52 * Contributor(s): _______________________________________
55 ************************************************************************/
56 /*************************************************************************
58 * to provide basic utilities for word pro filter
59 ************************************************************************/
61 #ifndef INCLUDED_LOTUSWORDPRO_INC_LWPTOOLS_HXX
62 #define INCLUDED_LOTUSWORDPRO_INC_LWPTOOLS_HXX
64 #include "lwpheader.hxx"
65 #include "lwpobjstrm.hxx"
66 #include "localtime.hxx"
67 #include "xfilter/xfdatestyle.hxx"
68 #include "xfilter/xftimestyle.hxx"
69 #include <rtl/textenc.h>
73 const sal_uInt32 UNITS_PER_INCH
= 65536L * 72L;
74 const double CM_PER_INCH
= 2.54;
75 const double INCHT_PER_CM
= (1.0 / CM_PER_INCH
);
78 const double POINTS_PER_INCH
= 72.27;
79 const double TWIPS_PER_POINT
= 20.0;
80 const double TWIPS_PER_INCH
= (TWIPS_PER_POINT
* POINTS_PER_INCH
);
81 const double TWIPS_PER_CM
= (TWIPS_PER_INCH
/CM_PER_INCH
);
83 * @brief tool class (unicode, conversion) for lwp filter.
89 static void QuickReadUnicode( LwpObjectStream
* pObjStrm
,
90 OUString
& str
, sal_uInt16 strlen
, rtl_TextEncoding aEncoding
);
91 static bool IsUnicodePacked(LwpObjectStream
* pObjStrm
, sal_uInt16 len
);
93 inline static double ConvertFromUnits(sal_Int32 nUnits
);
94 inline static double ConvertToMetric(double fInch
);
95 inline static double ConvertFromUnitsToMetric(sal_Int32 nUnits
);
97 inline static bool IsOddNumber(sal_uInt16 nNumber
);
98 inline static bool IsEvenNumber(sal_uInt16 nNumber
);
100 static bool isFileUrl(const OString
& fileName
);
101 static OUString
convertToFileUrl(const OString
& fileName
);
102 static OUString
DateTimeToOUString(const LtTm
& dt
);
104 static XFDateStyle
* GetSystemDateStyle(bool bLongFormat
);
105 static XFTimeStyle
* GetSystemTimeStyle();
108 inline double LwpTools::ConvertFromUnits(sal_Int32 nUnits
)
110 return static_cast<double>(nUnits
)/UNITS_PER_INCH
;
112 inline double LwpTools::ConvertToMetric(double fInch
)
114 return fInch
*CM_PER_INCH
;
116 inline double LwpTools::ConvertFromUnitsToMetric(sal_Int32 nUnits
)
118 double fInch
= ConvertFromUnits(nUnits
);
119 return ConvertToMetric(fInch
);
121 inline bool LwpTools::IsOddNumber(sal_uInt16 nNumber
)
123 return (nNumber
%2) != 0;
125 inline bool LwpTools::IsEvenNumber(sal_uInt16 nNumber
)
127 return (nNumber
%2) == 0;
130 class BadSeek
: public std::runtime_error
133 BadSeek() : std::runtime_error("Lotus Word Pro Bad Seek") { }
136 class BadRead
: public std::runtime_error
139 BadRead() : std::runtime_error("Lotus Word Pro Bad Read") { }
142 class BadDecompress
: public std::runtime_error
145 BadDecompress() : std::runtime_error("Lotus Word Pro Bad Decompress") { }
150 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */