Blame os400/wrappers.c

Packit 423ecb
/**
Packit 423ecb
***     UTF-8/EBCDIC wrappers to system and C library procedures.
Packit 423ecb
***
Packit 423ecb
***     See Copyright for the status of this software.
Packit 423ecb
***
Packit 423ecb
***     Author: Patrick Monnerat <pm@datasphere.ch>, DATASPHERE S.A.
Packit 423ecb
**/
Packit 423ecb
Packit 423ecb
#include <sys/types.h>
Packit 423ecb
#include <sys/socket.h>
Packit 423ecb
#include <arpa/inet.h>
Packit 423ecb
#include <stdlib.h>
Packit 423ecb
#include <dlfcn.h>
Packit 423ecb
#include <netdb.h>
Packit 423ecb
#include <errno.h>
Packit 423ecb
Packit 423ecb
#include "config.h"
Packit 423ecb
Packit 423ecb
#include "libxml/xmlmemory.h"
Packit 423ecb
Packit 423ecb
#include "transcode.h"
Packit 423ecb
Packit 423ecb
Packit 423ecb
static const char *     lxdles = NULL;
Packit 423ecb
Packit 423ecb
Packit 423ecb
int
Packit 423ecb
_lx_getaddrinfo(const char * node, const char * service,
Packit 423ecb
        const struct addrinfo * hints, struct addrinfo * * res)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        int i;
Packit 423ecb
Packit 423ecb
        i = getaddrinfo(xmlTranscodeResult(node, NULL, &d, NULL),
Packit 423ecb
            xmlTranscodeResult(service, NULL, &d, NULL), hints, res);
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return i;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
const char *
Packit 423ecb
_lx_inet_ntop(int af, const void * src, char * dst, socklen_t size)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        const char * cp1 = inet_ntop(af, src, dst, size);
Packit 423ecb
        char const * cp2;
Packit 423ecb
        int i;
Packit 423ecb
Packit 423ecb
        if (!cp1)
Packit 423ecb
                return cp1;
Packit 423ecb
Packit 423ecb
        if (!(cp2 = xmlTranscodeString(cp1, NULL, NULL)))
Packit 423ecb
                return cp2;
Packit 423ecb
Packit 423ecb
        i = strlen(cp2);
Packit 423ecb
Packit 423ecb
        if (i >= size) {
Packit 423ecb
                xmlFree((char *) cp2);
Packit 423ecb
                errno = ENOSPC;
Packit 423ecb
                return (const char *) NULL;
Packit 423ecb
                }
Packit 423ecb
Packit 423ecb
        memcpy(dst, cp2, i + 1);
Packit 423ecb
        xmlFree((char *) cp2);
Packit 423ecb
        return dst;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
void *
Packit 423ecb
_lx_dlopen(const char * filename, int flag)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        void * result;
Packit 423ecb
Packit 423ecb
        result = dlopen(xmlTranscodeResult(filename, NULL, &d, NULL), flag);
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return result;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
void *
Packit 423ecb
_lx_dlsym(void * handle, const char * symbol)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        void * result;
Packit 423ecb
Packit 423ecb
        result = dlsym(handle, xmlTranscodeResult(symbol, NULL, &d, NULL));
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return result;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
char *
Packit 423ecb
_lx_dlerror(void)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        char * cp1 = (char *) dlerror();
Packit 423ecb
Packit 423ecb
        if (!cp1)
Packit 423ecb
                return cp1;
Packit 423ecb
Packit 423ecb
        if (lxdles)
Packit 423ecb
                xmlFree((char *) lxdles);
Packit 423ecb
Packit 423ecb
        lxdles = (const char *) xmlTranscodeString(cp1, NULL, NULL);
Packit 423ecb
        return (char *) lxdles;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
#ifdef HAVE_ZLIB_H
Packit 423ecb
#include <zlib.h>
Packit 423ecb
Packit 423ecb
gzFile
Packit 423ecb
_lx_gzopen(const char * path, const char * mode)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        gzFile f;
Packit 423ecb
Packit 423ecb
        f = gzopen(xmlTranscodeResult(path, NULL, &d, NULL),
Packit 423ecb
            xmlTranscodeResult(mode, NULL, &d, NULL));
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return f;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
Packit 423ecb
gzFile
Packit 423ecb
_lx_gzdopen(int fd, const char * mode)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        gzFile f;
Packit 423ecb
Packit 423ecb
        f = gzdopen(fd, xmlTranscodeResult(mode, NULL, &d, NULL));
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return f;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
int
Packit 423ecb
_lx_inflateInit2_(z_streamp strm, int windowBits,
Packit 423ecb
                                        const char * version, int stream_size)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        int r;
Packit 423ecb
Packit 423ecb
        r = inflateInit2_(strm, windowBits,
Packit 423ecb
            xmlTranscodeResult(version, NULL, &d, NULL), stream_size);
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return r;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
int
Packit 423ecb
_lx_deflateInit2_(z_streamp strm, int level, int method, int windowBits,
Packit 423ecb
        int memLevel, int strategy, const char * version, int stream_size)
Packit 423ecb
Packit 423ecb
{
Packit 423ecb
        xmlDictPtr d = NULL;
Packit 423ecb
        int r;
Packit 423ecb
Packit 423ecb
        r = deflateInit2_(strm, level, method, windowBits, memLevel, strategy,
Packit 423ecb
            xmlTranscodeResult(version, NULL, &d, NULL), stream_size);
Packit 423ecb
        xmlZapDict(&d);
Packit 423ecb
        return r;
Packit 423ecb
}
Packit 423ecb
Packit 423ecb
#endif