1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ 2 /************************************************************************* 3 * 4 * The Contents of this file are made available subject to the terms of 5 * either of the following licenses 6 * 7 * - GNU Lesser General Public License Version 2.1 8 * - Sun Industry Standards Source License Version 1.1 9 * 10 * Sun Microsystems Inc., October, 2000 11 * 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 16 * 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. 20 * 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. 25 * 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, 29 * MA 02111-1307 USA 30 * 31 * 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. 38 * 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. 45 * 46 * The Initial Developer of the Original Code is: IBM Corporation 47 * 48 * Copyright: 2008 by IBM Corporation 49 * 50 * All Rights Reserved. 51 * 52 * Contributor(s): _______________________________________ 53 * 54 * 55 ************************************************************************/ 56 /************************************************************************* 57 * @file 58 * Global functions or include files that are needed. 59 * It's all for the full filter. 60 ************************************************************************/ 61 #ifndef INCLUDED_LOTUSWORDPRO_INC_XFILTER_XFGLOBAL_HXX 62 #define INCLUDED_LOTUSWORDPRO_INC_XFILTER_XFGLOBAL_HXX 63 64 #include <cassert> 65 66 #include <sal/types.h> 67 68 #include <rtl/ustring.hxx> 69 70 #include <xfilter/ixfstream.hxx> 71 #include <xfilter/ixfattrlist.hxx> 72 73 #include <xfilter/xfutil.hxx> 74 #include <xfilter/xfdefs.hxx> 75 76 #define PI 3.1415926 77 #define FLOAT_MIN 0.001 78 #define MAX2(a,b) (((a) > (b)) ? (a) : (b)) 79 #define MAX3(a,b,c) MAX2(a,MAX2(b,c)) 80 #define MIN2(a,b) (((a) < (b)) ? (a) : (b)) 81 #define MIN3(a,b,c) MIN2(a,MIN2(b,c)) 82 #define FABS(f) (f>0?f:-f) 83 84 void XFGlobalReset(); 85 86 /** 87 * @brief 88 * Global object, it manages all global variables for the full filter. 89 * Before loading a file, we'll need to reset all global variables. 90 * XFGlobal::Reset can do this for you. 91 */ 92 class XFGlobal 93 { 94 public: 95 /** 96 * @descr Generate a name for the section. 97 */ 98 static OUString GenSectionName(); 99 100 /** 101 * @descr Gen a name for the frame. 102 */ 103 static OUString GenFrameName(); 104 105 /** 106 * @descr Generate a name for a table. 107 */ 108 static OUString GenTableName(); 109 110 /** 111 * @descr Generate a name for a note. 112 */ 113 static OUString GenNoteName(); 114 115 /** 116 * @descr Generate a name for the stroke style. 117 */ 118 static OUString GenStrokeDashName(); 119 120 /** 121 * @descr Generate a name for the area fill style. 122 */ 123 static OUString GenAreaName(); 124 125 /** 126 * @descr Generate a name for an image object 127 */ 128 static OUString GenImageName(); 129 130 /** 131 * @descr Reset all global variables. 132 */ 133 static void Reset(); 134 135 public: 136 static int s_nSectionID; 137 static int s_nFrameID; 138 static int s_nNoteID; 139 static int s_nStrokeDashID; 140 static int s_nAreaID; 141 static int s_nImageID; 142 }; 143 144 #endif 145 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ 146