[xiph-commits] r7438 - trunk/icecast2yp/src
oddsock at motherfish-iii.xiph.org
oddsock
Thu Aug 5 19:05:45 PDT 2004
Author: oddsock
Date: Thu Aug 5 19:05:45 2004
New Revision: 7438
Removed:
trunk/icecast2yp/src/iconv_string.c
trunk/icecast2yp/src/iconv_string.h
Log:
these aren't used...should never have been committed...
Deleted: trunk/icecast2yp/src/iconv_string.c
===================================================================
--- trunk/icecast2yp/src/iconv_string.c 2004-07-31 21:51:45 UTC (rev 7437)
+++ trunk/icecast2yp/src/iconv_string.c 2004-07-31 21:59:31 UTC (rev 7438)
@@ -1,154 +0,0 @@
-/* Copyright (C) 1999-2001, 2003 Bruno Haible.
- This file is not part of the GNU LIBICONV Library.
- This file is put into the public domain. */
-
-#include "iconv_string.h"
-#include <iconv.h>
-#include <errno.h>
-#include <stdlib.h>
-#include <string.h>
-
-#define tmpbufsize 4096
-
-int iconv_string (const char* tocode, const char* fromcode,
- const char* start, const char* end,
- char** resultp, size_t* lengthp)
-{
- iconv_t cd = iconv_open(tocode,fromcode);
- size_t length;
- char* result;
- if (cd == (iconv_t)(-1)) {
- if (errno != EINVAL)
- return -1;
- /* Unsupported fromcode or tocode. Check whether the caller requested
- autodetection. */
- if (!strcmp(fromcode,"autodetect_utf8")) {
- int ret;
- /* Try UTF-8 first. There are very few ISO-8859-1 inputs that would
- be valid UTF-8, but many UTF-8 inputs are valid ISO-8859-1. */
- ret = iconv_string(tocode,"UTF-8",start,end,resultp,lengthp);
- if (!(ret < 0 && errno == EILSEQ))
- return ret;
- ret = iconv_string(tocode,"ISO-8859-1",start,end,resultp,lengthp);
- return ret;
- }
- if (!strcmp(fromcode,"autodetect_jp")) {
- int ret;
- /* Try 7-bit encoding first. If the input contains bytes >= 0x80,
- it will fail. */
- ret = iconv_string(tocode,"ISO-2022-JP-2",start,end,resultp,lengthp);
- if (!(ret < 0 && errno == EILSEQ))
- return ret;
- /* Try EUC-JP next. Short SHIFT_JIS inputs may come out wrong. This
- is unavoidable. People will condemn SHIFT_JIS.
- If we tried SHIFT_JIS first, then some short EUC-JP inputs would
- come out wrong, and people would condemn EUC-JP and Unix, which
- would not be good. */
- ret = iconv_string(tocode,"EUC-JP",start,end,resultp,lengthp);
- if (!(ret < 0 && errno == EILSEQ))
- return ret;
- /* Finally try SHIFT_JIS. */
- ret = iconv_string(tocode,"SHIFT_JIS",start,end,resultp,lengthp);
- return ret;
- }
- if (!strcmp(fromcode,"autodetect_kr")) {
- int ret;
- /* Try 7-bit encoding first. If the input contains bytes >= 0x80,
- it will fail. */
- ret = iconv_string(tocode,"ISO-2022-KR",start,end,resultp,lengthp);
- if (!(ret < 0 && errno == EILSEQ))
- return ret;
- /* Finally try EUC-KR. */
- ret = iconv_string(tocode,"EUC-KR",start,end,resultp,lengthp);
- return ret;
- }
- errno = EINVAL;
- return -1;
- }
- /* Determine the length we need. */
- {
- size_t count = 0;
- char tmpbuf[tmpbufsize];
- const char* inptr = start;
- size_t insize = end-start;
- while (insize > 0) {
- char* outptr = tmpbuf;
- size_t outsize = tmpbufsize;
- size_t res = iconv(cd,&inptr,&insize,&outptr,&outsize);
- if (res == (size_t)(-1) && errno != E2BIG) {
- if (errno == EINVAL)
- break;
- else {
- int saved_errno = errno;
- iconv_close(cd);
- errno = saved_errno;
- return -1;
- }
- }
- count += outptr-tmpbuf;
- }
- {
- char* outptr = tmpbuf;
- size_t outsize = tmpbufsize;
- size_t res = iconv(cd,NULL,NULL,&outptr,&outsize);
- if (res == (size_t)(-1)) {
- int saved_errno = errno;
- iconv_close(cd);
- errno = saved_errno;
- return -1;
- }
- count += outptr-tmpbuf;
- }
- length = count;
- }
- if (lengthp != NULL)
- *lengthp = length;
- if (resultp == NULL) {
- iconv_close(cd);
- return 0;
- }
- result = (*resultp == NULL ? malloc(length) : realloc(*resultp,length));
- *resultp = result;
- if (length == 0) {
- iconv_close(cd);
- return 0;
- }
- if (result == NULL) {
- iconv_close(cd);
- errno = ENOMEM;
- return -1;
- }
- iconv(cd,NULL,NULL,NULL,NULL); /* return to the initial state */
- /* Do the conversion for real. */
- {
- const char* inptr = start;
- size_t insize = end-start;
- char* outptr = result;
- size_t outsize = length;
- while (insize > 0) {
- size_t res = iconv(cd,&inptr,&insize,&outptr,&outsize);
- if (res == (size_t)(-1)) {
- if (errno == EINVAL)
- break;
- else {
- int saved_errno = errno;
- iconv_close(cd);
- errno = saved_errno;
- return -1;
- }
- }
- }
- {
- size_t res = iconv(cd,NULL,NULL,&outptr,&outsize);
- if (res == (size_t)(-1)) {
- int saved_errno = errno;
- iconv_close(cd);
- errno = saved_errno;
- return -1;
- }
- }
- if (outsize != 0) abort();
- }
- iconv_close(cd);
- return 0;
-}
Deleted: trunk/icecast2yp/src/iconv_string.h
===================================================================
--- trunk/icecast2yp/src/iconv_string.h 2004-07-31 21:51:45 UTC (rev 7437)
+++ trunk/icecast2yp/src/iconv_string.h 2004-07-31 21:59:31 UTC (rev 7438)
@@ -1,47 +0,0 @@
-/* Copyright (C) 1999-2001 Bruno Haible.
- This file is not part of the GNU LIBICONV Library.
- This file is put into the public domain. */
-
-/*
- * This C function converts an entire string from one encoding to another,
- * using iconv. Easier to use than iconv() itself, and supports autodetect
- * encodings on input.
- *
- * int iconv_string (const char* tocode, const char* fromcode,
- * const char* start, const char* end,
- * char** resultp, size_t* lengthp)
- *
- * Converts a memory region given in encoding FROMCODE to a new memory
- * region in encoding TOCODE. FROMCODE and TOCODE are as for iconv_open(3),
- * except that FROMCODE may be one of the values
- * "autodetect_utf8" supports ISO-8859-1 and UTF-8
- * "autodetect_jp" supports EUC-JP, ISO-2022-JP-2 and SHIFT_JIS
- * "autodetect_kr" supports EUC-KR and ISO-2022-KR
- * The input is in the memory region between start (inclusive) and end
- * (exclusive). If resultp is not NULL, the output string is stored in
- * *resultp; malloc/realloc is used to allocate the result.
- *
- * This function does not treat zero characters specially.
- *
- * Return value: 0 if successful, otherwise -1 and errno set. Particular
- * errno values: EILSEQ and ENOMEM.
- *
- * Example:
- * const char* s = ...;
- * char* result = NULL;
- * if (iconv_string("UCS-4-INTERNAL", "autodetect_utf8",
- * s, s+strlen(s)+1, &result, NULL) < 0)
- * perror("iconv_string");
- *
- */
-#include <stddef.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-extern int iconv_string (const char* tocode, const char* fromcode, const char* start, const char* end, char** resultp, size_t* lengthp);
-
-#ifdef __cplusplus
-}
-#endif
More information about the commits
mailing list