X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4f37154e988c597e32a840e43783cf0b23e5f8b4..3e1924dd5f5744c3e2a8973de9b3e4f372b7fd85:/src/generic/dcpsg.cpp diff --git a/src/generic/dcpsg.cpp b/src/generic/dcpsg.cpp index a2762fd7e4..c7a349ce76 100644 --- a/src/generic/dcpsg.cpp +++ b/src/generic/dcpsg.cpp @@ -236,23 +236,18 @@ static char wxPostScriptHeaderReencodeISO2[] = //------------------------------------------------------------------------------- -#if wxUSE_NEW_DC - IMPLEMENT_DYNAMIC_CLASS(wxPostScriptDC, wxDC) wxPostScriptDC::wxPostScriptDC() + : wxDC(new wxPostScriptDCImpl(this)) { - m_pimpl = new wxPostScriptImplDC( this ); } wxPostScriptDC::wxPostScriptDC(const wxPrintData& printData) + : wxDC(new wxPostScriptDCImpl(this, printData)) { - m_pimpl = new wxPostScriptImplDC( this, printData ); } -#endif - - // conversion static const double RAD2DEG = 180.0 / M_PI; @@ -267,62 +262,48 @@ static const double DEV2PS = 72.0 / 600.0; #define YLOG2DEVREL(x) ((double)(LogicalToDeviceYRel(x)) * DEV2PS) -#if wxUSE_NEW_DC -IMPLEMENT_ABSTRACT_CLASS(wxPostScriptImplDC, wxImplDC) -#else -IMPLEMENT_ABSTRACT_CLASS(wxPostScriptDC, wxDC) -#endif +IMPLEMENT_ABSTRACT_CLASS(wxPostScriptDCImpl, wxDCImpl) //------------------------------------------------------------------------------- -#if wxUSE_NEW_DC -wxPostScriptImplDC::wxPostScriptImplDC( wxPostScriptDC *owner ) : - wxImplDC( owner ) +wxPostScriptDCImpl::wxPostScriptDCImpl( wxPostScriptDC *owner ) : + wxDCImpl( owner ) { Init(); m_pageHeight = 842 * PS2DEV; - + m_ok = true; } -wxPostScriptImplDC::wxPostScriptImplDC( wxPostScriptDC *owner, const wxPrintData& data ) : - wxImplDC( owner ) +wxPostScriptDCImpl::wxPostScriptDCImpl( wxPostScriptDC *owner, const wxPrintData& data ) : + wxDCImpl( owner ) { Init(); - + // this calculates m_pageHeight required for // taking the inverted Y axis into account SetPrintData( data ); m_ok = true; } -#endif -#if wxUSE_NEW_DC -wxPostScriptImplDC::wxPostScriptImplDC( wxPrinterDC *owner ) : - wxImplDC( owner ) -#else -wxPostScriptDC::wxPostScriptDC() -#endif +wxPostScriptDCImpl::wxPostScriptDCImpl( wxPrinterDC *owner ) : + wxDCImpl( owner ) { Init(); m_pageHeight = 842 * PS2DEV; - + m_ok = true; } -#if wxUSE_NEW_DC -wxPostScriptImplDC::wxPostScriptImplDC( wxPrinterDC *owner, const wxPrintData& data ) : - wxImplDC( owner ) -#else -wxPostScriptDC::wxPostScriptDC( const wxPrintData& data ) -#endif +wxPostScriptDCImpl::wxPostScriptDCImpl( wxPrinterDC *owner, const wxPrintData& data ) : + wxDCImpl( owner ) { Init(); - + // this calculates m_pageHeight required for // taking the inverted Y axis into account SetPrintData( data ); @@ -330,7 +311,7 @@ wxPostScriptDC::wxPostScriptDC( const wxPrintData& data ) m_ok = true; } -void wxPostScriptImplDC::Init() +void wxPostScriptDCImpl::Init() { m_pstream = (FILE*) NULL; @@ -347,7 +328,7 @@ void wxPostScriptImplDC::Init() } -wxPostScriptImplDC::~wxPostScriptImplDC () +wxPostScriptDCImpl::~wxPostScriptDCImpl () { if (m_pstream) { @@ -356,12 +337,12 @@ wxPostScriptImplDC::~wxPostScriptImplDC () } } -bool wxPostScriptImplDC::IsOk() const +bool wxPostScriptDCImpl::IsOk() const { return m_ok; } -wxRect wxPostScriptImplDC::GetPaperRect() +wxRect wxPostScriptDCImpl::GetPaperRect() { int w = 0; int h = 0; @@ -369,26 +350,22 @@ wxRect wxPostScriptImplDC::GetPaperRect() return wxRect(0,0,w,h); } -int wxPostScriptImplDC::GetResolution() +int wxPostScriptDCImpl::GetResolution() { return DPI; } -void wxPostScriptImplDC::DoSetClippingRegion (wxCoord x, wxCoord y, wxCoord w, wxCoord h) +void wxPostScriptDCImpl::DoSetClippingRegion (wxCoord x, wxCoord y, wxCoord w, wxCoord h) { wxCHECK_RET( m_ok , wxT("invalid postscript dc") ); if (m_clipping) DestroyClippingRegion(); -#if wxUSE_NEW_DC m_clipX1 = x; m_clipY1 = y; m_clipX2 = x + w; m_clipY2 = y + h; -#else - wxDC::DoSetClippingRegion(x, y, w, h); -#endif m_clipping = true; @@ -409,7 +386,7 @@ void wxPostScriptImplDC::DoSetClippingRegion (wxCoord x, wxCoord y, wxCoord w, w } -void wxPostScriptImplDC::DestroyClippingRegion() +void wxPostScriptDCImpl::DestroyClippingRegion() { wxCHECK_RET( m_ok , wxT("invalid postscript dc") ); @@ -419,38 +396,34 @@ void wxPostScriptImplDC::DestroyClippingRegion() PsPrint( "grestore\n" ); } -#if wxUSE_NEW_DC - wxImplDC::DestroyClippingRegion(); -#else - wxDC::DestroyClippingRegion(); -#endif + wxDCImpl::DestroyClippingRegion(); } -void wxPostScriptImplDC::Clear() +void wxPostScriptDCImpl::Clear() { // This should fail silently to avoid unnecessary // asserts - // wxFAIL_MSG( wxT("wxPostScriptImplDC::Clear not implemented.") ); + // wxFAIL_MSG( wxT("wxPostScriptDCImpl::Clear not implemented.") ); } -bool wxPostScriptImplDC::DoFloodFill (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), const wxColour &WXUNUSED(col), int WXUNUSED(style)) +bool wxPostScriptDCImpl::DoFloodFill (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), const wxColour &WXUNUSED(col), int WXUNUSED(style)) { - wxFAIL_MSG( wxT("wxPostScriptImplDC::FloodFill not implemented.") ); + wxFAIL_MSG( wxT("wxPostScriptDCImpl::FloodFill not implemented.") ); return false; } -bool wxPostScriptImplDC::DoGetPixel (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), wxColour * WXUNUSED(col)) const +bool wxPostScriptDCImpl::DoGetPixel (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y), wxColour * WXUNUSED(col)) const { - wxFAIL_MSG( wxT("wxPostScriptImplDC::GetPixel not implemented.") ); + wxFAIL_MSG( wxT("wxPostScriptDCImpl::GetPixel not implemented.") ); return false; } -void wxPostScriptImplDC::DoCrossHair (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y)) +void wxPostScriptDCImpl::DoCrossHair (wxCoord WXUNUSED(x), wxCoord WXUNUSED(y)) { - wxFAIL_MSG( wxT("wxPostScriptImplDC::CrossHair not implemented.") ); + wxFAIL_MSG( wxT("wxPostScriptDCImpl::CrossHair not implemented.") ); } -void wxPostScriptImplDC::DoDrawLine (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2) +void wxPostScriptDCImpl::DoDrawLine (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -472,7 +445,7 @@ void wxPostScriptImplDC::DoDrawLine (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord CalcBoundingBox( x2, y2 ); } -void wxPostScriptImplDC::DoDrawArc (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2, wxCoord xc, wxCoord yc) +void wxPostScriptDCImpl::DoDrawArc (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord y2, wxCoord xc, wxCoord yc) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -550,7 +523,7 @@ void wxPostScriptImplDC::DoDrawArc (wxCoord x1, wxCoord y1, wxCoord x2, wxCoord } } -void wxPostScriptImplDC::DoDrawEllipticArc(wxCoord x,wxCoord y,wxCoord w,wxCoord h,double sa,double ea) +void wxPostScriptDCImpl::DoDrawEllipticArc(wxCoord x,wxCoord y,wxCoord w,wxCoord h,double sa,double ea) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -604,7 +577,7 @@ void wxPostScriptImplDC::DoDrawEllipticArc(wxCoord x,wxCoord y,wxCoord w,wxCoord } } -void wxPostScriptImplDC::DoDrawPoint (wxCoord x, wxCoord y) +void wxPostScriptDCImpl::DoDrawPoint (wxCoord x, wxCoord y) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -625,7 +598,7 @@ void wxPostScriptImplDC::DoDrawPoint (wxCoord x, wxCoord y) CalcBoundingBox( x, y ); } -void wxPostScriptImplDC::DoDrawPolygon (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle) +void wxPostScriptDCImpl::DoDrawPolygon (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -695,7 +668,7 @@ void wxPostScriptImplDC::DoDrawPolygon (int n, wxPoint points[], wxCoord xoffset } } -void wxPostScriptImplDC::DoDrawPolyPolygon (int n, int count[], wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle) +void wxPostScriptDCImpl::DoDrawPolyPolygon (int n, int count[], wxPoint points[], wxCoord xoffset, wxCoord yoffset, int fillStyle) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -771,7 +744,7 @@ void wxPostScriptImplDC::DoDrawPolyPolygon (int n, int count[], wxPoint points[] } } -void wxPostScriptImplDC::DoDrawLines (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset) +void wxPostScriptDCImpl::DoDrawLines (int n, wxPoint points[], wxCoord xoffset, wxCoord yoffset) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -805,7 +778,7 @@ void wxPostScriptImplDC::DoDrawLines (int n, wxPoint points[], wxCoord xoffset, PsPrint( "stroke\n" ); } -void wxPostScriptImplDC::DoDrawRectangle (wxCoord x, wxCoord y, wxCoord width, wxCoord height) +void wxPostScriptDCImpl::DoDrawRectangle (wxCoord x, wxCoord y, wxCoord width, wxCoord height) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -859,7 +832,7 @@ void wxPostScriptImplDC::DoDrawRectangle (wxCoord x, wxCoord y, wxCoord width, w } } -void wxPostScriptImplDC::DoDrawRoundedRectangle (wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius) +void wxPostScriptDCImpl::DoDrawRoundedRectangle (wxCoord x, wxCoord y, wxCoord width, wxCoord height, double radius) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -941,7 +914,7 @@ void wxPostScriptImplDC::DoDrawRoundedRectangle (wxCoord x, wxCoord y, wxCoord w } } -void wxPostScriptImplDC::DoDrawEllipse (wxCoord x, wxCoord y, wxCoord width, wxCoord height) +void wxPostScriptDCImpl::DoDrawEllipse (wxCoord x, wxCoord y, wxCoord width, wxCoord height) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -983,7 +956,7 @@ void wxPostScriptImplDC::DoDrawEllipse (wxCoord x, wxCoord y, wxCoord width, wxC } } -void wxPostScriptImplDC::DoDrawIcon( const wxIcon& icon, wxCoord x, wxCoord y ) +void wxPostScriptDCImpl::DoDrawIcon( const wxIcon& icon, wxCoord x, wxCoord y ) { DoDrawBitmap( icon, x, y, true ); } @@ -991,7 +964,7 @@ void wxPostScriptImplDC::DoDrawIcon( const wxIcon& icon, wxCoord x, wxCoord y ) /* this has to be char, not wxChar */ static char hexArray[] = "0123456789ABCDEF"; -void wxPostScriptImplDC::DoDrawBitmap( const wxBitmap& bitmap, wxCoord x, wxCoord y, bool WXUNUSED(useMask) ) +void wxPostScriptDCImpl::DoDrawBitmap( const wxBitmap& bitmap, wxCoord x, wxCoord y, bool WXUNUSED(useMask) ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1061,7 +1034,7 @@ void wxPostScriptImplDC::DoDrawBitmap( const wxBitmap& bitmap, wxCoord x, wxCoor PsPrint( "origstate restore\n" ); } -void wxPostScriptImplDC::SetFont( const wxFont& font ) +void wxPostScriptDCImpl::SetFont( const wxFont& font ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1155,7 +1128,7 @@ void wxPostScriptImplDC::SetFont( const wxFont& font ) PsPrint( buffer ); } -void wxPostScriptImplDC::SetPen( const wxPen& pen ) +void wxPostScriptDCImpl::SetPen( const wxPen& pen ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1263,7 +1236,7 @@ void wxPostScriptImplDC::SetPen( const wxPen& pen ) } } -void wxPostScriptImplDC::SetBrush( const wxBrush& brush ) +void wxPostScriptDCImpl::SetBrush( const wxBrush& brush ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1307,7 +1280,7 @@ void wxPostScriptImplDC::SetBrush( const wxBrush& brush ) } } -void wxPostScriptImplDC::DoDrawText( const wxString& text, wxCoord x, wxCoord y ) +void wxPostScriptDCImpl::DoDrawText( const wxString& text, wxCoord x, wxCoord y ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1369,11 +1342,9 @@ void wxPostScriptImplDC::DoDrawText( const wxString& text, wxCoord x, wxCoord y PsPrint( buffer ); PsPrint( "(" ); - size_t len = strlen(textbuf); - size_t i; - for (i = 0; i < len; i++) + for ( const char *p = textbuf; *p != '\0'; p++ ) { - int c = (unsigned char) textbuf[i]; + int c = (unsigned char)*p; if (c == ')' || c == '(' || c == '\\') { /* Cope with special characters */ @@ -1415,7 +1386,7 @@ void wxPostScriptImplDC::DoDrawText( const wxString& text, wxCoord x, wxCoord y CalcBoundingBox( x + size * text.length() * 2/3 , y ); } -void wxPostScriptImplDC::DoDrawRotatedText( const wxString& text, wxCoord x, wxCoord y, double angle ) +void wxPostScriptDCImpl::DoDrawRotatedText( const wxString& text, wxCoord x, wxCoord y, double angle ) { if ( wxIsNullDouble(angle) ) { @@ -1477,26 +1448,27 @@ void wxPostScriptImplDC::DoDrawRotatedText( const wxString& text, wxCoord x, wxC PsPrint( "(" ); const wxWX2MBbuf textbuf = text.mb_str(); - size_t len = strlen(textbuf); - size_t i; - for (i = 0; i < len; i++) + if ( textbuf ) { - int c = (unsigned char) textbuf[i]; - if (c == ')' || c == '(' || c == '\\') - { - /* Cope with special characters */ - PsPrint( "\\" ); - PsPrint( (char) c ); - } - else if ( c >= 128 ) - { - /* Cope with character codes > 127 */ - buffer.Printf( "\\%o", c); - PsPrint( buffer ); - } - else + for ( const char *p = textbuf; *p != '\0'; p++ ) { - PsPrint( (char) c ); + int c = (unsigned char)*p; + if (c == ')' || c == '(' || c == '\\') + { + /* Cope with special characters */ + PsPrint( "\\" ); + PsPrint( (char) c ); + } + else if ( c >= 128 ) + { + /* Cope with character codes > 127 */ + buffer.Printf( "\\%o", c); + PsPrint( buffer ); + } + else + { + PsPrint( (char) c ); + } } } @@ -1530,18 +1502,18 @@ void wxPostScriptImplDC::DoDrawRotatedText( const wxString& text, wxCoord x, wxC CalcBoundingBox( x + size * text.length() * 2/3 , y ); } -void wxPostScriptImplDC::SetBackground (const wxBrush& brush) +void wxPostScriptDCImpl::SetBackground (const wxBrush& brush) { m_backgroundBrush = brush; } -void wxPostScriptImplDC::SetLogicalFunction (int WXUNUSED(function)) +void wxPostScriptDCImpl::SetLogicalFunction (int WXUNUSED(function)) { - wxFAIL_MSG( wxT("wxPostScriptImplDC::SetLogicalFunction not implemented.") ); + wxFAIL_MSG( wxT("wxPostScriptDCImpl::SetLogicalFunction not implemented.") ); } #if wxUSE_SPLINES -void wxPostScriptImplDC::DoDrawSpline( const wxPointList *points ) +void wxPostScriptDCImpl::DoDrawSpline( const wxPointList *points ) { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1622,13 +1594,13 @@ void wxPostScriptImplDC::DoDrawSpline( const wxPointList *points ) } #endif // wxUSE_SPLINES -wxCoord wxPostScriptImplDC::GetCharWidth() const +wxCoord wxPostScriptDCImpl::GetCharWidth() const { // Chris Breeze: reasonable approximation using wxMODERN/Courier return (wxCoord) (GetCharHeight() * 72.0 / 120.0); } -void wxPostScriptImplDC::SetPrintData(const wxPrintData& data) +void wxPostScriptDCImpl::SetPrintData(const wxPrintData& data) { m_printData = data; @@ -1649,48 +1621,11 @@ void wxPostScriptImplDC::SetPrintData(const wxPrintData& data) m_pageHeight = h * PS2DEV; } -#if wxUSE_NEW_DC -#else -void wxPostScriptImplDC::SetAxisOrientation( bool xLeftRight, bool yBottomUp ) -{ - wxDCBase::SetAxisOrientation(xLeftRight,yBottomUp); -} - -void wxPostScriptImplDC::SetMapMode(int mode) -{ - wxDCBase::SetMapMode(mode); -} - -void wxPostScriptImplDC::SetUserScale(double x, double y) -{ - wxDCBase::SetUserScale(x,y); -} - -void wxPostScriptImplDC::SetLogicalScale(double x, double y) -{ - wxDCBase::SetLogicalScale(x,y); -} - -void wxPostScriptImplDC::SetLogicalOrigin(wxCoord x, wxCoord y) -{ - wxDCBase::SetLogicalOrigin(x,y); -} - -void wxPostScriptImplDC::SetDeviceOrigin(wxCoord x, wxCoord y) -{ - wxDCBase::SetDeviceOrigin(x,y); -} -#endif - -void wxPostScriptImplDC::ComputeScaleAndOrigin() +void wxPostScriptDCImpl::ComputeScaleAndOrigin() { const wxRealPoint origScale(m_scaleX, m_scaleY); -#if wxUSE_NEW_DC - wxImplDC::ComputeScaleAndOrigin(); -#else - wxDC::ComputeScaleAndOrigin(); -#endif + wxDCImpl::ComputeScaleAndOrigin(); // If scale has changed call SetPen to recalulate the line width // and SetFont to recalculate font size @@ -1701,7 +1636,7 @@ void wxPostScriptImplDC::ComputeScaleAndOrigin() } } -void wxPostScriptImplDC::DoGetSize(int* width, int* height) const +void wxPostScriptDCImpl::DoGetSize(int* width, int* height) const { wxPaperSize id = m_printData.GetPaperId(); @@ -1731,7 +1666,7 @@ void wxPostScriptImplDC::DoGetSize(int* width, int* height) const *height = wxRound( h * PS2DEV ); } -void wxPostScriptImplDC::DoGetSizeMM(int *width, int *height) const +void wxPostScriptDCImpl::DoGetSizeMM(int *width, int *height) const { wxPaperSize id = m_printData.GetPaperId(); @@ -1759,13 +1694,13 @@ void wxPostScriptImplDC::DoGetSizeMM(int *width, int *height) const } // Resolution in pixels per logical inch -wxSize wxPostScriptImplDC::GetPPI(void) const +wxSize wxPostScriptDCImpl::GetPPI(void) const { return wxSize( DPI, DPI ); } -bool wxPostScriptImplDC::StartDoc( const wxString& message ) +bool wxPostScriptDCImpl::StartDoc( const wxString& message ) { wxCHECK_MSG( m_ok, false, wxT("invalid postscript dc") ); @@ -1854,7 +1789,7 @@ bool wxPostScriptImplDC::StartDoc( const wxString& message ) return true; } -void wxPostScriptImplDC::EndDoc () +void wxPostScriptDCImpl::EndDoc () { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1954,7 +1889,7 @@ void wxPostScriptImplDC::EndDoc () #endif } -void wxPostScriptImplDC::StartPage() +void wxPostScriptDCImpl::StartPage() { wxCHECK_RET( m_ok, wxT("invalid postscript dc") ); @@ -1992,14 +1927,14 @@ void wxPostScriptImplDC::StartPage() PsPrint( "90 rotate\n" ); } -void wxPostScriptImplDC::EndPage () +void wxPostScriptDCImpl::EndPage () { wxCHECK_RET( m_ok , wxT("invalid postscript dc") ); PsPrint( "showpage\n" ); } -bool wxPostScriptImplDC::DoBlit( wxCoord xdest, wxCoord ydest, +bool wxPostScriptDCImpl::DoBlit( wxCoord xdest, wxCoord ydest, wxCoord fwidth, wxCoord fheight, wxDC *source, wxCoord xsrc, wxCoord ysrc, @@ -2022,7 +1957,7 @@ bool wxPostScriptImplDC::DoBlit( wxCoord xdest, wxCoord ydest, return true; } -wxCoord wxPostScriptImplDC::GetCharHeight() const +wxCoord wxPostScriptDCImpl::GetCharHeight() const { if (m_font.Ok()) return m_font.GetPointSize(); @@ -2030,7 +1965,7 @@ wxCoord wxPostScriptImplDC::GetCharHeight() const return 12; } -void wxPostScriptImplDC::PsPrint( const wxString& str ) +void wxPostScriptDCImpl::PsPrint( const wxString& str ) { const wxCharBuffer psdata(str.utf8_str()); @@ -2057,7 +1992,7 @@ void wxPostScriptImplDC::PsPrint( const wxString& str ) } } -void wxPostScriptImplDC::DoGetTextExtent(const wxString& string, +void wxPostScriptDCImpl::DoGetTextExtent(const wxString& string, wxCoord *x, wxCoord *y, wxCoord *descent, wxCoord *externalLeading, const wxFont *theFont ) const @@ -2352,13 +2287,13 @@ void wxPostScriptImplDC::DoGetTextExtent(const wxString& string, / these values from AFM files, too. Maybe later ... */ // NB: casts to int are needed to suppress gcc 3.3 warnings - lastWidths[196] = lastWidths[(int)'A']; // Ä - lastWidths[228] = lastWidths[(int)'a']; // ä - lastWidths[214] = lastWidths[(int)'O']; // Ö - lastWidths[246] = lastWidths[(int)'o']; // ö - lastWidths[220] = lastWidths[(int)'U']; // Ü - lastWidths[252] = lastWidths[(int)'u']; // ü - lastWidths[223] = lastWidths[(int)251]; // ß + lastWidths[196] = lastWidths[(int)'A']; // U+00C4 A Umlaute + lastWidths[228] = lastWidths[(int)'a']; // U+00E4 a Umlaute + lastWidths[214] = lastWidths[(int)'O']; // U+00D6 O Umlaute + lastWidths[246] = lastWidths[(int)'o']; // U+00F6 o Umlaute + lastWidths[220] = lastWidths[(int)'U']; // U+00DC U Umlaute + lastWidths[252] = lastWidths[(int)'u']; // U+00FC u Umlaute + lastWidths[223] = lastWidths[(int)251]; // U+00DF eszett (scharfes s) /* JC: calculate UnderlineThickness/UnderlinePosition */