/* * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* Portions * Copyright (c) 1995 Regents of the University of Michigan. * All rights reserved. * * charset.c */ #include "portable.h" #ifdef STR_TRANSLATION #include #include #include #include #include #ifdef HAVE_SYS_PARAM_H #include #endif #include "ldap-int.h" void ldap_set_string_translators( LDAP *ld, BERTranslateProc encode_proc, BERTranslateProc decode_proc ) { ld->ld_lber_encode_translate_proc = encode_proc; ld->ld_lber_decode_translate_proc = decode_proc; } void ldap_enable_translation( LDAP *ld, LDAPMessage *entry, int enable ) { unsigned short *optionsp; optionsp = ( entry == NULL ) ? &ld->ld_lberoptions : &entry->lm_ber->ber_options; if ( enable ) { *optionsp |= LBER_TRANSLATE_STRINGS; } else { *optionsp &= ~LBER_TRANSLATE_STRINGS; } } int ldap_translate_from_t61( LDAP *ld, char **bufp, ber_len_t *lenp, int free_input ) { if ( ld->ld_lber_decode_translate_proc == 0 ) { return( LDAP_SUCCESS ); } return( (*ld->ld_lber_decode_translate_proc)( bufp, lenp, free_input )); } int ldap_translate_to_t61( LDAP *ld, char **bufp, ber_len_t *lenp, int free_input ) { if ( ld->ld_lber_encode_translate_proc == 0 ) { return( LDAP_SUCCESS ); } return( (*ld->ld_lber_encode_translate_proc)( bufp, lenp, free_input )); } /* ** Character translation routine notes: * * On entry: bufp points to a "string" to be converted (not necessarily * zero-terminated) and buflenp points to the length of the buffer. * * On exit: bufp should point to a malloc'd result. If free_input is * non-zero then the original bufp will be freed. *buflenp should be * set to the new length. Zero bytes in the input buffer must be left * as zero bytes. * * Return values: any ldap error code (LDAP_SUCCESS if all goes well). */ #ifdef LDAP_CHARSET_8859 #if LDAP_CHARSET_8859 == 88591 #define ISO_8859 1 #elif LDAP_CHARSET_8859 == 88592 #define ISO_8859 2 #elif LDAP_CHARSET_8859 == 88593 #define ISO_8859 3 #elif LDAP_CHARSET_8859 == 88594 #define ISO_8859 4 #elif LDAP_CHARSET_8859 == 88595 #define ISO_8859 5 #elif LDAP_CHARSET_8859 == 88596 #define ISO_8859 6 #elif LDAP_CHARSET_8859 == 88597 #define ISO_8859 7 #elif LDAP_CHARSET_8859 == 88598 #define ISO_8859 8 #elif LDAP_CHARSET_8859 == 88599 #define ISO_8859 9 #elif LDAP_CHARSET_8859 == 885910 #define ISO_8859 10 #else #define ISO_8859 0 #endif /* * the following ISO_8859 to/afrom T.61 character set translation code is * based on the code found in Enrique Silvestre Mora's iso-t61.c, found * as part of this package: * ftp://pereiii.uji.es/pub/uji-ftp/unix/ldap/iso-t61.translation.tar.Z * Enrique is now (10/95) at this address: enrique.silvestre@uv.es * * changes made by mcs@umich.edu 12 October 1995: * Change calling conventions of iso8859_t61() and t61_iso8859() to * match libldap conventions; rename to ldap_8859_to_t61() and * ldap_t61_to_8859(). * Change conversion routines to deal with non-zero terminated strings. * ANSI-ize functions and include prototypes. */ /* iso-t61.c - ISO-T61 translation routines (version: 0.2.1, July-1994) */ /* * Copyright (c) 1994 Enrique Silvestre Mora, Universitat Jaume I, Spain. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that this notice is preserved and that due credit is given * to the Universitat Jaume I. The name of the University * may not be used to endorse or promote products derived from this * software without specific prior written permission. This software * is provided ``as is'' without express or implied warranty. */ #include #include #include /* Character set used: ISO 8859-1, ISO 8859-2, ISO 8859-3, ... */ /* #define ISO_8859 1 */ #ifndef ISO_8859 # define ISO_8859 0 #endif typedef unsigned char Byte; typedef struct { Byte a, b; } Couple; /* Prototypes without LDAP_P(): * 'Byte' in definition incompatible with unprototyped declaration. */ static Byte *c_to_hh ( Byte *o, Byte c ); static Byte *c_to_cc ( Byte *o, const Couple *cc, Byte c ); static int hh_to_c ( const Byte *h ); static Byte *cc_to_t61 ( Byte *o, const Byte *s ); /* Character choosed as base in diacritics alone: NO-BREAK SPACE. (The standard say it must be a blank space, 0x20.) */ #define ALONE 0xA0 static const Couple diacritic[16] = { #if (ISO_8859 == 1) || (ISO_8859 == 9) {0,0}, {'`',0}, {0xb4,0}, {'^',0}, {'~',0}, {0xaf,0}, {'(',ALONE}, {'.',ALONE}, {0xa8,0}, {0,0}, {'0',ALONE}, {0xb8,0}, {0,0}, {'"',ALONE}, {';',ALONE}, {'<',ALONE}, #elif (ISO_8859 == 2) {0,0}, {'`',0}, {0xb4,0}, {'^',0}, {'~',0}, {'-',ALONE}, {0xa2,0}, {0xff,0}, {0xa8,0}, {0,0}, {'0',ALONE}, {0xb8,0}, {0,0}, {0xbd,0}, {0xb2,0}, {0xb7,0} #elif (ISO_8859 == 3) {0,0}, {'`',0}, {0xb4,0}, {'^',0}, {'~',0}, {'-',ALONE}, {0xa2,0}, {0xff,0}, {0xa8,0}, {0,0}, {'0',ALONE}, {0xb8,0}, {0,0}, {'"',ALONE}, {';',ALONE}, {'<',ALONE} #elif (ISO_8859 == 4) {0,0}, {'`',0}, {0xb4,0}, {'^',0}, {'~',0}, {0xaf,0}, {'(',ALONE}, {0xff,0}, {0xa8,0}, {0,0}, {'0',ALONE}, {0xb8,0}, {0,0}, {'"',ALONE}, {0xb2,0}, {0xb7,0} #else {0,0}, {'`',0}, {'\'',ALONE}, {'^',0}, {'~',0}, {'-',ALONE}, {'(',ALONE}, {'.',ALONE}, {':',ALONE}, {0,0}, {'0',ALONE}, {',',ALONE}, {0,0}, {'"',ALONE}, {';',ALONE}, {'<',ALONE} #endif }; /* --- T.61 (T.51) letters with diacritics: conversion to ISO 8859-n ----- A, C, D, E, G, H, I, J, K, L, N, O, R, S, T, U, W, Y, Z. ----------------------------------------------------------------------- */ static const int letter_w_diacritic[16][38] = { #if (ISO_8859 == 1) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc0,0, 0, 0xc8,0, 0, 0xcc,0, 0, 0, 0, 0xd2,0, 0, 0, 0xd9,0, 0, 0, 0xe0,0, 0, 0xe8,0, 0, 0xec,0, 0, 0, 0, 0xf2,0, 0, 0, 0xf9,0, 0, 0, 0xc1,-1, 0, 0xc9,0, 0, 0xcd,0, 0, -1, -1, 0xd3,-1, -1, 0, 0xda,0, 0xdd,-1, 0xe1,-1, 0, 0xe9,0, 0, 0xed,0, 0, -1, -1, 0xf3,-1, -1, 0, 0xfa,0, 0xfd,-1, 0xc2,-1, 0, 0xca,-1, -1, 0xce,-1, 0, 0, 0, 0xd4,0, -1, 0, 0xdb,-1, -1, 0, 0xe2,-1, 0, 0xea,-1, -1, 0xee,-1, 0, 0, 0, 0xf4,0, -1, 0, 0xfb,-1, -1, 0, 0xc3,0, 0, 0, 0, 0, -1, 0, 0, 0, 0xd1,0xd5,0, 0, 0, -1, 0, 0, 0, 0xe3,0, 0, 0, 0, 0, -1, 0, 0, 0, 0xf1,0xf5,0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, -1, -1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, -1, 0, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0xc4,0, 0, 0xcb,0, 0, 0xcf,0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, 0xef,0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, 0xff,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xe5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0xc7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, 0xe7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1 #elif (ISO_8859 == 2) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xc1,0xc6,0, 0xc9,0, 0, 0xcd,0, 0, 0xc5,0xd1,0xd3,0xc0,0xa6,0, 0xda,0, 0xdd,0xac, 0xe1,0xe6,0, 0xe9,0, 0, 0xed,0, 0, 0xe5,0xf1,0xf3,0xe0,0xb6,0, 0xfa,0, 0xfd,0xbc, 0xc2,-1, 0, -1, -1, -1, 0xce,-1, 0, 0, 0, 0xd4,0, -1, 0, -1, -1, -1, 0, 0xe2,-1, 0, -1, -1, -1, 0xee,-1, 0, 0, 0, 0xf4,0, -1, 0, -1, -1, -1, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xc3,0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xe3,0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, -1, -1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xaf, 0, -1, 0, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xbf, 0xc4,0, 0, 0xcb,0, 0, -1, 0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, -1, 0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xd9,0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xf9,0, 0, 0, 0, 0xc7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xaa,0xde,0, 0, 0, 0, 0, 0xe7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xba,0xfe,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xd5,0, 0, 0, 0xdb,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xf5,0, 0, 0, 0xfb,0, 0, 0, 0xa1,0, 0, 0xca,0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xb1,0, 0, 0xea,0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0xc8,0xcf,0xcc,0, 0, 0, 0, 0, 0xa5,0xd2,0, 0xd8,0xa9,0xab,0, 0, 0, 0xae, 0, 0xe8,0xef,0xec,0, 0, 0, 0, 0, 0xb5,0xf2,0, 0xf8,0xb9,0xbb,0, 0, 0, 0xbe #elif (ISO_8859 == 3) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc0,0, 0, 0xc8,0, 0, 0xcc,0, 0, 0, 0, 0xd2,0, 0, 0, 0xd9,0, 0, 0, 0xe0,0, 0, 0xe8,0, 0, 0xec,0, 0, 0, 0, 0xf2,0, 0, 0, 0xf9,0, 0, 0, 0xc1,-1, 0, 0xc9,0, 0, 0xcd,0, 0, -1, -1, 0xd3,-1, -1, 0, 0xda,0, -1, -1, 0xe1,-1, 0, 0xe9,0, 0, 0xed,0, 0, -1, -1, 0xf3,-1, -1, 0, 0xfa,0, -1, -1, 0xc2,0xc6,0, 0xca,0xd8,0xa6,0xce,0xac,0, 0, 0, 0xd4,0, 0xde,0, 0xdb,-1, -1, 0, 0xe2,0xe6,0, 0xea,0xf8,0xb6,0xee,0xbc,0, 0, 0, 0xf4,0, 0xfe,0, 0xfb,-1, -1, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xd1,-1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xf1,-1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xab,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xdd,0, 0, 0, -1, 0, 0, 0, 0xbb,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xfd,0, 0, 0, 0, 0xc5,0, -1, 0xd5,0, 0xa9,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xaf, 0, 0xe5,0, -1, 0xf5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xbf, 0xc4,0, 0, 0xcb,0, 0, 0xcf,0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, 0xef,0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0xc7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xaa,-1, 0, 0, 0, 0, 0, 0xe7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xba,-1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1 #elif (ISO_8859 == 4) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xc1,-1, 0, 0xc9,0, 0, 0xcd,0, 0, -1, -1, -1, -1, -1, 0, 0xda,0, -1, -1, 0xe1,-1, 0, 0xe9,0, 0, 0xed,0, 0, -1, -1, -1, -1, -1, 0, 0xfa,0, -1, -1, 0xc2,-1, 0, -1, -1, -1, 0xce,-1, 0, 0, 0, 0xd4,0, -1, 0, 0xdb,-1, -1, 0, 0xe2,-1, 0, -1, -1, -1, 0xee,-1, 0, 0, 0, 0xf4,0, -1, 0, 0xfb,-1, -1, 0, 0xc3,0, 0, 0, 0, 0, 0xa5,0, 0, 0, -1, 0xd5,0, 0, 0, 0xdd,0, 0, 0, 0xe3,0, 0, 0, 0, 0, 0xb5,0, 0, 0, -1, 0xf5,0, 0, 0, 0xfd,0, 0, 0, 0xc0,0, 0, 0xaa,0, 0, 0xcf,0, 0, 0, 0, 0xd2,0, 0, 0, 0xde,0, 0, 0, 0xe0,0, 0, 0xba,0, 0, 0xef,0, 0, 0, 0, 0xf2,0, 0, 0, 0xfe,0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0xcc,-1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, -1, 0, 0xec,-1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0xc4,0, 0, 0xcb,0, 0, -1, 0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, -1, 0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xe5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0xab,0, 0, 0, 0xd3, 0xa6,0xd1,0, 0xa3,-1, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0xbb,0, 0, 0, 0xf3, 0xb6,0xf1,0, 0xb3,-1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xa1,0, 0, 0xca,0, 0, 0xc7,0, 0, 0, 0, 0, 0, 0, 0, 0xd9,0, 0, 0, 0xb1,0, 0, 0xea,0, 0, 0xe7,0, 0, 0, 0, 0, 0, 0, 0, 0xf9,0, 0, 0, 0, 0xc8,-1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, 0xa9,-1, 0, 0, 0, 0xae, 0, 0xe8,-1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, 0xb9,-1, 0, 0, 0, 0xbe #elif (ISO_8859 == 9) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc0,0, 0, 0xc8,0, 0, 0xcc,0, 0, 0, 0, 0xd2,0, 0, 0, 0xd9,0, 0, 0, 0xe0,0, 0, 0xe8,0, 0, -1, 0, 0, 0, 0, 0xf2,0, 0, 0, 0xf9,0, 0, 0, 0xc1,-1, 0, 0xc9,0, 0, 0xcd,0, 0, -1, -1, 0xd3,-1, -1, 0, 0xda,0, -1, -1, 0xe1,-1, 0, 0xe9,0, 0, 0xed,0, 0, -1, -1, 0xf3,-1, -1, 0, 0xfa,0, -1, -1, 0xc2,-1, 0, 0xca,-1, -1, 0xce,-1, 0, 0, 0, 0xd4,0, -1, 0, 0xdb,-1, -1, 0, 0xe2,-1, 0, -1, -1, -1, 0xee,-1, 0, 0, 0, 0xf4,0, -1, 0, 0xfb,-1, -1, 0, 0xc3,0, 0, 0, 0, 0, -1, 0, 0, 0, 0xd1,0xd5,0, 0, 0, -1, 0, 0, 0, 0xe3,0, 0, 0, 0, 0, -1, 0, 0, 0, 0xf1,0xf5,0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0xef,0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xd0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xf0,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, -1, -1, 0, 0xdd,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, -1, 0, 0xec,-1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0xc4,0, 0, 0xcb,0, 0, 0xcf,0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, -1, 0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, 0xff,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xe5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0xc7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xde,-1, 0, 0, 0, 0, 0, 0xe7,0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, 0xfe,-1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0xea,0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1 #elif (ISO_8859 == 10) 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xc1,-1, 0, 0xc9,0, 0, 0xcd,0, 0, -1, -1, 0xd3,-1, -1, 0, 0xda,0, 0xdd,-1, 0xe1,-1, 0, 0xe9,0, 0, 0xed,0, 0, -1, -1, 0xf3,-1, -1, 0, 0xfa,0, 0xfd,-1, 0xc2,-1, 0, -1, -1, -1, 0xce,-1, 0, 0, 0, 0xd4,0, -1, 0, 0xdb,-1, -1, 0, 0xe2,-1, 0, -1, -1, -1, 0xee,-1, 0, 0, 0, 0xf4,0, -1, 0, 0xfb,-1, -1, 0, 0xc3,0, 0, 0, 0, 0, 0xa5,0, 0, 0, -1, 0xd5,0, 0, 0, 0xd7,0, 0, 0, 0xe3,0, 0, 0, 0, 0, 0xb5,0, 0, 0, -1, 0xf5,0, 0, 0, 0xf7,0, 0, 0, 0xc0,0, 0, 0xa2,0, 0, 0xa4,0, 0, 0, 0, 0xd2,0, 0, 0, 0xae,0, 0, 0, 0xe0,0, 0, 0xb2,0, 0, 0xb4,0, 0, 0, 0, 0xf2,0, 0, 0, 0xbe,0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0xcc,-1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, -1, 0, 0xec,-1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0xc4,0, 0, 0xcb,0, 0, 0xcf,0, 0, 0, 0, 0xd6,0, 0, 0, 0xdc,0, -1, 0, 0xe4,0, 0, 0xeb,0, 0, 0xef,0, 0, 0, 0, 0xf6,0, 0, 0, 0xfc,0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0xc5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0xe5,0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0xa3,0, 0, 0, 0xa6, 0xa8,0xd1,0, -1, -1, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0xb3,0, 0, 0, 0xb6, 0xb8,0xf1,0, -1, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0xa1,0, 0, 0xca,0, 0, 0xc7,0, 0, 0, 0, 0, 0, 0, 0, 0xd9,0, 0, 0, 0xb1,0, 0, 0xea,0, 0, 0xe7,0, 0, 0, 0, 0, 0, 0, 0, 0xf9,0, 0, 0, 0, 0xc8,-1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, 0xaa,-1, 0, 0, 0, 0xac, 0, 0xe8,-1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, 0xba,-1, 0, 0, 0, 0xbc #else 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, -1, 0, -1, 0, 0, -1, 0, 0, -1, -1, -1, -1, -1, 0, -1, 0, -1, -1, -1, -1, 0, -1, 0, 0, -1, 0, 0, -1, -1, -1, -1, -1, 0, -1, 0, -1, -1, -1, -1, 0, -1, -1, -1, -1, -1, 0, 0, 0, -1, 0, -1, 0, -1, -1, -1, 0, -1, -1, 0, -1, -1, -1, -1, -1, 0, 0, 0, -1, 0, -1, 0, -1, -1, -1, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, -1, -1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, -1, 0, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, -1, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, 0, 0, -1, 0, 0, 0, -1, -1, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, -1, 0, 0, -1, 0, 0, -1, 0, 0, 0, 0, 0, 0, 0, 0, -1, 0, 0, 0, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1, 0, -1, -1, -1, 0, 0, 0, 0, 0, -1, -1, 0, -1, -1, -1, 0, 0, 0, -1 #endif }; /* --- T.61 characters [0xA0 .. 0xBF] ----------------- */ static const Couple trans_t61a_iso8859[32] = { #if (ISO_8859 == 1) || (ISO_8859 == 9) {'N','S'}, {0xa1,0}, {0xa2,0}, {0xa3,0}, {'D','O'}, {0xa5,0}, {'C','u'}, {0xa7,0}, {0xa4,0}, {'\'','6'},{'"','6'}, {0xab,0}, {'<','-'}, {'-','!'}, {'-','>'}, {'-','v'}, {0xb0,0}, {0xb1,0}, {0xb2,0}, {0xb3,0}, {0xd7,0}, {0xb5,0}, {0xb6,0}, {0xb7,0}, {0xf7,0}, {'\'','9'},{'"','9'}, {0xbb,0}, {0xbc,0}, {0xbd,0}, {0xbe,0}, {0xbf,0} #elif (ISO_8859 == 2) || (ISO_8859 == 4) {'N','S'}, {'!','I'}, {'C','t'}, {'P','d'}, {'D','O'}, {'Y','e'}, {'C','u'}, {0xa7,0}, {0xa4,0}, {'\'','6'},{'"','6'}, {'<','<'}, {'<','-'}, {'-','!'}, {'-','>'}, {'-','v'}, {0xb0,0}, {'+','-'}, {'2','S'}, {'3','S'}, {0xd7,0}, {'M','y'}, {'P','I'}, {'.','M'}, {0xf7,0}, {'\'','9'},{'"','9'}, {'>','>'}, {'1','4'}, {'1','2'}, {'3','4'}, {'?','I'}, #elif (ISO_8859 == 3) {'N','S'}, {'!','I'}, {'C','t'}, {0xa3,0}, {'D','O'}, {'Y','e'}, {'C','u'}, {0xa7,0}, {0xa4,0}, {'\'','6'},{'"','6'}, {'<','<'}, {'<','-'}, {'-','!'}, {'-','>'}, {'-','v'}, {0xb0,0}, {'+','-'}, {0xb2,0}, {0xb3,0}, {0xd7,0}, {0xb5,0}, {'P','I'}, {0xb7,0}, {0xf7,0}, {'\'','9'},{'"','9'}, {'>','>'}, {'1','4'}, {0xbd,0}, {'3','4'}, {'?','I'} #elif (ISO_8859 == 10) {'N','S'}, {'!','I'}, {'C','t'}, {'P','d'}, {'D','O'}, {'Y','e'}, {'C','u'}, {0xa7,0}, {'C','u'}, {'\'','6'},{'"','6'}, {'<','<'}, {'<','-'}, {'-','!'}, {'-','>'}, {'-','v'}, {0xb0,0}, {'+','-'}, {'2','S'}, {'3','S'}, {'*','X'}, {'M','y'}, {'P','I'}, {0xb7,0}, {'-',':'}, {'\'','9'},{'"','9'}, {'>','>'}, {'1','4'}, {'1','2'}, {'3','4'}, {'?','I'} #else {'N','S'}, {'!','I'}, {'C','t'}, {'P','d'}, {'D','O'}, {'Y','e'}, {'C','u'}, {'S','E'}, {'X','O'}, {'\'','6'},{'"','6'}, {'<','<'}, {'<','-'}, {'-','!'}, {'-','>'}, {'-','v'}, {'D','G'}, {'+','-'}, {'2','S'}, {'3','S'}, {'*','X'}, {'M','y'}, {'P','I'}, {'.','M'}, {'-',':'}, {'\'','9'},{'"','9'}, {'>','>'}, {'1','4'}, {'1','2'}, {'3','4'}, {'?','I'} #endif }; /* --- T.61 characters [0xE0 .. 0xFF] ----------------- */ static const Couple trans_t61b_iso8859[48] = { #if (ISO_8859 == 1) {'-','M'}, {0xb9,0}, {0xae,0}, {0xa9,0}, {'T','M'}, {'M','8'}, {0xac,0}, {0xa6,0}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {0xc6,0}, {0xd0,0}, {0xaa,0}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {0xd8,0}, {'O','E'}, {0xba,0}, {0xde,0}, {'T','/'}, {'N','G'}, {'\'','n'}, {'k','k'}, {0xe6,0}, {'d','/'}, {0xf0,0}, {'h','/'}, {'i','.'}, {'i','j'}, {'l','.'}, {'l','/'}, {0xf8,0}, {'o','e'}, {0xdf,0}, {0xfe,0}, {'t','/'}, {'n','g'}, {'-','-'} #elif (ISO_8859 == 2) {'-','M'}, {'1','S'}, {'R','g'}, {'C','o'}, {'T','M'}, {'M','8'}, {'N','O'}, {'B','B'}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {'A','E'}, {0xd0,0}, {'-','a'}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {0xa3,0}, {'O','/'}, {'O','E'}, {'-','o'}, {'T','H'}, {'T','/'}, {'N','G'}, {'\'','n'}, {'k','k'}, {'a','e'}, {0xf0,0}, {'d','-'}, {'h','/'}, {'i','.'}, {'i','j'}, {'l','.'}, {0xb3,0}, {'o','/'}, {'o','e'}, {0xdf,0}, {'t','h'}, {'t','/'}, {'n','g'}, {'-','-'} #elif (ISO_8859 == 3) {'-','M'}, {'1','S'}, {'R','g'}, {'C','o'}, {'T','M'}, {'M','8'}, {'N','O'}, {'B','B'}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {'A','E'}, {'D','/'}, {'-','a'}, {0xa1,0}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {'O','/'}, {'O','E'}, {'-','o'}, {'T','H'}, {'T','/'}, {'N','G'}, {'\'','n'}, {'k','k'}, {'a','e'}, {'d','/'}, {'d','-'}, {0xb1,0}, {0xb9,0}, {'i','j'}, {'l','.'}, {'l','/'}, {'o','/'}, {'o','e'}, {0xdf,0}, {'t','h'}, {'t','/'}, {'n','g'}, {'-','-'} #elif (ISO_8859 == 4) {'-','M'}, {'1','S'}, {'R','g'}, {'C','o'}, {'T','M'}, {'M','8'}, {'N','O'}, {'B','B'}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {0xc6,0}, {0xd0,0}, {'-','a'}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {0xd8,0}, {'O','E'}, {'-','o'}, {'T','H'}, {0xac,0}, {0xbd,0}, {'\'','n'}, {0xa2,0}, {0xe6,0}, {0xf0,0}, {'d','-'}, {'h','/'}, {'i','.'}, {'i','j'}, {'l','.'}, {'l','/'}, {0xf8,0}, {'o','e'}, {0xdf,0}, {'t','h'}, {0xbc,0}, {0xbf,0}, {'-','-'} #elif (ISO_8859 == 9) {'-','M'}, {0xb9,0}, {0xae,0}, {0xa9,0}, {'T','M'}, {'M','8'}, {0xac,0}, {0xa6,0}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {0xc6,0}, {'D','/'}, {0xaa,0}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {0xd8,0}, {'O','E'}, {0xba,0}, {'T','H'}, {'T','/'}, {'N','G'}, {'\'','n'}, {'k','k'}, {0xe6,0}, {'d','/'}, {'d','-'}, {'h','/'}, {0xfd,0}, {'i','j'}, {'l','.'}, {'l','/'}, {0xf8,0}, {'o','e'}, {0xdf,0}, {'t','h'}, {'t','/'}, {'n','g'}, {'-','-'} #elif (ISO_8859 == 10) {0xbd,0}, {'1','S'}, {'R','g'}, {'C','o'}, {'T','M'}, {'M','8'}, {'N','O'}, {'B','B'}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {0xc6,0}, {0xa9,0}, {'-','a'}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {0xd8,0}, {'O','E'}, {'-','o'}, {0xde,0}, {0xab,0}, {0xaf,0}, {'\'','n'}, {0xff,0}, {0xe6,0}, {0xb9,0}, {0xf0,0}, {'h','/'}, {'i','.'}, {'i','j'}, {'l','.'}, {'l','/'}, {0xf8,0}, {'o','e'}, {0xdf,0}, {0xfe,0}, {0xbb,0}, {0xbf,0}, {'-','-'} #else {'-','M'}, {'1','S'}, {'R','g'}, {'C','o'}, {'T','M'}, {'M','8'}, {'N','O'}, {'B','B'}, {0,0}, {0,0}, {0,0}, {0,0}, {'1','8'}, {'3','8'}, {'5','8'}, {'7','8'}, {'O','m'}, {'A','E'}, {'D','/'}, {'-','a'}, {'H','/'}, {0,0}, {'I','J'}, {'L','.'}, {'L','/'}, {'O','/'}, {'O','E'}, {'-','o'}, {'T','H'}, {'T','/'}, {'N','G'}, {'\'','n'}, {'k','k'}, {'a','e'}, {'d','/'}, {'d','-'}, {'h','/'}, {'i','.'}, {'i','j'}, {'l','.'}, {'l','/'}, {'o','/'}, {'o','e'}, {'s','s'}, {'t','h'}, {'t','-'}, {'n','g'}, {'-','-'} #endif }; /* --- ISO 8859-n characters <0xA0 .. 0xFF> ------------------- */ #if (ISO_8859 == 1) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xa1,0}, {0xa2,0}, {0xa3,0}, {0xa8,0}, {0xa5,0}, {0xd7,0}, {0xa7,0}, {0xc8,ALONE}, {0xd3,0}, {0xe3,0}, {0xab,0}, {0xd6,0}, {0xff,0}, {0xd2,0}, {0xc5,ALONE}, {0xb0,0}, {0xb1,0}, {0xb2,0}, {0xb3,0}, {0xc2,ALONE}, {0xb5,0}, {0xb6,0}, {0xb7,0}, {0xcb,ALONE}, {0xd1,0}, {0xeb,0}, {0xbb,0}, {0xbc,0}, {0xbd,0}, {0xbe,0}, {0xbf,0}, {0xc1,'A'}, {0xc2,'A'}, {0xc3,'A'}, {0xc4,'A'}, {0xc8,'A'}, {0xca,'A'}, {0xe1,0}, {0xcb,'C'}, {0xc1,'E'}, {0xc2,'E'}, {0xc3,'E'}, {0xc8,'E'}, {0xc1,'I'}, {0xc2,'I'}, {0xc3,'I'}, {0xc8,'I'}, {0xe2,0}, {0xc4,'N'}, {0xc1,'O'}, {0xc2,'O'}, {0xc3,'O'}, {0xc4,'O'}, {0xc8,'O'}, {0xb4,0}, {0xe9,0}, {0xc1,'U'}, {0xc2,'U'}, {0xc3,'U'}, {0xc8,'U'}, {0xc2,'Y'}, {0xec,0}, {0xfb,0}, {0xc1,'a'}, {0xc2,'a'}, {0xc3,'a'}, {0xc4,'a'}, {0xc8,'a'}, {0xca,'a'}, {0xf1,0}, {0xcb,'c'}, {0xc1,'e'}, {0xc2,'e'}, {0xc3,'e'}, {0xc8,'e'}, {0xc1,'i'}, {0xc2,'i'}, {0xc3,'i'}, {0xc8,'i'}, {0xf3,0}, {0xc4,'n'}, {0xc1,'o'}, {0xc2,'o'}, {0xc3,'o'}, {0xc4,'o'}, {0xc8,'o'}, {0xb8,0}, {0xf9,0}, {0xc1,'u'}, {0xc2,'u'}, {0xc3,'u'}, {0xc8,'u'}, {0xc2,'y'}, {0xfc,0}, {0xc8,'y'} }; #elif (ISO_8859 == 2) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xce,'A'}, {0xc6,ALONE}, {0xe8,0}, {0xa8,0}, {0xcf,'L'}, {0xc2,'S'}, {0xa7,0}, {0xc8,ALONE}, {0xcf,'S'}, {0xcb,'S'}, {0xcf,'T'}, {0xc2,'Z'}, {0xff,0}, {0xcf,'Z'}, {0xc7,'Z'}, {0xb0,0}, {0xce,'a'}, {0xce,ALONE}, {0xf8,0}, {0xc2,ALONE}, {0xcf,'l'}, {0xc2,'s'}, {0xcf,ALONE}, {0xcb,ALONE}, {0xcf,'s'}, {0xcb,'s'}, {0xcf,'t'}, {0xc2,'z'}, {0xcd,ALONE}, {0xcf,'z'}, {0xc7,'z'}, {0xc2,'R'}, {0xc2,'A'}, {0xc3,'A'}, {0xc6,'A'}, {0xc8,'A'}, {0xc2,'L'}, {0xc2,'C'}, {0xcb,'C'}, {0xcf,'C'}, {0xc2,'E'}, {0xce,'E'}, {0xc8,'E'}, {0xcf,'E'}, {0xc2,'I'}, {0xc3,'I'}, {0xcf,'D'}, {0xe2,0}, {0xc2,'N'}, {0xcf,'N'}, {0xc2,'O'}, {0xc3,'O'}, {0xcd,'O'}, {0xc8,'O'}, {0xb4,0}, {0xcf,'R'}, {0xca,'U'}, {0xc2,'U'}, {0xcd,'U'}, {0xc8,'U'}, {0xc2,'Y'}, {0xcb,'T'}, {0xfb,0}, {0xc2,'r'}, {0xc2,'a'}, {0xc3,'a'}, {0xc6,'a'}, {0xc8,'a'}, {0xc2,'l'}, {0xc2,'c'}, {0xcb,'c'}, {0xcf,'c'}, {0xc2,'e'}, {0xce,'e'}, {0xc8,'e'}, {0xcf,'e'}, {0xc2,'i'}, {0xc3,'i'}, {0xcf,'d'}, {0xf2,0}, {0xc2,'n'}, {0xcf,'n'}, {0xc2,'o'}, {0xc3,'o'}, {0xcd,'o'}, {0xc8,'o'}, {0xb8,0}, {0xcf,'r'}, {0xca,'u'}, {0xc2,'u'}, {0xcd,'u'}, {0xc8,'u'}, {0xc2,'y'}, {0xcb,'t'}, {0xc7,ALONE} }; #elif (ISO_8859 == 3) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xe4,0}, {0xc6,ALONE}, {0xa3,0}, {0xa8,0}, {0,0}, {0xc3,'H'}, {0xa7,0}, {0xc8,ALONE}, {0xc7,'I'}, {0xcb,'S'}, {0xc6,'G'}, {0xc3,'J'}, {0xff,0}, {0,0}, {0xc7,'Z'}, {0xb0,0}, {0xf4,0}, {0xb2,0}, {0xb3,0}, {0xc2,ALONE}, {0xb5,0}, {0xc3,'h'}, {0xb7,0}, {0xcb,ALONE}, {0xf5,0}, {0xcb,'s'}, {0xc6,'g'}, {0xc3,'j'}, {0xbd,0}, {0,0}, {0xc7,'z'}, {0xc1,'A'}, {0xc2,'A'}, {0xc3,'A'}, {0,0}, {0xc8,'A'}, {0xc7,'C'}, {0xc3,'C'}, {0xcb,'C'}, {0xc1,'E'}, {0xc2,'E'}, {0xc3,'E'}, {0xc8,'E'}, {0xc1,'I'}, {0xc2,'I'}, {0xc3,'I'}, {0xc8,'I'}, {0,0}, {0xc4,'N'}, {0xc1,'O'}, {0xc2,'O'}, {0xc3,'O'}, {0xc7,'G'}, {0xc8,'O'}, {0xb4,0}, {0xc3,'G'}, {0xc1,'U'}, {0xc2,'U'}, {0xc3,'U'}, {0xc8,'U'}, {0xc6,'U'}, {0xc3,'S'}, {0xfb,0}, {0xc1,'a'}, {0xc2,'a'}, {0xc3,'a'}, {0,0}, {0xc8,'a'}, {0xc7,'c'}, {0xc3,'c'}, {0xcb,'c'}, {0xc1,'e'}, {0xc2,'e'}, {0xc3,'e'}, {0xc8,'e'}, {0xc1,'i'}, {0xc2,'i'}, {0xc3,'i'}, {0xc8,'i'}, {0,0}, {0xc4,'n'}, {0xc1,'o'}, {0xc2,'o'}, {0xc3,'o'}, {0xc7,'g'}, {0xc8,'o'}, {0xb8,0}, {0xc3,'g'}, {0xc1,'u'}, {0xc2,'u'}, {0xc3,'u'}, {0xc8,'u'}, {0xc6,'u'}, {0xc3,'s'}, {0xc7,ALONE} }; #elif (ISO_8859 == 4) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xce,'A'}, {0xf0,0}, {0xcb,'R'}, {0xa8,0}, {0xc4,'I'}, {0xcb,'L'}, {0xa7,0}, {0xc8,ALONE}, {0xcf,'S'}, {0xc5,'E'}, {0xcb,'G'}, {0xed,0}, {0xff,0}, {0xcf,'Z'}, {0xc5,ALONE}, {0xb0,0}, {0xce,'a'}, {0xce,ALONE}, {0xcb,'r'}, {0xc2,ALONE}, {0xc4,'i'}, {0xcb,'l'}, {0xcf,ALONE}, {0xcb,ALONE}, {0xcf,'s'}, {0xc5,'e'}, {0xcb,'g'}, {0xfd,0}, {0xee,0}, {0xcf,'z'}, {0xfe,0}, {0xc5,'A'}, {0xc2,'A'}, {0xc3,'A'}, {0xc4,'A'}, {0xc8,'A'}, {0xca,'A'}, {0xe1,0}, {0xce,'I'}, {0xcf,'C'}, {0xc2,'E'}, {0xce,'E'}, {0xc8,'E'}, {0xc7,'E'}, {0xc2,'I'}, {0xc3,'I'}, {0xc5,'I'}, {0xe2,0}, {0xcb,'N'}, {0xc5,'O'}, {0xcb,'K'}, {0xc3,'O'}, {0xc4,'O'}, {0xc8,'O'}, {0xb4,0}, {0xe9,0}, {0xce,'U'}, {0xc2,'U'}, {0xc3,'U'}, {0xc8,'U'}, {0xc4,'U'}, {0xc5,'U'}, {0xfb,0}, {0xc5,'a'}, {0xc2,'a'}, {0xc3,'a'}, {0xc4,'a'}, {0xc8,'a'}, {0xca,'a'}, {0xf1,0}, {0xce,'i'}, {0xcf,'c'}, {0xc2,'e'}, {0xce,'e'}, {0xc8,'e'}, {0xc7,'e'}, {0xc2,'i'}, {0xc3,'i'}, {0xc5,'i'}, {0xf2,0}, {0xcb,'n'}, {0xc5,'o'}, {0xcb,'k'}, {0xc3,'o'}, {0xc4,'o'}, {0xc8,'o'}, {0xb8,0}, {0xf9,0}, {0xce,'u'}, {0xc2,'u'}, {0xc3,'u'}, {0xc8,'u'}, {0xc4,'u'}, {0xc5,'u'}, {0xc7,ALONE} }; #elif (ISO_8859 == 9) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xa1,0}, {0xa2,0}, {0xa3,0}, {0xa8,0}, {0xa5,0}, {0xd7,0}, {0xa7,0}, {0xc8,ALONE}, {0xd3,0}, {0xe3,0}, {0xab,0}, {0xd6,0}, {0xff,0}, {0xd2,0}, {0xc5,ALONE}, {0xb0,0}, {0xb1,0}, {0xb2,0}, {0xb3,0}, {0xc2,ALONE}, {0xb5,0}, {0xb6,0}, {0xb7,0}, {0xcb,ALONE}, {0xd1,0}, {0xeb,0}, {0xbb,0}, {0xbc,0}, {0xbd,0}, {0xbe,0}, {0xbf,0}, {0xc1,'A'}, {0xc2,'A'}, {0xc3,'A'}, {0xc4,'A'}, {0xc8,'A'}, {0xca,'A'}, {0xe1,0}, {0xcb,'C'}, {0xc1,'E'}, {0xc2,'E'}, {0xc3,'E'}, {0xc8,'E'}, {0xc1,'I'}, {0xc2,'I'}, {0xc3,'I'}, {0xc8,'I'}, {0xc6,'G'}, {0xc4,'N'}, {0xc1,'O'}, {0xc2,'O'}, {0xc3,'O'}, {0xc4,'O'}, {0xc8,'O'}, {0xb4,0}, {0xe9,0}, {0xc1,'U'}, {0xc2,'U'}, {0xc3,'U'}, {0xc8,'U'}, {0xc7,'I'}, {0xcb,'S'}, {0xfb,0}, {0xc1,'a'}, {0xc2,'a'}, {0xc3,'a'}, {0xc4,'a'}, {0xc8,'a'}, {0xca,'a'}, {0xf1,0}, {0xcb,'c'}, {0xc1,'e'}, {0xc2,'e'}, {0xce,'e'}, {0xc8,'e'}, {0xc7,'e'}, {0xc2,'i'}, {0xc3,'i'}, {0xc5,'i'}, {0xc6,'g'}, {0xc4,'n'}, {0xc1,'o'}, {0xc2,'o'}, {0xc3,'o'}, {0xc4,'o'}, {0xc8,'o'}, {0xb8,0}, {0xf9,0}, {0xc1,'u'}, {0xc2,'u'}, {0xc3,'u'}, {0xc8,'u'}, {0xf5,0}, {0xcb,'s'}, {0xc8,'y'} }; #elif (ISO_8859 == 10) static const Couple trans_iso8859_t61[96] = { {0xa0,0}, {0xce,'A'}, {0xc5,'E'}, {0xcb,'G'}, {0xc5,'I'}, {0xc4,'I'}, {0xcb,'K'}, {0xa7,0}, {0xcb,'L'}, {0xe2,0}, {0xcf,'S'}, {0xed,0}, {0xcf,'Z'}, {0xff,0}, {0xc5,'U'}, {0xee,0}, {0xb0,0}, {0xce,'a'}, {0xc5,'e'}, {0xcb,'g'}, {0xc5,'i'}, {0xc4,'i'}, {0xcb,'k'}, {0xb7,0}, {0xcb,'l'}, {0xf2,0}, {0xcf,'s'}, {0xfd,0}, {0xcf,'z'}, {0xd0,0}, {0xc5,'u'}, {0xfe,0}, {0xc5,'A'}, {0xc2,'A'}, {0xc3,'A'}, {0xc4,'A'}, {0xc8,'A'}, {0xca,'A'}, {0xe1,0}, {0xce,'I'}, {0xcf,'C'}, {0xc2,'E'}, {0xce,'E'}, {0xc8,'E'}, {0xc7,'E'}, {0xc2,'I'}, {0xc3,'I'}, {0xc8,'I'}, {0,0}, {0xcb,'N'}, {0xc5,'O'}, {0xc2,'O'}, {0xc3,'O'}, {0xc4,'O'}, {0xc8,'O'}, {0xc4,'U'}, {0xe9,0}, {0xce,'U'}, {0xc2,'U'}, {0xc3,'U'}, {0xc8,'U'}, {0xc2,'Y'}, {0xec,0}, {0xfb,0}, {0xc5,'a'}, {0xc2,'a'}, {0xc3,'a'}, {0xc4,'a'}, {0xc8,'a'}, {0xca,'a'}, {0xf1,0}, {0xce,'i'}, {0xcf,'c'}, {0xc2,'e'}, {0xce,'e'}, {0xc8,'e'}, {0xc7,'e'}, {0xc2,'i'}, {0xc3,'i'}, {0xc8,'i'}, {0xf3,0}, {0xcb,'n'}, {0xc5,'o'}, {0xc2,'o'}, {0xc3,'o'}, {0xc4,'o'}, {0xc8,'o'}, {0xc4,'u'}, {0xf9,0}, {0xce,'u'}, {0xc2,'u'}, {0xc3,'u'}, {0xc8,'u'}, {0xc2,'y'}, {0xfc,0}, {0xf0,0} }; #endif static Byte * c_to_hh( Byte *o, Byte c ) { Byte n; *o++ = '{'; *o++ = 'x'; n = c >> 4; *o++ = ((n < 0xA) ? '0' : 'A' - 0xA) + n; n = c & 0x0F; *o++ = ((n < 0xA) ? '0' : 'A' - 0xA) + n; *o++ = '}'; return o; } static Byte * c_to_cc( Byte *o, const Couple *cc, Byte c ) { if ( (*cc).a != 0 ) { if ( (*cc).b == 0 ) *o++ = (*cc).a; else { *o++ = '{'; *o++ = (*cc).a; *o++ = (*cc).b; *o++ = '}'; } return o; } else return c_to_hh( o, c ); } /* --- routine to convert from T.61 to ISO 8859-n --- */ int ldap_t61_to_8859( char **bufp, ber_len_t *buflenp, int free_input ) { Byte *s, *oo, *o; unsigned int n; int c; ber_len_t len; Debug( LDAP_DEBUG_TRACE, "ldap_t61_to_8859 input length: %ld\n", *buflenp, 0, 0 ); len = *buflenp; s = (Byte *) *bufp; if ( (o = oo = (Byte *)LDAP_MALLOC( 2 * len + 64 )) == NULL ) { return( 1 ); } while ( (char *)s - *(char **)bufp < len ) { switch ( *s >> 4 ) { case 0xA: case 0xB: o = c_to_cc( o, &trans_t61a_iso8859[ *s - 0xA0 ], *s ); s++; break; case 0xD: case 0xE: case 0xF: o = c_to_cc( o, &trans_t61b_iso8859[ *s - 0xD0 ], *s ); s++; break; case 0xC: if ( (*s == 0xC0) || (*s == 0xC9) || (*s == 0xCC) ) { o = c_to_hh( o, *s++ ); break; } n = (*s++) - 0xC0; switch ( *s ) { case 'A': c = letter_w_diacritic[n][0]; break; case 'C': c = letter_w_diacritic[n][1]; break; case 'D': c = letter_w_diacritic[n][2]; break; case 'E': c = letter_w_diacritic[n][3]; break; case 'G': c = letter_w_diacritic[n][4]; break; case 'H': c = letter_w_diacritic[n][5]; break; case 'I': c = letter_w_diacritic[n][6]; break; case 'J': c = letter_w_diacritic[n][7]; break; case 'K': c = letter_w_diacritic[n][8]; break; case 'L': c = letter_w_diacritic[n][9]; break; case 'N': c = letter_w_diacritic[n][10]; break; case 'O': c = letter_w_diacritic[n][11]; break; case 'R': c = letter_w_diacritic[n][12]; break; case 'S': c = letter_w_diacritic[n][13]; break; case 'T': c = letter_w_diacritic[n][14]; break; case 'U': c = letter_w_diacritic[n][15]; break; case 'W': c = letter_w_diacritic[n][16]; break; case 'Y': c = letter_w_diacritic[n][17]; break; case 'Z': c = letter_w_diacritic[n][18]; break; case 'a': c = letter_w_diacritic[n][19]; break; case 'c': c = letter_w_diacritic[n][20]; break; case 'd': c = letter_w_diacritic[n][21]; break; case 'e': c = letter_w_diacritic[n][22]; break; case 'g': c = letter_w_diacritic[n][23]; break; case 'h': c = letter_w_diacritic[n][24]; break; case 'i': c = letter_w_diacritic[n][25]; break; case 'j': c = letter_w_diacritic[n][26]; break; case 'k': c = letter_w_diacritic[n][27]; break; case 'l': c = letter_w_diacritic[n][28]; break; case 'n': c = letter_w_diacritic[n][29]; break; case 'o': c = letter_w_diacritic[n][30]; break; case 'r': c = letter_w_diacritic[n][31]; break; case 's': c = letter_w_diacritic[n][32]; break; case 't': c = letter_w_diacritic[n][33]; break; case 'u': c = letter_w_diacritic[n][34]; break; case 'w': c = letter_w_diacritic[n][35]; break; case 'y': c = letter_w_diacritic[n][36]; break; case 'z': c = letter_w_diacritic[n][37]; break; case ALONE: c = (( !diacritic[n].b ) ? diacritic[n].a : -1); break; default: c = 0; } if ( c > 0 ) { *o++ = c; s++; } else { *o++ = '{'; if ( c == -1 ) { *o++ = ( ( *s == ALONE ) ? ' ' : *s ); s++; } else { *o++ = '"'; } *o++ = diacritic[n].a; *o++ = '}'; } break; #if (ISO_8859 == 0) case 0x8: case 0x9: *o++ = 0x1B; /* */ *o++ = *s++ - 0x40; break; #endif default: *o++ = *s++; } } len = o - oo; o = oo; if ( (oo = (Byte *)LDAP_REALLOC( o, len )) == NULL ) { LDAP_FREE( o ); return( 1 ); } if ( free_input ) { LDAP_FREE( *bufp ); } *bufp = (char *) oo; *buflenp = len; return( 0 ); } static int hh_to_c( const Byte *h ) { Byte c; if ( (*h >= '0') && (*h <= '9') ) c = *h++ - '0'; else if ( (*h >= 'A') && (*h <= 'F') ) c = *h++ - 'A' + 10; else if ( (*h >= 'a') && (*h <= 'f') ) c = *h++ - 'a' + 10; else return -1; c <<= 4; if ( (*h >= '0') && (*h <= '9') ) c |= *h - '0'; else if ( (*h >= 'A') && (*h <= 'F') ) c |= *h - 'A' + 10; else if ( (*h >= 'a') && (*h <= 'f') ) c |= *h - 'a' + 10; else return -1; return c; } static Byte * cc_to_t61( Byte *o, const Byte *s ) { int n, c = 0; switch ( *(s + 1) ) { case '`': c = -1; break; /* */ case '!': switch ( *s ) { case '!': c = 0x7C; break; /* */ case '(': c = 0x7B; break; /* */ case '-': c = 0xAD; break; /* */ default: c = -1; /* */ } break; #if (ISO_8859 == 1) || (ISO_8859 == 2) || (ISO_8859 == 3) || \ (ISO_8859 == 4) || (ISO_8859 == 9) case 0xB4: #endif case '\'': c = -2; break; /* */ case '^': c = -3; break; /* */ case '>': switch ( *s ) { case ')': c = 0x5D; break; /* */ case '>': c = 0xBB; break; /* */ case '-': c = 0xAE; break; /* */ default: c = -3; /* */ } break; case '~': case '?': c = -4; break; /* */ #if (ISO_8859 == 1) || (ISO_8859 == 4) || (ISO_8859 == 9) case 0xAF: c = -5; break; /* */ #endif case '-': switch ( *s ) { case '-': c = 0xFF; break; /* */ case '<': c = 0xAC; break; /* */ case '+': c = 0xB1; break; /* */ case 'd': c = 0xF3; break; /* */ default: c = -5; /* */ } break; #if (ISO_8859 == 2) || (ISO_8859 == 3) case 0xA2: c = -6; break; /* */ #endif case '(': if ( *s == '<' ) c = 0x5B; /* */ else c = -6; /* */ break; #if (ISO_8859 == 2) || (ISO_8859 == 3) || (ISO_8859 == 4) case 0xFF: c = -7; break; /* */ #endif case '.': switch ( *s ) { case 'i': c = 0xF5; break; /* */ case 'L': c = 0xE7; break; /* */ case 'l': c = 0xF7; break; /* */ default: c = -7; /* */ } break; #if (ISO_8859 == 1) || (ISO_8859 == 2) || (ISO_8859 == 3) || \ (ISO_8859 == 4) || (ISO_8859 == 9) case 0xA8: c = -8; break; /* */ #endif case ':': if ( *s == '-') c = 0xB8; /* */ else c = -8; /* */ break; #if (ISO_8859 == 1) || (ISO_8859 == 2) || (ISO_8859 == 3) || \ (ISO_8859 == 4) || (ISO_8859 == 9) || (ISO_8859 == 10) case 0xB0: #endif case '0': c = -10; break; /* */ #if (ISO_8859 == 1) || (ISO_8859 == 2) || (ISO_8859 == 3) || \ (ISO_8859 == 4) || (ISO_8859 == 9) case 0xB8: #endif case ',': c = -11; break; /* */ #if (ISO_8859 == 2) case 0xBD: #endif case '"': c = -13; break; /* */ #if (ISO_8859 == 2) || (ISO_8859 == 4) case 0xB2: #endif case ';': c = -14; break; /* */ #if (ISO_8859 == 2) || (ISO_8859 == 4) case 0xB7: c = -15; break; /* */ #endif case ')': if ( *s == '!' ) c = 0x7D; /* */ break; case '<': if ( *s == '<' ) c = 0xAB; /* */ else c = -15; /* */ break; case '/': switch ( *s ) { case '/': c = 0x5C; break; /* */ case 'D': c = 0xE2; break; /* */ case 'd': c = 0xF2; break; /* */ case 'H': c = 0xE4; break; /* */ case 'h': c = 0xF4; break; /* */ case 'L': c = 0xE8; break; /* */ case 'l': c = 0xF8; break; /* */ case 'O': c = 0xE9; break; /* */ case 'o': c = 0xF9; break; /* */ case 'T': c = 0xED; break; /* */ case 't': c = 0xFD; break; /* */ } break; case '2': if ( *s == '1' ) c = 0xBD; /* */ break; case '4': switch ( *s ) { case '1': c = 0xBC; break; /* */ case '3': c = 0xBE; break; /* */ } break; case '6': switch ( *s ) { case '\'': c = 0xA9; break; /* */ case '"': c = 0xAA; break; /* */ } break; case '8': switch ( *s ) { case '1': c = 0xDC; break; /* */ case '3': c = 0xDD; break; /* */ case '5': c = 0xDE; break; /* */ case '7': c = 0xDF; break; /* */ case 'M': c = 0xD5; break; /* */ } break; case '9': switch ( *s ) { case '\'': c = 0xB9; break; /* */ case '"': c = 0xBA; break; /* */ } break; case 'A': if ( *s == 'A' ) c = -10; /* + */ break; case 'a': switch ( *s ) { case '-': c = 0xE3; break; /* */ case 'a': c = -10; break; /* + */ } break; case 'B': if ( *s == 'B' ) c = 0xD7; /* */ break; case 'b': if ( *s == 'N' ) c = 0xA6; /* */ break; case 'd': if ( *s == 'P' ) c = 0xA3; /* */ break; case 'E': switch ( *s ) { case 'S': c = 0xA7; break; /* */ case 'A': c = 0xE1; break; /* */ case 'O': c = 0xEA; break; /* */ } break; case 'e': switch ( *s ) { case 'a': c = 0xF1; break; /* */ case 'o': c = 0xFA; break; /* */ case 'Y': c = 0xA5; break; /* */ } break; case 'G': switch ( *s ) { case 'D': c = 0xB0; break; /* */ case 'N': c = 0xEE; break; /* */ } break; case 'g': switch ( *s ) { case 'R': c = 0xD2; break; /* */ case 'n': c = 0xFE; break; /* */ } break; case 'H': if ( *s == 'T' ) c = 0xEC; /* */ break; case 'h': if ( *s == 't' ) c = 0xFC; /* */ break; case 'I': switch ( *s ) { case 'P': c = 0xB6; break; /* */ case '!': c = 0xA1; break; /* */ case '?': c = 0xBF; break; /* */ } break; case 'J': if ( *s == 'I' ) c = 0xE6; /* */ break; case 'j': if ( *s == 'i' ) c = 0xF6; /* */ break; case 'k': if ( *s == 'k' ) c = 0xF0; /* */ break; case 'M': switch ( *s ) { case '.': c = 0xB7; break; /* */ case '-': c = 0xD0; break; /* */ case 'T': c = 0xD4; break; /* */ } break; case 'm': switch ( *s ) { case '\'': /* RFC 1345 */ case ' ': c = -5; break; /* */ case 'O': c = 0xE0; break; /* */ } break; case 'n': if ( *s == '\'' ) c = 0xEF; /* */ break; case 'O': switch ( *s ) { case 'D': c = 0xA4; break; /* */ case 'N': c = 0xD6; break; /* */ } break; case 'o': switch ( *s ) { case 'C': c = 0xD3; break; /* */ case '-': c = 0xEB; break; /* */ } break; case 'S': switch ( *s ) { case '1': c = 0xD1; break; /* */ case '2': c = 0xB2; break; /* */ case '3': c = 0xB3; break; /* */ case 'N': c = 0xA0; break; /* */ } break; case 's': if ( *s == 's' ) c = 0xFB; /* */ break; case 't': if ( *s == 'C' ) c = 0xA2; /* */ break; case 'u': if ( *s == 'C' ) c = 0xA8; /* */ break; case 'v': if ( *s == '-' ) c = 0xAF; /* */ break; case 'X': if ( *s == '*' ) c = 0xB4; /* */ break; case 'y': if ( *s == 'M' ) c = 0xB5; /* */ break; } if ( c > 0 ) { *o++ = c; return o; } else if ( !c ) return NULL; /* else: c < 0 */ n = -c; switch ( *s ) { case 'A': c = letter_w_diacritic[n][0]; break; case 'C': c = letter_w_diacritic[n][1]; break; case 'D': c = letter_w_diacritic[n][2]; break; case 'E': c = letter_w_diacritic[n][3]; break; case 'G': c = letter_w_diacritic[n][4]; break; case 'H': c = letter_w_diacritic[n][5]; break; case 'I': c = letter_w_diacritic[n][6]; break; case 'J': c = letter_w_diacritic[n][7]; break; case 'K': c = letter_w_diacritic[n][8]; break; case 'L': c = letter_w_diacritic[n][9]; break; case 'N': c = letter_w_diacritic[n][10]; break; case 'O': c = letter_w_diacritic[n][11]; break; case 'R': c = letter_w_diacritic[n][12]; break; case 'S': c = letter_w_diacritic[n][13]; break; case 'T': c = letter_w_diacritic[n][14]; break; case 'U': c = letter_w_diacritic[n][15]; break; case 'W': c = letter_w_diacritic[n][16]; break; case 'Y': c = letter_w_diacritic[n][17]; break; case 'Z': c = letter_w_diacritic[n][18]; break; case 'a': c = letter_w_diacritic[n][19]; break; case 'c': c = letter_w_diacritic[n][20]; break; case 'd': c = letter_w_diacritic[n][21]; break; case 'e': c = letter_w_diacritic[n][22]; break; case 'g': c = letter_w_diacritic[n][23]; break; case 'h': c = letter_w_diacritic[n][24]; break; case 'i': c = letter_w_diacritic[n][25]; break; case 'j': c = letter_w_diacritic[n][26]; break; case 'k': c = letter_w_diacritic[n][27]; break; case 'l': c = letter_w_diacritic[n][28]; break; case 'n': c = letter_w_diacritic[n][29]; break; case 'o': c = letter_w_diacritic[n][30]; break; case 'r': c = letter_w_diacritic[n][31]; break; case 's': c = letter_w_diacritic[n][32]; break; case 't': c = letter_w_diacritic[n][33]; break; case 'u': c = letter_w_diacritic[n][34]; break; case 'w': c = letter_w_diacritic[n][35]; break; case 'y': c = letter_w_diacritic[n][36]; break; case 'z': c = letter_w_diacritic[n][37]; break; case '\'': case ' ': c = -1; break; default: c = 0; } if ( !c ) return NULL; *o++ = n + 0xC0; *o++ = ( ( (*s == ' ') || (*s == '\'') ) ? ALONE : *s ); return o; } /* --- routine to convert from ISO 8859-n to T.61 --- */ int ldap_8859_to_t61( char **bufp, ber_len_t *buflenp, int free_input ) { Byte *s, *oo, *o, *aux; int c; ber_len_t len; const Couple *cc; Debug( LDAP_DEBUG_TRACE, "ldap_8859_to_t61 input length: %ld\n", *buflenp, 0, 0 ); len = *buflenp; s = (Byte *) *bufp; if ( (o = oo = (Byte *)LDAP_MALLOC( 2 * len + 64 )) == NULL ) { return( 1 ); } while ( (char *)s - *(char **)bufp < len ) { switch( *s >> 5 ) { case 2: switch ( *s ) { case '^': *o++ = 0xC3; *o++ = ALONE; s++; break; case '\\': s++; if ( (c = hh_to_c( s )) != -1 ) { *o++ = c; s += 2; } else *o++ = '\\'; break; default: *o++ = *s++; } break; case 3: switch ( *s ) { case '`': *o++ = 0xC1; *o++ = ALONE; s++; break; case '~': *o++ = 0xC4; *o++ = ALONE; s++; break; case '{': s++; if ( *(s + 2) == '}' ) { if ( (aux = cc_to_t61( o, s )) != NULL ) { o = aux; s += 3; } else { *o++ = '{'; } } else if ( (*(s + 3) == '}') && ( (*s == 'x') || (*s == 'X') ) && ( (c = hh_to_c( s + 1 )) != -1 ) ) { *o++ = c; s += 4; } else { *o++ = '{'; } break; default: *o++ = *s++; } break; #if (ISO_8859 == 0) case 4: case 5: case 6: case 7: s++; break; #else case 5: case 6: case 7: # if (ISO_8859 == 1) || (ISO_8859 == 2) || (ISO_8859 == 3) || \ (ISO_8859 == 4) || (ISO_8859 == 9) || (ISO_8859 == 10) if ( (*(cc = &trans_iso8859_t61[ *s - 0xA0 ])).a ) { *o++ = (*cc).a; if ( (*cc).b ) *o++ = (*cc).b; } # endif s++; break; #endif default: *o++ = *s++; } } len = o - oo; o = oo; if ( (oo = (Byte *)LDAP_REALLOC( o, len )) == NULL ) { LDAP_FREE( o ); return( 1 ); } if ( free_input ) { LDAP_FREE( *bufp ); } *bufp = (char *) oo; *buflenp = len; return( 0 ); } #ifdef NOT_NEEDED_IN_LIBLDAP /* mcs@umich.edu 12 Oct 1995 */ /* --- routine to convert "escaped" (\hh) characters to 8bits --- */ void convert_escaped_to_8bit( s ) char *s; { char *o = s; int c; while ( *s ) { if ( *s == '\\' ) { if ( (c = hh_to_c( (Byte *) ++s )) != -1 ) { *o++ = c; s += 2; } else *o++ = '\\'; } else *o++ = *s++; } *o = '\0'; } /* --- routine to convert 8bits characters to the "escaped" (\hh) form --- */ char *convert_8bit_to_escaped( s ) const Byte *s; { Byte *o, *oo; Byte n; if ( (o = oo = (Byte *)LDAP_MALLOC( 2 * strlen( s ) + 64 )) == NULL ) { return( NULL ); } while ( *s ) { if ( *s < 0x80 ) *o++ = *s++; else { *o++ = '\\'; n = *s >> 4; *o++ = ((n < 0xA) ? '0' : 'A' - 0xA) + n; n = *s++ & 0x0F; *o++ = ((n < 0xA) ? '0' : 'A' - 0xA) + n; } } *o = '\0'; o = oo; if ( (oo = (Byte *)LDAP_REALLOC( o, strlen( o ) + 1 )) == NULL ) { LDAP_FREE( o ); return( NULL ); } return( (char *)oo ); } /* --- routine to convert from T.61 to printable characters --- */ /* printable characters [RFC 1488]: 'A'..'Z', 'a'..'z', '0'..'9', '\'', '(', ')', '+', ',', '-', '.', '/', ':', '?, ' '. that conversion is language dependent. */ static const Couple last_t61_printabled[32] = { {0,0}, {'A','E'}, {'D',0}, {0,0}, {'H',0}, {0,0}, {'I','J'}, {'L',0}, {'L',0}, {'O',0}, {'O','E'}, {0,0}, {'T','H'}, {'T',0}, {'N','G'}, {'n',0}, {'k',0}, {'a','e'}, {'d',0}, {'d',0}, {'h',0}, {'i',0}, {'i','j'}, {'l',0}, {'l',0}, {'o',0}, {'o','e'}, {'s','s'}, {'t','h'}, {'t',0}, {'n','g'}, {0,0} }; char *t61_printable( s ) Byte *s; { Byte *o, *oo; Byte n; const Couple *cc; if ( (o = oo = (Byte *)LDAP_MALLOC( 2 * strlen( s ) + 64 )) == NULL ) { return( NULL ); } while ( *s ) { if ( ( (*s >= 'A') && (*s <= 'Z') ) || ( (*s >= 'a') && (*s <= 'z') ) || ( (*s >= '0') && (*s <= '9') ) || ( (*s >= '\'') && (*s <= ')') ) || ( (*s >= '+') && (*s <= '/') ) || ( *s == '?' ) || ( *s == ' ' ) ) *o++ = *s++; else { if ( *s >= 0xE0 ) { if ( (*(cc = &last_t61_printabled[ *s - 0xE0 ])).a ) { *o++ = (*cc).a; if ( (*cc).b ) *o++ = (*cc).b; } } else if ( (*s >> 4) == 0xC ) { switch ( *s ) { case 0xCA: /* ring */ switch ( *(s + 1) ) { case 'A': *o++ = 'A'; *o++ = 'A'; s++; break; /* Swedish */ case 'a': *o++ = 'a'; *o++ = 'a'; s++; break; /* Swedish */ } break; case 0xC8: /* diaeresis */ switch ( *(s + 1) ) { case 'Y': *o++ = 'I'; *o++ = 'J'; s++; break; /* Dutch */ case 'y': *o++ = 'i'; *o++ = 'j'; s++; break; /* Dutch */ } break; } } s++; } } *o = '\0'; o = oo; if ( (oo = (Byte *)LDAP_REALLOC( o, strlen( o ) + 1 )) == NULL ) { LDAP_FREE( o ); return( NULL ); } return( (char *)oo ); } #endif /* NOT_NEEDED_IN_LIBLDAP */ /* mcs@umich.edu 12 Oct 1995 */ #endif /* LDAP_CHARSET_8859 */ #endif /* STR_TRANSLATION */