idn2_to_ascii_lz(3) libidn2 idn2_to_ascii_lz(3)

idn2_to_ascii_lz - API function

#include <idn2.h>

int idn2_to_ascii_lz(const char * input, char ** output, int flags);

zero terminated input UTF-8 string.
pointer to newly allocated output string.
optional idn2_flags to modify behaviour.

Convert a domain name in locale's encoding to ASCII string using the IDNA2008 rules. The domain name may contain several labels, separated by dots. The output buffer must be deallocated by the caller.

The default behavior of this function (when flags are zero) is to apply the IDNA2008 rules without the TR46 amendments. As the TR46 non-transitional processing is nowadays ubiquitous, when unsure, it is recommended to call this function with the IDN2_NONTRANSITIONAL and the IDN2_NFC_INPUT flags for compatibility with other software.

IDN2_OK on success, or error code. Same as described in idn2_lookup_ul() documentation.


Report bugs to <>.
General guidelines for reporting bugs:
Libidn2 home page:

Copyright © 2002-2024 Simon Josefsson.
Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved.

The full documentation for libidn2 is maintained as a Texinfo manual. If the info and libidn2 programs are properly installed at your site, the command

info libidn2

should give you access to the complete manual. As an alternative you may obtain the manual from:
2.3.7 libidn2