libidn
1.42
|
Go to the source code of this file.
Macros | |
#define | DOTP(c) |
Functions | |
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_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) |
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) |
Variables | |
const Tld_table * | _tld_tables [] |
#define DOTP | ( | c | ) |
int tld_check_4 | ( | const uint32_t * | in, |
size_t | inlen, | ||
size_t * | errpos, | ||
const Tld_table ** | overrides | ||
) |
tld_check_4:
in | Array of unicode code points to process. Does not need to be zero terminated. |
inlen | Number of unicode code points. |
errpos | Position of offending character is returned here. |
overrides | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when @tld is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.
int tld_check_4t | ( | const uint32_t * | in, |
size_t | inlen, | ||
size_t * | errpos, | ||
const Tld_table * | tld | ||
) |
tld_check_4t:
in | Array of unicode code points to process. Does not need to be zero terminated. |
inlen | Number of unicode code points. |
errpos | Position of offending character is returned here. |
tld | A Tld_table data structure representing the restrictions for which the input should be tested. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when @tld is null, TLD_INVALID if 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 | ||
) |
tld_check_4tz:
in | Zero terminated array of unicode code points to process. |
errpos | Position of offending character is returned here. |
tld | A Tld_table data structure representing the restrictions for which the input should be tested. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when @tld is null, TLD_INVALID if 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 | ||
) |
tld_check_4z:
in | Zero-terminated array of unicode code points to process. |
errpos | Position of offending character is returned here. |
overrides | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when @tld is null, TLD_INVALID if 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 | ||
) |
tld_check_8z:
in | Zero-terminated UTF8 string to process. |
errpos | Position of offending character is returned here. |
overrides | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all characters are valid or when @tld is null, TLD_INVALID if 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 | ||
) |
tld_check_lz:
in | Zero-terminated string in the current locales encoding to process. |
errpos | Position of offending character is returned here. |
overrides | A Tld_table array of additional domain restriction structures that complement and supersede the built-in information. |
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.
Return value: Returns the Tld_rc value TLD_SUCCESS if all characters are valid or when @tld is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.
tld_default_table:
tld | TLD name (e.g. "com") as zero terminated ASCII byte string. |
overrides | Additional zero terminated array of Tld_table info-structures for TLDs, or NULL to only use library default tables. |
Get the TLD table for a named TLD, using the internal defaults, possibly overridden by the (optional) supplied tables.
Return value: Return structure corresponding to TLD @tld_str, first looking through @overrides then thru built-in list, or NULL if no such structure found.
int tld_get_4 | ( | const uint32_t * | in, |
size_t | inlen, | ||
char ** | out | ||
) |
tld_get_4:
in | Array of unicode code points to process. Does not need to be zero terminated. |
inlen | Number of unicode code points. |
out | Zero terminated ascii result string pointer. |
Isolate the top-level domain of @in and return it as an ASCII string in @out.
Return value: Return TLD_SUCCESS on success, or the corresponding Tld_rc error code otherwise.
int tld_get_4z | ( | const uint32_t * | in, |
char ** | out | ||
) |
tld_get_4z:
in | Zero terminated array of unicode code points to process. |
out | Zero terminated ascii result string pointer. |
Isolate the top-level domain of @in and return it as an ASCII string in @out.
Return value: Return TLD_SUCCESS on success, or the corresponding Tld_rc error code otherwise.
tld_get_table:
tld | TLD name (e.g. "com") as zero terminated ASCII byte string. |
tables | Zero terminated array of Tld_table info-structures for TLDs. |
Get the TLD table for a named TLD by searching through the given TLD table array.
Return value: Return structure corresponding to TLD @tld by going thru @tables, or return NULL if no such structure is found.
int tld_get_z | ( | const char * | in, |
char ** | out | ||
) |
tld_get_z:
in | Zero terminated character array to process. |
out | Zero terminated ascii result string pointer. |
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.
Return value: Return TLD_SUCCESS on success, or the corresponding Tld_rc error code otherwise.