⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 scanner.h

📁 基于sip协议的网络电话源码
💻 H
📖 第 1 页 / 共 2 页
字号:
 * of PJ_SCAN_AUTOSKIP_WS settings. If the character left is less than len,  * syntax error callback will be called. * * @param scanner   The scanner. * @param len	    Length to peek. * @param out	    String to store the result. * * @return the character right after the peek-ed position or zero if there's *	   no more characters. */PJ_DECL(int) pj_scan_peek_n( pj_scanner *scanner,			     pj_size_t len, pj_str_t *out);/**  * Peek strings in current position until spec is matched, and return * the strings in parameter out. The current scanner position will not be * moved. If the scanner is already in EOF state, syntax error callback will * be called. * * @param scanner   The scanner. * @param spec	    The peeking will stop when the input match this spec. * @param out	    String to store the result. * * @return the character right after the peek-ed position. */PJ_DECL(int) pj_scan_peek_until( pj_scanner *scanner,				 const pj_cis_t *spec, 				 pj_str_t *out);/**  * Get characters from the buffer according to the spec, and return them * in out parameter. The scanner will attempt to get as many characters as * possible as long as the spec matches. If the first character doesn't * match the spec, or scanner is already in EOF when this function is called, * an exception will be thrown. * * @param scanner   The scanner. * @param spec	    The spec to match input string. * @param out	    String to store the result. */PJ_DECL(void) pj_scan_get( pj_scanner *scanner,			   const pj_cis_t *spec, pj_str_t *out);/**  * Just like #pj_scan_get(), but additionally performs unescaping when * escaped ('%') character is found. The input spec MUST NOT contain the * specification for '%' characted. * * @param scanner   The scanner. * @param spec	    The spec to match input string. * @param out	    String to store the result. */PJ_DECL(void) pj_scan_get_unescape( pj_scanner *scanner,				    const pj_cis_t *spec, pj_str_t *out);/**  * Get characters between quotes. If current input doesn't match begin_quote, * syntax error will be thrown. Note that the resulting string will contain * the enclosing quote. * * @param scanner	The scanner. * @param begin_quote	The character to begin the quote. * @param end_quote	The character to end the quote. * @param out		String to store the result. */PJ_DECL(void) pj_scan_get_quote( pj_scanner *scanner,				 int begin_quote, int end_quote, 				 pj_str_t *out);/**  * Get characters between quotes. If current input doesn't match begin_quote, * syntax error will be thrown. Note that the resulting string will contain * the enclosing quote. * * @param scanner	The scanner. * @param begin_quotes  The character array to begin the quotes. For example, *                      the two characters " and '. * @param end_quotes    The character array to end the quotes. The position *                      found in the begin_quotes array will be used to match *                      the end quotes. So if the begin_quotes was the array *                      of "'< the end_quotes should be "'>. If begin_array *                      matched the ' then the end_quotes will look for ' to *                      match at the end. * @param qsize         The size of the begin_quotes and end_quotes arrays. * @param out           String to store the result. */PJ_DECL(void) pj_scan_get_quotes(pj_scanner *scanner,                                 const char *begin_quotes,                                 const char *end_quotes, int qsize,                                 pj_str_t *out);/** * Get N characters from the scanner. * * @param scanner   The scanner. * @param N	    Number of characters to get. * @param out	    String to store the result. */PJ_DECL(void) pj_scan_get_n( pj_scanner *scanner,			     unsigned N, pj_str_t *out);/**  * Get one character from the scanner. * * @param scanner   The scanner. * * @return The character. */PJ_DECL(int) pj_scan_get_char( pj_scanner *scanner );/**  * Get characters from the scanner and move the scanner position until the * current character matches the spec. * * @param scanner   The scanner. * @param spec	    Get until the input match this spec. * @param out	    String to store the result. */PJ_DECL(void) pj_scan_get_until( pj_scanner *scanner,				 const pj_cis_t *spec, pj_str_t *out);/**  * Get characters from the scanner and move the scanner position until the * current character matches until_char. * * @param scanner	The scanner. * @param until_char    Get until the input match this character. * @param out		String to store the result. */PJ_DECL(void) pj_scan_get_until_ch( pj_scanner *scanner, 				    int until_char, pj_str_t *out);/**  * Get characters from the scanner and move the scanner position until the * current character matches until_char. * * @param scanner	The scanner. * @param until_spec	Get until the input match any of these characters. * @param out		String to store the result. */PJ_DECL(void) pj_scan_get_until_chr( pj_scanner *scanner,				     const char *until_spec, pj_str_t *out);/**  * Advance the scanner N characters, and skip whitespace * if necessary. * * @param scanner   The scanner. * @param N	    Number of characters to skip. * @param skip	    Flag to specify whether whitespace should be skipped *		    after skipping the characters. */PJ_DECL(void) pj_scan_advance_n( pj_scanner *scanner,				 unsigned N, pj_bool_t skip);/**  * Compare string in current position with the specified string. *  * @param scanner   The scanner. * @param s	    The string to compare with. * @param len	    Length of the string to compare. * * @return zero, <0, or >0 (just like strcmp()). */PJ_DECL(int) pj_scan_strcmp( pj_scanner *scanner, const char *s, int len);/**  * Case-less string comparison of current position with the specified * string. * * @param scanner   The scanner. * @param s	    The string to compare with. * @param len	    Length of the string to compare with. * * @return zero, <0, or >0 (just like strcmp()). */PJ_DECL(int) pj_scan_stricmp( pj_scanner *scanner, const char *s, int len);/** * Perform case insensitive string comparison of string in current position, * knowing that the string to compare only consists of alphanumeric * characters. * * Note that unlike #pj_scan_stricmp, this function can only return zero or * -1. * * @param scanner   The scanner. * @param s	    The string to compare with. * @param len	    Length of the string to compare with. * * @return	    zero if equal or -1. * * @see strnicmp_alnum, pj_stricmp_alnum */PJ_DECL(int) pj_scan_stricmp_alnum( pj_scanner *scanner, const char *s, 				    int len);/**  * Get a newline from the scanner. A newline is defined as '\\n', or '\\r', or * "\\r\\n". If current input is not newline, syntax error will be thrown. * * @param scanner   The scanner. */PJ_DECL(void) pj_scan_get_newline( pj_scanner *scanner );/**  * Manually skip whitespaces according to flag that was specified when * the scanner was initialized. * * @param scanner   The scanner. */PJ_DECL(void) pj_scan_skip_whitespace( pj_scanner *scanner );/** * Skip current line. * * @param scanner   The scanner. */PJ_DECL(void) pj_scan_skip_line( pj_scanner *scanner );/**  * Save the full scanner state. * * @param scanner   The scanner. * @param state	    Variable to store scanner's state. */PJ_DECL(void) pj_scan_save_state( const pj_scanner *scanner, 				  pj_scan_state *state);/**  * Restore the full scanner state. * Note that this would not restore the string if application has modified * it. This will only restore the scanner scanning position. * * @param scanner   The scanner. * @param state	    State of the scanner. */PJ_DECL(void) pj_scan_restore_state( pj_scanner *scanner, 				     pj_scan_state *state);/** * Get current column position. * * @param scanner   The scanner. * * @return	    The column position. */PJ_INLINE(int) pj_scan_get_col( const pj_scanner *scanner ){    return (int)(scanner->curptr - scanner->start_line);}/** * @} */PJ_END_DECL#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -