Provided by:
manpages-es_1.55-10_all 
NOMBRE
iconv - realiza la conversion del conjunto de caracteres
SINOPSIS
#include <iconv.h>
size_t iconv(iconv_t cd,
char **inbuf, size_t *inbytesleft,
char **outbuf, size_t *outbytesleft);
DESCRIPCI'ON
El argumento cd debe ser un descriptor de conversion creado mediante la
funcion iconv_open.
El principal caso se da cuando inbuf es distinto de NULL y *inbuf es
distinto de NULL. En este caso, la funcion iconv convierte la
secuencia multibyte que comienza en *inbuf en una secuencia multibyte
que comenzara en *outbuf. Como mucho se leeran *inbytesleft bytes,
comenzando en *inbuf. Como mucho se escribiran *outbytesleft bytes,
comenzando en *outbuf.
La funcion iconv convierte un caracter multibyte a la vez, y para cada
conversion individual incrementa *inbuf y decrementa *inbytesleft con
el numero de bytes de entrada convertidos, incrementa *outbuf y
decrementa *outbytesleft con el numero de bytes de salida convertidos,
y actualiza el estado de la conversion contenido en cd. La conversion
puede detenerse por cuatro motivos:
1. Se encontro una secuencia multibyte invalida en la entrada. En este
caso se asigna a errno el valor EILSEQ y se devuelve (size_t)(-1).
*inbuf se deja apuntando al principio de la secuencia multibyte
invalida.
2. La secuencia de bytes de entrada ha sido totalmente convertida, esto
es, *inbytesleft ha llegado a 0. En este caso iconv devuelve el numero
de conversiones no recuperables realizadas durante esta llamada.
3. Se encontro una secuencia multibyte incompleta en la entrada, y la
secuencia de bytes de entrada termina despues de ella. En este caso se
asigna a errno el valor EINVAL y se devuelve (size_t)(-1). *inbuf se
deja apuntando al principio de la secuencia multibyte incompleta.
4. El buffer de salida no tiene suficiente espacio para el siguiente
caracter convertido. En este caso se asigna a errno el valor E2BIG y se
devuelve (size_t)(-1).
Un caso diferente es cuando inbuf es NULL o *inbuf es NULL, pero outbuf
no es NULL y *outbuf no es NULL. En este caso, la funcion iconv intenta
poner el estado de conversion de cd en el estado inicial y almacenar
una secuencia de cambios correspondiente en *outbuf. Como mucho se
ecribiran *outbytesleft bytes, comenzando en *outbuf. Si el buffer de
salida se queda sin espacio para esta secuencia de reinicio, la funcion
asigna a errno el valor E2BIG y devuelve (size_t)(-1). En otro caso
incrementa *outbuf y decrementa *outbytesleft con el numero de bytes
escritos.
Un tercer caso es cuando inbuf es NULL o *inbuf es NULL, y outbuf es
NULL o *outbuf es NULL. En este caso, la funcion iconv pone el estado
de conversion de cd en el estado inicial.
VALOR DEVUELTO
La funcion iconv devuelve el numero de caracteres convertidos de manera
no-recuperable durante la llamada; las conversiones recuperables no se
cuentan. En caso de error, modifica errno con un valor apropiado y
devuelve (size_t)(-1).
ERRORES
Pueden ocurrir los siguientes errores, entre otros:
E2BIG No hay suficiente espacio en *outbuf.
EILSEQ Se encontro una secuencia multibyte invalida a la entrada.
EINVAL Se encontro una secuencia multibyte incompleta a la entrada.
CONFORME A
UNIX98
V'EASE TAMBI'EN
iconv_open(3), iconv_close(3)