summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sw/source/filter/ww8/ww8par.hxx2
-rw-r--r--sw/source/filter/ww8/ww8par2.cxx2
-rw-r--r--sw/source/filter/ww8/ww8par5.cxx4
-rw-r--r--sw/source/filter/ww8/ww8par6.cxx80
-rw-r--r--sw/source/filter/ww8/ww8scan.cxx30
-rw-r--r--sw/source/filter/ww8/ww8struc.hxx2
6 files changed, 45 insertions, 75 deletions
diff --git a/sw/source/filter/ww8/ww8par.hxx b/sw/source/filter/ww8/ww8par.hxx
index 4613727d9ef3..4409fdb77771 100644
--- a/sw/source/filter/ww8/ww8par.hxx
+++ b/sw/source/filter/ww8/ww8par.hxx
@@ -1344,7 +1344,7 @@ private:
const bool bFirstLineOfStSet = false,
const bool bLeftIndentSet = false );
- bool GetFontParams(sal_uInt16, FontFamily&, String&, FontPitch&,
+ bool GetFontParams(sal_uInt16, FontFamily&, OUString&, FontPitch&,
rtl_TextEncoding&);
bool SetNewFontAttr(sal_uInt16 nFCode, bool bSetEnums, sal_uInt16 nWhich);
void ResetCharSetVars();
diff --git a/sw/source/filter/ww8/ww8par2.cxx b/sw/source/filter/ww8/ww8par2.cxx
index 3bf32a748456..955266eb5842 100644
--- a/sw/source/filter/ww8/ww8par2.cxx
+++ b/sw/source/filter/ww8/ww8par2.cxx
@@ -645,7 +645,7 @@ void SwWW8ImplReader::SetAnlvStrings(SwNumFmt &rNum, WW8_ANLV &rAV,
if( bListSymbol )
{
FontFamily eFamily;
- String aName;
+ OUString aName;
FontPitch ePitch;
if( GetFontParams( SVBT16ToShort( rAV.ftc ), eFamily, aName,
diff --git a/sw/source/filter/ww8/ww8par5.cxx b/sw/source/filter/ww8/ww8par5.cxx
index ea6cd218e766..c4383ed6214d 100644
--- a/sw/source/filter/ww8/ww8par5.cxx
+++ b/sw/source/filter/ww8/ww8par5.cxx
@@ -2355,11 +2355,11 @@ eF_ResT SwWW8ImplReader::Read_F_Macro( WW8FieldDesc*, String& rStr)
for ( ; i < pFonts->GetMax(); i++ )
{
FontFamily eFamily;
- String aFontName;
+ OUString aFontName;
FontPitch ePitch;
CharSet eSrcCharSet;
if( GetFontParams( i, eFamily, aFontName, ePitch, eSrcCharSet )
- && aFontName.EqualsAscii("Wingdings") )
+ && aFontName=="Wingdings" )
{
break;
}
diff --git a/sw/source/filter/ww8/ww8par6.cxx b/sw/source/filter/ww8/ww8par6.cxx
index a01fb7dfbed5..e8766e0cb720 100644
--- a/sw/source/filter/ww8/ww8par6.cxx
+++ b/sw/source/filter/ww8/ww8par6.cxx
@@ -3359,7 +3359,7 @@ void SwWW8ImplReader::Read_UnderlineColor(sal_uInt16, const sal_uInt8* pData, sh
}
}
bool SwWW8ImplReader::GetFontParams( sal_uInt16 nFCode, FontFamily& reFamily,
- String& rName, FontPitch& rePitch, CharSet& reCharSet )
+ OUString& rName, FontPitch& rePitch, CharSet& reCharSet )
{
// Die Defines, aus denen diese Tabellen erzeugt werden, stehen in windows.h
static const FontPitch ePitchA[] =
@@ -3370,14 +3370,14 @@ bool SwWW8ImplReader::GetFontParams( sal_uInt16 nFCode, FontFamily& reFamily,
static const FontFamily eFamilyA[] =
{
FAMILY_DONTKNOW, FAMILY_ROMAN, FAMILY_SWISS, FAMILY_MODERN,
- FAMILY_SCRIPT, FAMILY_DECORATIVE
+ FAMILY_SCRIPT, FAMILY_DECORATIVE, FAMILY_DONTKNOW, FAMILY_DONTKNOW
};
const WW8_FFN* pF = pFonts->GetFont( nFCode ); // Info dazu
if( !pF ) // FontNummer unbekannt ?
return false; // dann ignorieren
- rName = String( pF->sFontname );
+ rName = pF->sFontname;
// pF->prg : Pitch
rePitch = ePitchA[pF->prg];
@@ -3396,62 +3396,34 @@ bool SwWW8ImplReader::GetFontParams( sal_uInt16 nFCode, FontFamily& reFamily,
reCharSet = rtl_getTextEncodingFromWindowsCharset( pF->chs );
}
- // pF->ff : Family
- sal_uInt8 b = pF->ff;
-
// make sure Font Family Code is set correctly
// at least for the most important fonts
// ( might be set wrong when Doc was not created by
// Winword but by third party program like Applixware... )
- /*
- 0: FAMILY_DONTKNOW
- 1: FAMILY_ROMAN
- 2: FAMILY_SWISS
- 3: FAMILY_MODERN
- 4: FAMILY_SCRIPT
- 5: FAMILY_DECORATIVE
- */
-#define FONTNAMETAB_SZ 14
-#define MAX_FONTNAME_ROMAN 6
- static const sal_Char
- // first comes ROMAN
- sFontName0[] = "\x07""Tms Rmn",
- sFontName1[] = "\x07""Timmons",
- sFontName2[] = "\x08""CG Times",
- sFontName3[] = "\x08""MS Serif",
- sFontName4[] = "\x08""Garamond",
- sFontName5[] = "\x11""Times Roman",
- sFontName6[] = "\x15""Times New Roman",
- // from here SWISS --> see above: #define MAX_FONTNAME_ROMAN 6
- sFontName7[] = "\x04""Helv",
- sFontName8[] = "\x05""Arial",
- sFontName9[] = "\x07""Univers",
- sFontName10[]= "\x11""LinePrinter",
- sFontName11[]= "\x11""Lucida Sans",
- sFontName12[]= "\x11""Small Fonts",
- sFontName13[]= "\x13""MS Sans Serif";
- static const sal_Char* const aFontNameTab[ FONTNAMETAB_SZ ] =
- {
- sFontName0, sFontName1, sFontName2, sFontName3,
- sFontName4, sFontName5, sFontName6, sFontName7,
- sFontName8, sFontName9, sFontName10, sFontName11,
- sFontName12, sFontName13
- };
-
- for( sal_uInt16 n = 0; n < FONTNAMETAB_SZ; n++ )
- {
- const sal_Char* pCmp = aFontNameTab[ n ];
- xub_StrLen nLen = *pCmp++;
- if( rName.EqualsIgnoreCaseAscii(pCmp, 0, nLen) )
- {
- b = n <= MAX_FONTNAME_ROMAN ? 1 : 2;
- break;
- }
+ if (rName.startsWithIgnoreAsciiCase("Tms Rmn") ||
+ rName.startsWithIgnoreAsciiCase("Timmons") ||
+ rName.startsWithIgnoreAsciiCase("CG Times") ||
+ rName.startsWithIgnoreAsciiCase("MS Serif") ||
+ rName.startsWithIgnoreAsciiCase("Garamond") ||
+ rName.startsWithIgnoreAsciiCase("Times Roman") ||
+ rName.startsWithIgnoreAsciiCase("Times New Roman"))
+ {
+ reFamily = FAMILY_ROMAN;
+ }
+ else if (rName.startsWithIgnoreAsciiCase("Helv") ||
+ rName.startsWithIgnoreAsciiCase("Arial") ||
+ rName.startsWithIgnoreAsciiCase("Univers") ||
+ rName.startsWithIgnoreAsciiCase("LinePrinter") ||
+ rName.startsWithIgnoreAsciiCase("Lucida Sans") ||
+ rName.startsWithIgnoreAsciiCase("Small Fonts") ||
+ rName.startsWithIgnoreAsciiCase("MS Sans Serif"))
+ {
+ reFamily = FAMILY_SWISS;
}
- if (b < (sizeof(eFamilyA)/sizeof(eFamilyA[0])))
- reFamily = eFamilyA[b];
else
- reFamily = FAMILY_DONTKNOW;
+ {
+ reFamily = eFamilyA[pF->ff];
+ }
return true;
}
@@ -3460,7 +3432,7 @@ bool SwWW8ImplReader::SetNewFontAttr(sal_uInt16 nFCode, bool bSetEnums,
sal_uInt16 nWhich)
{
FontFamily eFamily;
- String aName;
+ OUString aName;
FontPitch ePitch;
CharSet eSrcCharSet;
diff --git a/sw/source/filter/ww8/ww8scan.cxx b/sw/source/filter/ww8/ww8scan.cxx
index 55faadebbfd9..f050025454bd 100644
--- a/sw/source/filter/ww8/ww8scan.cxx
+++ b/sw/source/filter/ww8/ww8scan.cxx
@@ -6133,7 +6133,7 @@ struct WW8_FFN_Ver8 : public WW8_FFN_BASE
};
// #i43762# check font name for illegal characters
-static void lcl_checkFontname( String& sString )
+static void lcl_checkFontname( OUString& sString )
{
// for efficiency, we'd like to use String methods as far as possible.
// Hence, we will:
@@ -6143,24 +6143,23 @@ static void lcl_checkFontname( String& sString )
// completely removed
// convert all invalid chars to \u0001
- sal_Unicode* pBuffer = sString.GetBufferAccess();
- xub_StrLen nLen = sString.Len();
+ OUStringBuffer aBuf(sString);
+ const sal_Int32 nLen = aBuf.getLength();
bool bFound = false;
- for( xub_StrLen n = 0; n < nLen; n++ )
+ for ( sal_Int32 n = 0; n < nLen; ++n )
{
- if( pBuffer[n] < sal_Unicode( 0x20 ) )
+ if ( aBuf[n] < 0x20 )
{
- pBuffer[n] = sal_Unicode( 1 );
+ aBuf[n] = 1;
bFound = true;
}
}
- sString.ReleaseBufferAccess();
+ sString = aBuf.makeStringAndClear();
// if anything was found, remove \u0001 + leading/trailing ';'
if( bFound )
{
- sString = comphelper::string::remove(sString, 1);
- sString = comphelper::string::strip(sString, ';');
+ sString = comphelper::string::strip(sString.replaceAll("\001", ""), ';');
}
}
@@ -6292,22 +6291,22 @@ WW8Fonts::WW8Fonts( SvStream& rSt, WW8Fib& rFib )
rtl_TextEncoding eEnc = WW8Fib::GetFIBCharset(p->chs);
if ((eEnc == RTL_TEXTENCODING_SYMBOL) || (eEnc == RTL_TEXTENCODING_DONTKNOW))
eEnc = RTL_TEXTENCODING_MS_1252;
- p->sFontname = String(pVer6->szFfn, eEnc);
+ p->sFontname = OUString(pVer6->szFfn, rtl_str_getLength(pVer6->szFfn), eEnc);
const sal_uInt16 maxStrSize = sizeof (pVer6->szFfn) / sizeof (pVer6->szFfn[0]);
if (p->ibszAlt && p->ibszAlt < maxStrSize) //don't start after end of string
{
- p->sFontname.Append(';');
- p->sFontname += String(pVer6->szFfn+p->ibszAlt, eEnc);
+ const sal_Char *pAlt = pVer6->szFfn+p->ibszAlt;
+ p->sFontname += ";" + OUString(pAlt, rtl_str_getLength(pAlt), eEnc);
}
else
{
//#i18369# if its a symbol font set Symbol as fallback
if (
RTL_TEXTENCODING_SYMBOL == WW8Fib::GetFIBCharset(p->chs)
- && !p->sFontname.EqualsAscii("Symbol")
+ && p->sFontname!="Symbol"
)
{
- p->sFontname.AppendAscii(";Symbol");
+ p->sFontname += ";Symbol";
}
}
pVer6 = (WW8_FFN_Ver6*)( ((sal_uInt8*)pVer6) + pVer6->cbFfnM1 + 1 );
@@ -6371,12 +6370,11 @@ WW8Fonts::WW8Fonts( SvStream& rSt, WW8Fib& rFib )
p->sFontname = pPrimary;
if (p->ibszAlt && p->ibszAlt < nMaxNullTerminatedPossible)
{
- p->sFontname.Append(';');
sal_Unicode *pSecondary = pPrimary + p->ibszAlt;
#ifdef OSL_BIGENDIAN
swapEndian(pSecondary);
#endif
- p->sFontname.Append(pSecondary);
+ p->sFontname += ";" + OUString(pSecondary);
}
// #i43762# check font name for illegal characters
diff --git a/sw/source/filter/ww8/ww8struc.hxx b/sw/source/filter/ww8/ww8struc.hxx
index 06b3578f93c4..b4ed4a2a32ef 100644
--- a/sw/source/filter/ww8/ww8struc.hxx
+++ b/sw/source/filter/ww8/ww8struc.hxx
@@ -216,7 +216,7 @@ struct WW8_FFN_BASE // Font Descriptor
struct WW8_FFN : public WW8_FFN_BASE
{
// ab Ver8 als Unicode
- String sFontname;// 0x6 bzw. 0x40 ab Ver8 zero terminated string that
+ OUString sFontname;// 0x6 bzw. 0x40 ab Ver8 zero terminated string that
// records name of font.
// Maximal size of szFfn is 65 characters.
// Vorsicht: Dieses Array kann auch kleiner sein!!!