1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
/* This file is part of the YAZ toolkit.
* Copyright (C) Index Data
* See the file LICENSE for details.
*/
/**
* \file
* \brief Danmarc2 character set encoding
*/
#if HAVE_CONFIG_H
#include <config.h>
#endif
#include <assert.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>
#include <yaz/xmalloc.h>
#include "iconv-p.h"
static size_t write_danmarc(yaz_iconv_t cd, yaz_iconv_encoder_t en,
unsigned long x,
char **outbuf, size_t *outbytesleft)
{
unsigned char *outp = (unsigned char *) *outbuf;
if (x == '@' || x == '*')
{
if (*outbytesleft < 2)
{
yaz_iconv_set_errno(cd, YAZ_ICONV_E2BIG);
return (size_t)(-1);
}
*outp++ = '@';
(*outbytesleft)--;
*outp++ = (unsigned char) x;
(*outbytesleft)--;
}
else if (x <= 255)
{ /* latin-1 range */
if (*outbytesleft < 1)
{
yaz_iconv_set_errno(cd, YAZ_ICONV_E2BIG);
return (size_t)(-1);
}
*outp++ = (unsigned char) x;
(*outbytesleft)--;
}
else
{
if (*outbytesleft < 6)
{
yaz_iconv_set_errno(cd, YAZ_ICONV_E2BIG);
return (size_t)(-1);
}
switch (x)
{
case 0xa733:
*outp++ = '@';
*outp++ = 0xe5;
(*outbytesleft) -= 2;
break;
case 0xa732:
*outp++ = '@';
*outp++ = 0xc5;
(*outbytesleft) -= 2;
break;
default:
/* full unicode, emit @XXXX */
sprintf(*outbuf, "@%04lX", x);
outp += 5;
(*outbytesleft) -= 5;
break;
}
}
*outbuf = (char *) outp;
return 0;
}
yaz_iconv_encoder_t yaz_danmarc_encoder(const char *tocode,
yaz_iconv_encoder_t e)
{
if (!yaz_matchstr(tocode, "danmarc"))
{
e->write_handle = write_danmarc;
return e;
}
return 0;
}
/*
* Local variables:
* c-basic-offset: 4
* c-file-style: "Stroustrup"
* indent-tabs-mode: nil
* End:
* vim: shiftwidth=4 tabstop=8 expandtab
*/
|