tld.c File Reference

#include <stringprep.h>
#include <string.h>
#include <tld.h>

Go to the source code of this file.

Defines

#define DOTP(c)

Functions

const Tld_tabletld_get_table (const char *tld, const Tld_table **tables)
const Tld_tabletld_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 Documentation

#define DOTP (  ) 

Value:

((c) == 0x002E || (c) == 0x3002 ||      \
                 (c) == 0xFF0E || (c) == 0xFF61)

Definition at line 95 of file tld.c.


Function Documentation

int tld_check_4 ( const uint32_t *  in,
size_t  inlen,
size_t *  errpos,
const Tld_table **  overrides 
)

tld_check_4 - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the information in or by the built-in TLD restriction data. When data for the same TLD is available both internally and in , the information in takes precedence. If several entries for a specific TLD are found, the first one is used. If is NULL, only the built-in information is used. The position of the first offending character is returned in .

Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 348 of file tld.c.

References tld_check_4t(), tld_default_table(), tld_get_4(), TLD_NO_TLD, and TLD_SUCCESS.

Referenced by tld_check_4z(), and tld_check_8z().

int tld_check_4t ( const uint32_t *  in,
size_t  inlen,
size_t *  errpos,
const Tld_table tld 
)

tld_check_4t - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the data structure in , return the position of the first character for which this is not the case in .

Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 269 of file tld.c.

References TLD_SUCCESS, and uint32_t.

Referenced by tld_check_4(), and tld_check_4tz().

int tld_check_4tz ( const uint32_t *  in,
size_t *  errpos,
const Tld_table tld 
)

tld_check_4tz - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the data structure in , return the position of the first character for which this is not the case in .

Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 311 of file tld.c.

References tld_check_4t(), TLD_NODATA, and uint32_t.

int tld_check_4z ( const uint32_t *  in,
size_t *  errpos,
const Tld_table **  overrides 
)

tld_check_4z - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the information in or by the built-in TLD restriction data. When data for the same TLD is available both internally and in , the information in takes precedence. If several entries for a specific TLD are found, the first one is used. If is NULL, only the built-in information is used. The position of the first offending character is returned in .

Return value: Returns the Tld_rc value TLD_SUCCESS if all code points are valid or when is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 398 of file tld.c.

References tld_check_4(), TLD_NODATA, and uint32_t.

int tld_check_8z ( const char *  in,
size_t *  errpos,
const Tld_table **  overrides 
)

tld_check_8z - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the information in or by the built-in TLD restriction data. When data for the same TLD is available both internally and in , the information in takes precedence. If several entries for a specific TLD are found, the first one is used. If is NULL, only the built-in information is used. The position of the first offending character is returned in . 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 is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 436 of file tld.c.

References stringprep_utf8_to_ucs4(), tld_check_4(), TLD_MALLOC_ERROR, TLD_NODATA, and uint32_t.

Referenced by tld_check_lz().

int tld_check_lz ( const char *  in,
size_t *  errpos,
const Tld_table **  overrides 
)

tld_check_lz - verify that characters are permitted

Parameters:
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 for whether or not they are allowed by the information in or by the built-in TLD restriction data. When data for the same TLD is available both internally and in , the information in takes precedence. If several entries for a specific TLD are found, the first one is used. If is NULL, only the built-in information is used. The position of the first offending character is returned in . 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 is null, TLD_INVALID if a character is not allowed, or additional error codes on general failure conditions.

Definition at line 481 of file tld.c.

References stringprep_locale_to_utf8(), tld_check_8z(), TLD_ICONV_ERROR, and TLD_NODATA.

const Tld_table* tld_default_table ( const char *  tld,
const Tld_table **  overrides 
)

tld_default_table - get table for a TLD name

Parameters:
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 deault tables.
Get the TLD table for a named TLD, using the internal defaults, possibly overrided by the (optional) supplied tables.

Return value: Return structure corresponding to TLD , first looking through then thru built-in list, or NULL if no such structure found.

Definition at line 79 of file tld.c.

References _tld_tables, and tld_get_table().

Referenced by tld_check_4().

int tld_get_4 ( const uint32_t *  in,
size_t  inlen,
char **  out 
)

tld_get_4 - extract top level domain part in input Unicode string

Parameters:
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 and return it as an ASCII string in .

Return value: Return TLD_SUCCESS on success, or the corresponding Tld_rc error code otherwise.

Definition at line 112 of file tld.c.

References DOTP, TLD_MALLOC_ERROR, TLD_NO_TLD, TLD_NODATA, TLD_SUCCESS, and uint32_t.

Referenced by tld_check_4(), tld_get_4z(), and tld_get_z().

int tld_get_4z ( const uint32_t *  in,
char **  out 
)

tld_get_4z - extract top level domain part in input Unicode string

Parameters:
in Zero terminated array of unicode code points to process.
out Zero terminated ascii result string pointer.
Isolate the top-level domain of and return it as an ASCII string in .

Return value: Return TLD_SUCCESS on success, or the corresponding Tld_rc error code otherwise.

Definition at line 160 of file tld.c.

References tld_get_4(), TLD_NODATA, and uint32_t.

const Tld_table* tld_get_table ( const char *  tld,
const Tld_table **  tables 
)

tld_get_table - get table for a TLD name in table

Parameters:
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 by going thru , or return NULL if no such structure is found.

Definition at line 50 of file tld.c.

References Stringprep_profiles::tables.

Referenced by tld_default_table().

int tld_get_z ( const char *  in,
char **  out 
)

tld_get_z - extract top level domain part in input string

Parameters:
in Zero terminated character array to process.
out Zero terminated ascii result string pointer.
Isolate the top-level domain of and return it as an ASCII string in . The input string 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.

Definition at line 186 of file tld.c.

References tld_get_4(), TLD_MALLOC_ERROR, and uint32_t.


Variable Documentation

const Tld_table* _tld_tables[]

Definition at line 58 of file tlds.c.

Referenced by tld_default_table().


Generated on Wed Sep 13 10:20:32 2006 for libidn by  doxygen 1.4.7