Rewrite fl_encoding_mac_roman.cxx under the driver model.

git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3-porting@11600 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Manolo Gouy 2016-04-13 14:19:13 +00:00
parent b590bc49f9
commit 8653a5353e
4 changed files with 27 additions and 16 deletions

View File

@ -177,6 +177,9 @@ public:
// the implementations of local_to_latin1() and latin1_to_local() are in fl_encoding_latin1.cxx // the implementations of local_to_latin1() and latin1_to_local() are in fl_encoding_latin1.cxx
virtual const char *local_to_latin1(const char *t, int n); virtual const char *local_to_latin1(const char *t, int n);
virtual const char *latin1_to_local(const char *t, int n); virtual const char *latin1_to_local(const char *t, int n);
// the implementations of local_to_mac_roman() and mac_roman_to_local() are in fl_encoding_mac_roman.cxx
virtual const char *local_to_mac_roman(const char *t, int n);
virtual const char *mac_roman_to_local(const char *t, int n);
}; };
#endif // FL_SYSTEM_DRIVER_H #endif // FL_SYSTEM_DRIVER_H

View File

@ -61,6 +61,8 @@ public:
const char *application); const char *application);
virtual const char *local_to_latin1(const char *t, int n); virtual const char *local_to_latin1(const char *t, int n);
virtual const char *latin1_to_local(const char *t, int n); virtual const char *latin1_to_local(const char *t, int n);
virtual const char *local_to_mac_roman(const char *t, int n);
virtual const char *mac_roman_to_local(const char *t, int n);
}; };
#endif // FL_DARWIN_SYSTEM_DRIVER_H #endif // FL_DARWIN_SYSTEM_DRIVER_H

View File

@ -3,7 +3,7 @@
// //
// Convert MSWindows-1252 (Latin-1) encoded text to the local encoding. // Convert MSWindows-1252 (Latin-1) encoded text to the local encoding.
// //
// Copyright 1998-2010 by Bill Spitzak and others. // Copyright 1998-2016 by Bill Spitzak and others.
// //
// This library is free software. Distribution and use rights are outlined in // This library is free software. Distribution and use rights are outlined in
// the file "COPYING" which should have been included with this file. If this // the file "COPYING" which should have been included with this file. If this

View File

@ -3,7 +3,7 @@
// //
// Convert Mac Roman encoded text to the local encoding. // Convert Mac Roman encoded text to the local encoding.
// //
// Copyright 1998-2010 by Bill Spitzak and others. // Copyright 1998-2016 by Bill Spitzak and others.
// //
// This library is free software. Distribution and use rights are outlined in // This library is free software. Distribution and use rights are outlined in
// the file "COPYING" which should have been included with this file. If this // the file "COPYING" which should have been included with this file. If this
@ -16,38 +16,38 @@
// http://www.fltk.org/str.php // http://www.fltk.org/str.php
// //
#include "config_lib.h"
#include <FL/fl_draw.H> #include <FL/fl_draw.H>
#include <FL/Fl_System_Driver.H>
#include <FL/Fl.H>
#include <FL/Enumerations.H> #include <FL/Enumerations.H>
#include <stdlib.h> #include <stdlib.h>
#include "flstring.h" #include "flstring.h"
// These function assume a western code page. If you need to support // These function assume a western code page.
// scripts that are not part of this code page, you might want to
// take a look at FLTK2, which uses utf8 for text encoding.
// //
// By keeping these conversion tables in their own module, they will not // On Mac OS X, nothing need to be converted. We simply return the
// be statically linked (by a smart linker) unless actually used.
//
// On Mac OS X, nothing need to be converted. We simply return the
// original pointer. // original pointer.
// //
// MSWindows and X11 render text in ISO or Latin-1 for western settings. The // MSWindows and X11 render text in ISO or Latin-1 for western settings. The
// lookup tables below will convert all common character codes and replace // lookup tables below will convert all common character codes and replace
// unknown characters with an upsidedown question mark. // unknown characters with an upsidedown question mark.
#ifdef __APPLE__ // PORTME: Fl_Screen_Driver - platform text encoding #ifdef FL_CFG_WIN_COCOA
const char *fl_mac_roman_to_local(const char *t, int) # include "drivers/Darwin/Fl_Darwin_System_Driver.H"
const char *Fl_Darwin_System_Driver::mac_roman_to_local(const char *t, int)
{ {
return t; return t;
} }
const char *fl_local_to_mac_roman(const char *t, int) const char *Fl_Darwin_System_Driver::local_to_mac_roman(const char *t, int)
{ {
return t; return t;
} }
#else #endif
// This table converts MSWindows-1252/Latin 1 into MacRoman encoding // This table converts MSWindows-1252/Latin 1 into MacRoman encoding
static uchar latin2roman[128] = { static uchar latin2roman[128] = {
@ -76,7 +76,7 @@ static uchar roman2latin[128] = {
static char *buf = 0; static char *buf = 0;
static int n_buf = 0; static int n_buf = 0;
const char *fl_local_to_mac_roman(const char *t, int n) const char *Fl_System_Driver::local_to_mac_roman(const char *t, int n)
{ {
if (n==-1) n = (int) strlen(t); if (n==-1) n = (int) strlen(t);
if (n<=n_buf) { if (n<=n_buf) {
@ -97,7 +97,7 @@ const char *fl_local_to_mac_roman(const char *t, int n)
return buf; return buf;
} }
const char *fl_mac_roman_to_local(const char *t, int n) const char *Fl_System_Driver::mac_roman_to_local(const char *t, int n)
{ {
if (n==-1) n = (int) strlen(t); if (n==-1) n = (int) strlen(t);
if (n<=n_buf) { if (n<=n_buf) {
@ -118,7 +118,13 @@ const char *fl_mac_roman_to_local(const char *t, int n)
return buf; return buf;
} }
#endif const char *fl_local_to_mac_roman(const char *t, int n) {
return Fl::system_driver()->local_to_mac_roman(t, n);
}
const char *fl_mac_roman_to_local(const char *t, int n) {
return Fl::system_driver()->mac_roman_to_local(t, n);
}
// //
// End of "$Id$". // End of "$Id$".