You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
98 lines
3.5 KiB
98 lines
3.5 KiB
/* This file is part of the KOffice project
|
|
Copyright (C) 2002 Werner Trobin <trobin@kde.org>
|
|
Copyright (C) 2002 David Faure <faure@kde.org>
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU General Public
|
|
License version 2 as published by the Free Software Foundation.
|
|
|
|
This program 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
|
|
General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; see the file COPYING. If not, write to
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
* Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#ifndef CONVERSION_H
|
|
#define CONVERSION_H
|
|
|
|
#include <wv2/ustring.h>
|
|
#include <tqstring.h>
|
|
#include <tqcolor.h>
|
|
|
|
class TQDomElement;
|
|
namespace wvWare {
|
|
namespace Word97 {
|
|
class LSPD;
|
|
class BRC;
|
|
}
|
|
class FLD;
|
|
}
|
|
|
|
// Static methods for simple MSWord->KWord conversions
|
|
// (enums etc.)
|
|
|
|
namespace Conversion
|
|
{
|
|
// UString -> TQConstString conversion. Use .string() to get the TQString.
|
|
// Always store the TQConstString into a variable first, to avoid a deep copy.
|
|
inline TQConstString string( const wvWare::UString& str ) {
|
|
// Let's hope there's no copying of the TQConstString happening...
|
|
return TQConstString( reinterpret_cast<const TQChar*>( str.data() ), str.length() );
|
|
}
|
|
|
|
// Prepare text for inclusion in XML
|
|
void encodeText(TQString &text);
|
|
|
|
// Convert color code (ico) to TQColor
|
|
TQColor color(int number, int defaultcolor, bool defaultWhite = false);
|
|
|
|
// Convert pattern style (ipat) to TQBrush::BrushStyle
|
|
int fillPatternStyle( int ipat );
|
|
|
|
// Hackery for gray levels
|
|
int ditheringToGray( int ipat, bool* ok );
|
|
|
|
// Convert alignment code to string
|
|
TQString alignment( int jc );
|
|
|
|
// Convert linespacing struct to string
|
|
TQString lineSpacing( const wvWare::Word97::LSPD& lspd );
|
|
|
|
// Convert number format code to KWord's COUNTER.type code
|
|
int numberFormatCode( int nfc );
|
|
|
|
// Set the 3 color attributes in the XML element, from a color code (ico)
|
|
// prefix: if empty, the attribute names will be red/blue/green
|
|
// if not empty, they will be xRed/xBlue/xGreen
|
|
void setColorAttributes( TQDomElement& element, int ico, const TQString& prefix = TQString(), bool defaultWhite = false );
|
|
|
|
// Set all border attributes in the XML element, from a BRC structure
|
|
// prefix: if empty, the attribute names will be red/blue/green/width/style
|
|
// if not empty, they will be xRed/xBlue/xGreen/xWidth/xStyle
|
|
void setBorderAttributes( TQDomElement& borderElement, const wvWare::Word97::BRC& brc, const TQString& prefix = TQString() );
|
|
|
|
// Convert wv2's Header Type to a KWord frameInfo value
|
|
int headerTypeToFrameInfo( unsigned char type );
|
|
|
|
// Convert wv2's Header Type to a KWord frameset name
|
|
TQString headerTypeToFramesetName( unsigned char type );
|
|
|
|
// Convert a mask of Header Types to the hType value for KWord
|
|
int headerMaskToHType( unsigned char mask );
|
|
|
|
// Convert a mask of Header Types to the fType value for KWord
|
|
int headerMaskToFType( unsigned char mask );
|
|
|
|
// Convert wv2's FLD to KWord FIELD.subtype (or -1 if can't be handled)
|
|
int fldToFieldType( const wvWare::FLD* fld );
|
|
|
|
bool isHeader( unsigned char type );
|
|
}
|
|
|
|
#endif
|