|  |  |  | GNU Libidn API Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#define IDNAPI typedef Tld_table_element; typedef Tld_table; enum Tld_rc; const char * tld_strerror (Tld_rc rc); int tld_get_4 (const uint32_t *in, size_t inlen, char **out); int tld_get_4z (const uint32_t *in, char **out); int tld_get_z (const char *in, char **out); const Tld_table * tld_get_table (const char *tld, const Tld_table **tables); const Tld_table * tld_default_table (const char *tld, const Tld_table **overrides); int tld_check_4t (const uint32_t *in, size_t inlen, size_t *errpos, const Tld_table *tld); int tld_check_4tz (const uint32_t *in, size_t *errpos, const Tld_table *tld); int tld_check_4 (const uint32_t *in, size_t inlen, size_t *errpos, const Tld_table **overrides); int tld_check_4z (const uint32_t *in, size_t *errpos, const Tld_table **overrides); int tld_check_8z (const char *in, size_t *errpos, const Tld_table **overrides); int tld_check_lz (const char *in, size_t *errpos, const Tld_table **overrides);
  typedef enum
  {
    TLD_SUCCESS = 0,
    TLD_INVALID = 1,		/* Invalid character found. */
    TLD_NODATA = 2,		/* Char, domain or inlen = 0. */
    TLD_MALLOC_ERROR = 3,
    TLD_ICONV_ERROR = 4,
    TLD_NO_TLD = 5,
    /* Workaround typo in earlier versions. */
    TLD_NOTLD = TLD_NO_TLD
  } Tld_rc;
Enumerated return codes of the TLD checking functions. The value 0 is guaranteed to always correspond to success.
| Successful operation. This value is guaranteed to always be zero, the remaining ones are only guaranteed to hold non-zero values, for logical comparison purposes. | |
| Invalid character found. | |
| No input data was provided. | |
| Error during memory allocation. | |
| Error during iconv string conversion. | |
| No top-level domain found in domain string. | |
const char * tld_strerror (Tld_rc rc);
Convert a return code integer to a text string. This string can be used to output a diagnostic message to the user.
TLD_SUCCESS: Successful operation. This value is guaranteed to always be zero, the remaining ones are only guaranteed to hold non-zero values, for logical comparison purposes. TLD_INVALID: Invalid character found. TLD_NODATA: No input data was provided. TLD_MALLOC_ERROR: Error during memory allocation. TLD_ICONV_ERROR: Error during iconv string conversion. TLD_NO_TLD: No top-level domain found in domain string.
| 
 | tld return code | 
| Returns : | Returns a pointer to a statically allocated string
containing a description of the error with the return code rc. | 
int                 tld_get_4                           (const uint32_t *in,
                                                         size_t inlen,
                                                         char **out);
Isolate the top-level domain of in and return it as an ASCII
string in out.
| 
 | Array of unicode code points to process. Does not need to be zero terminated. | 
| 
 | Number of unicode code points. | 
| 
 | Zero terminated ascii result string pointer. | 
| Returns : | Return TLD_SUCCESSon success, or the corresponding
  Tld_rc error code otherwise. | 
int                 tld_get_4z                          (const uint32_t *in,
                                                         char **out);
Isolate the top-level domain of in and return it as an ASCII
string in out.
| 
 | Zero terminated array of unicode code points to process. | 
| 
 | Zero terminated ascii result string pointer. | 
| Returns : | Return TLD_SUCCESSon success, or the corresponding
  Tld_rc error code otherwise. | 
int                 tld_get_z                           (const char *in,
                                                         char **out);
Isolate the top-level domain of in and return it as an ASCII
string in out.  The input string in may be UTF-8, ISO-8859-1 or
any ASCII compatible character encoding.
| 
 | Zero terminated character array to process. | 
| 
 | Zero terminated ascii result string pointer. | 
| Returns : | Return TLD_SUCCESSon success, or the corresponding
  Tld_rc error code otherwise. | 
const Tld_table * tld_get_table (const char *tld, const Tld_table **tables);
Get the TLD table for a named TLD by searching through the given TLD table array.
| 
 | TLD name (e.g. "com") as zero terminated ASCII byte string. | 
| 
 | Zero terminated array of Tld_table info-structures for TLDs. | 
| Returns : | Return structure corresponding to TLD tldby going
  thrutables, or returnNULLif no such structure is found. | 
const Tld_table * tld_default_table (const char *tld, const Tld_table **overrides);
Get the TLD table for a named TLD, using the internal defaults, possibly overrided by the (optional) supplied tables.
| 
 | TLD name (e.g. "com") as zero terminated ASCII byte string. | 
| 
 | Additional zero terminated array of Tld_table
  info-structures for TLDs, or NULLto only use library deault
  tables. | 
| Returns : | Return structure corresponding to TLD tld_str, first
  looking throughoverridesthen thru built-in list, orNULLif
  no such structure found. | 
int                 tld_check_4t                        (const uint32_t *in,
                                                         size_t inlen,
                                                         size_t *errpos,
                                                         const Tld_table *tld);
Test each of the code points in in for whether or not
they are allowed by the data structure in tld, return
the position of the first character for which this is not
the case in errpos.
| 
 | Array of unicode code points to process. Does not need to be zero terminated. | 
| 
 | Number of unicode code points. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table data structure representing the restrictions for which the input should be tested. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all code
  points are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. | 
int                 tld_check_4tz                       (const uint32_t *in,
                                                         size_t *errpos,
                                                         const Tld_table *tld);
Test each of the code points in in for whether or not
they are allowed by the data structure in tld, return
the position of the first character for which this is not
the case in errpos.
| 
 | Zero terminated array of unicode code points to process. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table data structure representing the restrictions for which the input should be tested. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all code
  points are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. | 
int                 tld_check_4                         (const uint32_t *in,
                                                         size_t inlen,
                                                         size_t *errpos,
                                                         const Tld_table **overrides);
Test each of the code points in in for whether or not they are
allowed by the information in overrides or by the built-in TLD
restriction data. When data for the same TLD is available both
internally and in overrides, the information in overrides takes
precedence. If several entries for a specific TLD are found, the
first one is used.  If overrides is NULL, only the built-in
information is used.  The position of the first offending character
is returned in errpos.
| 
 | Array of unicode code points to process. Does not need to be zero terminated. | 
| 
 | Number of unicode code points. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all code
  points are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. | 
int                 tld_check_4z                        (const uint32_t *in,
                                                         size_t *errpos,
                                                         const Tld_table **overrides);
Test each of the code points in in for whether or not they are
allowed by the information in overrides or by the built-in TLD
restriction data. When data for the same TLD is available both
internally and in overrides, the information in overrides takes
precedence. If several entries for a specific TLD are found, the
first one is used.  If overrides is NULL, only the built-in
information is used.  The position of the first offending character
is returned in errpos.
| 
 | Zero-terminated array of unicode code points to process. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all code
  points are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. | 
int                 tld_check_8z                        (const char *in,
                                                         size_t *errpos,
                                                         const Tld_table **overrides);
Test each of the characters in in for whether or not they are
allowed by the information in overrides or by the built-in TLD
restriction data. When data for the same TLD is available both
internally and in overrides, the information in overrides takes
precedence. If several entries for a specific TLD are found, the
first one is used.  If overrides is NULL, only the built-in
information is used.  The position of the first offending character
is returned in errpos.  Note that the error position refers to the
decoded character offset rather than the byte position in the
string.
| 
 | Zero-terminated UTF8 string to process. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all
  characters are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. | 
int                 tld_check_lz                        (const char *in,
                                                         size_t *errpos,
                                                         const Tld_table **overrides);
Test each of the characters in in for whether or not they are
allowed by the information in overrides or by the built-in TLD
restriction data. When data for the same TLD is available both
internally and in overrides, the information in overrides takes
precedence. If several entries for a specific TLD are found, the
first one is used.  If overrides is NULL, only the built-in
information is used.  The position of the first offending character
is returned in errpos.  Note that the error position refers to the
decoded character offset rather than the byte position in the
string.
| 
 | Zero-terminated string in the current locales encoding to process. | 
| 
 | Position of offending character is returned here. | 
| 
 | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. | 
| Returns : | Returns the Tld_rc value TLD_SUCCESSif all
  characters are valid or whentldis null,TLD_INVALIDif a
  character is not allowed, or additional error codes on general
  failure conditions. |