summaryrefslogtreecommitdiff
path: root/svx/source/editeng
diff options
context:
space:
mode:
Diffstat (limited to 'svx/source/editeng')
-rw-r--r--svx/source/editeng/textconv.cxx360
1 files changed, 0 insertions, 360 deletions
diff --git a/svx/source/editeng/textconv.cxx b/svx/source/editeng/textconv.cxx
deleted file mode 100644
index 497ad8b9b519..000000000000
--- a/svx/source/editeng/textconv.cxx
+++ /dev/null
@@ -1,360 +0,0 @@
-/*************************************************************************
- *
- * $RCSfile: textconv.cxx,v $
- *
- * $Revision: 1.1.1.1 $
- *
- * last change: $Author: hr $ $Date: 2000-09-18 17:01:14 $
- *
- * 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): _______________________________________
- *
- *
- ************************************************************************/
-
-#pragma hdrstop
-
-#ifndef ENABLEUNICODE
-
-#define _TEXTCONV_CXX
-#include <textconv.hxx>
-
-#ifndef _TOOLS_DEBUG_HXX
-#include <tools/debug.hxx>
-#endif
-
-#ifndef _SV_OUTDEV_HXX
-#include <vcl/outdev.hxx>
-#endif
-
-#ifndef _SV_METRIC_HXX
-#include <vcl/metric.hxx>
-#endif
-
-#include <rtl/tencinfo.h>
-#include <rtl/textenc.h>
-
-SV_IMPL_VARARR( NonConvChars, AttribRange );
-
-TextConverter::TextConverter()
-{
- eSourceCharSet = CHARSET_DONTKNOW;
- eDestCharSet = CHARSET_DONTKNOW;
-}
-
-TextConverter::TextConverter( CharSet eSource, CharSet eDest )
-{
- eSourceCharSet = eSource;
- eDestCharSet = eDest;
-}
-
-void TextConverter::Convert( String& rText, BOOL bSmartReplace )
-{
- aNotConvertedChars.Remove( 0, aNotConvertedChars.Count() );
-
- if( rText.Len() )
- {
- rtl_TextEncodingInfo aTextEncInfo1;
- aTextEncInfo1.StructSize = sizeof( aTextEncInfo1 );
- rtl_getTextEncodingInfo( eSourceCharSet, &aTextEncInfo1 );
-
- rtl_TextEncodingInfo aTextEncInfo2;
- aTextEncInfo2.StructSize = sizeof( aTextEncInfo2 );
- rtl_getTextEncodingInfo( eDestCharSet, &aTextEncInfo2 );
-
- if ( (aTextEncInfo1.MaximumCharSize == 1) &&
- (aTextEncInfo2.MaximumCharSize == 1) )
- {
- // Erstmal den gesamten String konvertieren und dann ggf. die nicht
- // konvertierbaren Zeichen zurueckkopieren.
- // Das kann auch nicht teurer sein als staendig neue kleine
- // Strings zu erzeugen und aneinander zu haengen.
- String aNewText( rText );
- aNewText.Convert( eSourceCharSet, eDestCharSet, FALSE );
-
- // bReplace = FALSE => nicht konvertiebare Zeichen sind jetzt ZERO
-
- // Bereich fuer nicht konvertierbare Zeichen
- USHORT nNotConvertedFrom = INVPOS;
- USHORT nNotConvertedTo = 0;
-
- USHORT nCurNonConvblRange = 0;
- USHORT nNonConvblStartOff = INVPOS;
- USHORT nNonConvblEndOff = 0;
-
- // 1. nicht konvertierbarer Bereich:
- GetNonConvblRange( nCurNonConvblRange++, nNonConvblStartOff, nNonConvblEndOff );
-
- USHORT nLen = rText.Len();
- char* pNewText = aNewText.GetCharStr();
- for( USHORT nChar = 0; nChar < nLen; nChar++ )
- {
- // ggf. naechster nicht konvertierbarer Bereich:
- if( ( nNonConvblStartOff != 0xFFFF ) && ( nNonConvblEndOff <= nChar ) )
- GetNonConvblRange( nCurNonConvblRange++, nNonConvblStartOff, nNonConvblEndOff );
-
- // Testen, ob man sich im verbotenen Bereich befindet:
- if( ( nNonConvblStartOff == INVPOS ) || ( nChar < nNonConvblStartOff ) || ( nChar >= nNonConvblEndOff ) )
- {
- if( !pNewText[nChar] && bSmartReplace )
- {
- // Gottseidank haben alle OS/2-Zeichensaetze bis auf 865
- // die Zeichen und am selben Fleck. Da hier nur
- // die nichtkonvertierbaren ZS durchschlagen, ist die
- // Abfrage sehr einfach zu halten. ANSI und Mac werden
- // von String::Convert() bereits korrekt konvertiert.
- // CHARSET_UNIXANSI gibt es (noch) nicht
- switch( eSourceCharSet )
- {
- case CHARSET_ANSI:
- {
- switch( (unsigned char)rText.GetChar( nChar ) )
- {
- case 132: pNewText[nChar] = (char)(unsigned char)175; break;
- case 147: pNewText[nChar] = (char)(unsigned char)174; break;
- }
- }
- break;
- case CHARSET_MAC:
- {
- switch( (unsigned char)rText.GetChar( nChar ) )
- {
- case 210:
- case 227: pNewText[nChar] = (char)(unsigned char)175; break;
- case 211: pNewText[nChar] = (char)(unsigned char)174; break;
- }
- }
- break;
- }
-
- // Der Zeichensatz 865 hat keine Matchpaare fuer Anf.Zeichen
- if( ( eDestCharSet == CHARSET_IBMPC_865 ) && ( ( (unsigned char)pNewText[nChar] == 174 ) || ( (unsigned char)pNewText[nChar] == 175 ) ) )
- pNewText[nChar] = '"';
- }
-
- if( pNewText[nChar] )
- {
- // Zeichen konnte (wieder) konvertiert werden.
-
- // Range der Zeichen, die nicht konvertiert werden konnten:
- if( nNotConvertedFrom != INVPOS )
- {
- aNotConvertedChars.Insert( AttribRange( nNotConvertedFrom, nNotConvertedTo ), aNotConvertedChars.Count() );
- nNotConvertedFrom = INVPOS;
- }
- }
- else
- {
- // Zeichen ist nicht konvertierbar: merken und restaurieren
- pNewText[nChar] = rText.GetChar( nChar );
- if( nNotConvertedFrom == INVPOS )
- nNotConvertedFrom = nChar;
- nNotConvertedTo = nChar;
- }
- }
- else
- {
- pNewText[nChar] = rText.GetChar( nChar );
- // Zeichen die nicht konvertiert werden duerfen, sollen nicht
- // als NotConverted auftauchen.
- if( nNotConvertedFrom != INVPOS )
- {
- aNotConvertedChars.Insert( AttribRange( nNotConvertedFrom, nNotConvertedTo ), aNotConvertedChars.Count() );
- nNotConvertedFrom = INVPOS;
- }
- }
- }
- // Eventuellen uebriggelassenen nicht konvertierbaren Bereich:
- if( nNotConvertedFrom != INVPOS )
- aNotConvertedChars.Insert( AttribRange( nNotConvertedFrom, nNotConvertedTo ), aNotConvertedChars.Count() );
-
- #ifdef DBG_UTIL
- for ( USHORT n = aNewText.Len(); n; )
- DBG_ASSERT( aNewText.GetChar( --n ), "TextConverter: Char not converted - error in String" );
- #endif
-
- rText = aNewText;
- }
- else
- {
- // NonConvertableChars not supported here!
- rText.Convert( eSourceCharSet, eDestCharSet, TRUE );
- }
- }
-}
-
-char TextConverter::GetReplaceChar( OutputDevice* pDev, sal_Unicode cUnicode, Font& rFont )
-{
- char cReplace = 0;
-
- if ( pDev )
- {
- pDev->Push( PUSH_FONT );
- pDev->SetFont( rFont );
- FontMetric aNewFont = pDev->GetFontMetric();
- cReplace = String::ConvertFromUnicode( cUnicode, aNewFont.GetCharSet(), FALSE );
- pDev->Pop();
- }
-
- if ( !cReplace )
- {
- // Try replacement character in 'StarBats'
- switch ( cUnicode )
- {
- // Currency
- case 0x00A2: cReplace = (char)224;
- break;
- case 0x00A4: cReplace = (char)225;
- break;
- case 0x00A5: cReplace = (char)226;
- break;
- case 0x20A1: cReplace = (char)228;
- break;
- case 0x20A2: cReplace = (char)229;
- break;
- case 0x20A3: cReplace = (char)230;
- break;
- case 0x20A4: cReplace = (char)231;
- break;
- case 0x20A7: cReplace = (char)227;
- break;
- case 0x20A8: cReplace = (char)234;
- break;
- case 0x20A9: cReplace = (char)232;
- break;
- case 0x20AB: cReplace = (char)233;
- break;
- case 0x20AC: cReplace = (char)128;
- break;
-
- // Punctuation and other
- case 0x201A: cReplace = (char)130; // SINGLE LOW-9 QUOTATION MARK
- break;
- case 0x0192: cReplace = (char)131; // LATIN SMALL LETTER F WITH HOOK
- break;
- case 0x201E: // DOUBLE LOW-9 QUOTATION MARK
- case 0x301F: // LOW DOUBLE PRIME QUOTATION MARK
- cReplace = (char)132;
- break;
- case 0x2026: cReplace = (char)133; // HORIZONTAL ELLIPSES
- break;
- case 0x2020: cReplace = (char)134; // DAGGER
- break;
- case 0x2021: cReplace = (char)135; // DOUBLE DAGGER
- break;
- case 0x02C6: cReplace = (char)136; // MODIFIER LETTER CIRCUMFLEX ACCENT
- break;
- case 0x2030: cReplace = (char)137; // PER MILLE SIGN
- break;
- case 0x0160: cReplace = (char)138; // LATIN CAPITAL LETTER S WITH CARON
- break;
- case 0x2039: cReplace = (char)139; // SINGLE LEFT-POINTING ANGLE QUOTATION MARK
- break;
- case 0x0152: cReplace = (char)140; // LATIN CAPITAL LIGATURE OE
- break;
- case 0x017D: cReplace = (char)142; // LATIN CAPITAL LETTER Z WITH CARON
- break;
- case 0x2018: // LEFT SINGLE QUOTATION MARK
- case 0x02BB: // MODIFIER LETTER TURNED COMMA
- cReplace = (char)145;
- break;
- case 0x2019: // RIGHT SINGLE QUOTATION MARK
- case 0x02BC: // MODIFIER LETTER APOSTROPHE
- cReplace = (char)146;
- break;
- case 0x201C: // LEFT DOUBLE QUOTATION MARK
- case 0x301D: // REVERSED DOUBLE PRIME QUOTATION MARK
- cReplace = (char)147;
- break;
- case 0x201D: // RIGHT DOUBLE QUOTATION MARK
- case 0x301E: // REVERSED DOUBLE PRIME QUOTATION MARK
- cReplace = (char)148;
- break;
- case 0x2022: cReplace = (char)149; // BULLET
- break;
- case 0x2013: cReplace = (char)150; // EN DASH
- break;
- case 0x2014: cReplace = (char)151; // EM DASH
- break;
- case 0x02DC: cReplace = (char)152; // SMALL TILDE
- break;
- case 0x2122: cReplace = (char)153; // TRADE MARK SIGN
- break;
- case 0x0161: cReplace = (char)154; // LATIN SMALL LETTER S WITH CARON
- break;
- case 0x203A: cReplace = (char)155; // SINGLE RIGHT-POINTING ANGLE QUOTATION MARK
- break;
- case 0x0153: cReplace = (char)156; // LATIN SMALL LIGATURE OE
- break;
- case 0x017E: cReplace = (char)158; // LATIN SMALL LETTER Z WITH CARON
- break;
- case 0x0178: cReplace = (char)159; // LATIN CAPITAL LETTER Y WITH DIAERESIS
- break;
- case 0x00B6: cReplace = (char)222; // PILCROW SIGN / PARAGRAPH SIGN
- break;
- }
-
- if ( cReplace )
- {
- // return replacement character from 'StarBats'
- rFont.SetName( "StarBats" );
- rFont.SetCharSet( CHARSET_SYMBOL );
- }
- else
- {
- // return replacement character from original font
- cReplace = String::ConvertFromUnicode( cUnicode, rFont.GetCharSet(), TRUE );
- }
- }
-
- return cReplace;
-}
-
-#endif // ENABLEUNICODE