mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Use the shiny new character-set library to handle conversion from Unicode
to Mac OS Roman for display if the Unicode Converter isn't around. Support for Mac character sets other than Roman (e.g. the variant used by the Apple VT100 font) is still absent. [originally from svn r2401]
This commit is contained in:
parent
720c09f576
commit
491f7be9fc
2
Recipe
2
Recipe
@ -146,4 +146,4 @@ plink : [U] uxplink uxcons NONSSH UXSSH be_all logging UXMISC
|
|||||||
|
|
||||||
PuTTY : [M] terminal wcwidth tree234 misc ldisc ldiscucs
|
PuTTY : [M] terminal wcwidth tree234 misc ldisc ldiscucs
|
||||||
+ logging settings be_none mac macdlg macstore macterm macucs
|
+ logging settings be_none mac macdlg macstore macterm macucs
|
||||||
+ mac_res.rsrc testback
|
+ mac_res.rsrc testback CHARSET
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: macterm.c,v 1.28 2002/12/31 20:11:38 ben Exp $ */
|
/* $Id: macterm.c,v 1.29 2002/12/31 22:49:03 ben Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1999 Simon Tatham
|
* Copyright (c) 1999 Simon Tatham
|
||||||
* Copyright (c) 1999, 2002 Ben Harris
|
* Copyright (c) 1999, 2002 Ben Harris
|
||||||
@ -60,6 +60,7 @@
|
|||||||
|
|
||||||
#include "macresid.h"
|
#include "macresid.h"
|
||||||
#include "putty.h"
|
#include "putty.h"
|
||||||
|
#include "charset.h"
|
||||||
#include "mac.h"
|
#include "mac.h"
|
||||||
#include "storage.h"
|
#include "storage.h"
|
||||||
#include "terminal.h"
|
#include "terminal.h"
|
||||||
@ -951,7 +952,10 @@ void do_text(Context ctx, int x, int y, char *text, int len,
|
|||||||
RgnHandle textrgn;
|
RgnHandle textrgn;
|
||||||
char mactextbuf[1024];
|
char mactextbuf[1024];
|
||||||
UniChar unitextbuf[1024];
|
UniChar unitextbuf[1024];
|
||||||
|
wchar_t *unitextptr;
|
||||||
int i;
|
int i;
|
||||||
|
ByteCount iread, olen;
|
||||||
|
OSStatus err;
|
||||||
|
|
||||||
assert(len <= 1024);
|
assert(len <= 1024);
|
||||||
|
|
||||||
@ -965,23 +969,29 @@ void do_text(Context ctx, int x, int y, char *text, int len,
|
|||||||
if (!RectInRgn(&a.textrect, s->window->visRgn))
|
if (!RectInRgn(&a.textrect, s->window->visRgn))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (s->uni_to_font != NULL) {
|
/* Unpack Unicode from the mad format we get passed */
|
||||||
ByteCount iread, olen;
|
|
||||||
OSStatus err;
|
|
||||||
|
|
||||||
for (i = 0; i < len; i++)
|
for (i = 0; i < len; i++)
|
||||||
unitextbuf[i] = (unsigned char)text[i] | (attr & CSET_MASK);
|
unitextbuf[i] = (unsigned char)text[i] | (attr & CSET_MASK);
|
||||||
|
|
||||||
|
if (s->uni_to_font != NULL) {
|
||||||
err = ConvertFromUnicodeToText(s->uni_to_font, len * sizeof(UniChar),
|
err = ConvertFromUnicodeToText(s->uni_to_font, len * sizeof(UniChar),
|
||||||
unitextbuf, kUnicodeUseFallbacksMask,
|
unitextbuf, kUnicodeUseFallbacksMask,
|
||||||
0, NULL, NULL, NULL,
|
0, NULL, NULL, NULL,
|
||||||
1024, &iread, &olen, mactextbuf);
|
1024, &iread, &olen, mactextbuf);
|
||||||
if (err == noErr || err == kTECUsedFallbacksStatus)
|
if (err != noErr && err != kTECUsedFallbacksStatus)
|
||||||
text = mactextbuf; len = olen;
|
/* XXX Should handle this more sensibly */
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
/* XXX this is bogus if wchar_t and UniChar are different sizes. */
|
||||||
|
unitextptr = (wchar_t *)unitextbuf;
|
||||||
|
/* XXX Should choose charset based on script, font etc. */
|
||||||
|
olen = charset_from_unicode(&unitextptr, &len, mactextbuf, 1024,
|
||||||
|
CS_MAC_ROMAN, NULL, ".", 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
a.s = s;
|
a.s = s;
|
||||||
a.text = text;
|
a.text = mactextbuf;
|
||||||
a.len = len;
|
a.len = olen;
|
||||||
a.attr = attr;
|
a.attr = attr;
|
||||||
a.lattr = lattr;
|
a.lattr = lattr;
|
||||||
a.numer.h = a.numer.v = a.denom.h = a.denom.v = 1;
|
a.numer.h = a.numer.v = a.denom.h = a.denom.v = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user