diff options
Diffstat (limited to 'protocols/Sametime/src/glib/gregex.h')
| -rw-r--r-- | protocols/Sametime/src/glib/gregex.h | 471 | 
1 files changed, 471 insertions, 0 deletions
diff --git a/protocols/Sametime/src/glib/gregex.h b/protocols/Sametime/src/glib/gregex.h new file mode 100644 index 0000000000..ce1b44a972 --- /dev/null +++ b/protocols/Sametime/src/glib/gregex.h @@ -0,0 +1,471 @@ +/* GRegex -- regular expression API wrapper around PCRE. + * + * Copyright (C) 1999, 2000 Scott Wimer + * Copyright (C) 2004, Matthias Clasen <mclasen@redhat.com> + * Copyright (C) 2005 - 2007, Marco Barisione <marco@barisione.org> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA + */ + +#if defined(G_DISABLE_SINGLE_INCLUDES) && !defined (__GLIB_H_INSIDE__) && !defined (GLIB_COMPILATION) +#error "Only <glib.h> can be included directly." +#endif + +#ifndef __G_REGEX_H__ +#define __G_REGEX_H__ + +#include <glib/gerror.h> +#include <glib/gstring.h> + +G_BEGIN_DECLS + +/** + * GRegexError: + * @G_REGEX_ERROR_COMPILE: Compilation of the regular expression failed. + * @G_REGEX_ERROR_OPTIMIZE: Optimization of the regular expression failed. + * @G_REGEX_ERROR_REPLACE: Replacement failed due to an ill-formed replacement + *     string. + * @G_REGEX_ERROR_MATCH: The match process failed. + * @G_REGEX_ERROR_INTERNAL: Internal error of the regular expression engine. + *     Since 2.16 + * @G_REGEX_ERROR_STRAY_BACKSLASH: "\\" at end of pattern. Since 2.16 + * @G_REGEX_ERROR_MISSING_CONTROL_CHAR: "\\c" at end of pattern. Since 2.16 + * @G_REGEX_ERROR_UNRECOGNIZED_ESCAPE: Unrecognized character follows "\\". + *     Since 2.16 + * @G_REGEX_ERROR_QUANTIFIERS_OUT_OF_ORDER: Numbers out of order in "{}" + *     quantifier. Since 2.16 + * @G_REGEX_ERROR_QUANTIFIER_TOO_BIG: Number too big in "{}" quantifier. + *     Since 2.16 + * @G_REGEX_ERROR_UNTERMINATED_CHARACTER_CLASS: Missing terminating "]" for + *     character class. Since 2.16 + * @G_REGEX_ERROR_INVALID_ESCAPE_IN_CHARACTER_CLASS: Invalid escape sequence + *     in character class. Since 2.16 + * @G_REGEX_ERROR_RANGE_OUT_OF_ORDER: Range out of order in character class. + *     Since 2.16 + * @G_REGEX_ERROR_NOTHING_TO_REPEAT: Nothing to repeat. Since 2.16 + * @G_REGEX_ERROR_UNRECOGNIZED_CHARACTER: Unrecognized character after "(?", + *     "(?<" or "(?P". Since 2.16 + * @G_REGEX_ERROR_POSIX_NAMED_CLASS_OUTSIDE_CLASS: POSIX named classes are + *     supported only within a class. Since 2.16 + * @G_REGEX_ERROR_UNMATCHED_PARENTHESIS: Missing terminating ")" or ")" + *     without opening "(". Since 2.16 + * @G_REGEX_ERROR_INEXISTENT_SUBPATTERN_REFERENCE: Reference to non-existent + *     subpattern. Since 2.16 + * @G_REGEX_ERROR_UNTERMINATED_COMMENT: Missing terminating ")" after comment. + *     Since 2.16 + * @G_REGEX_ERROR_EXPRESSION_TOO_LARGE: Regular expression too large. + *     Since 2.16 + * @G_REGEX_ERROR_MEMORY_ERROR: Failed to get memory. Since 2.16 + * @G_REGEX_ERROR_VARIABLE_LENGTH_LOOKBEHIND: Lookbehind assertion is not + *     fixed length. Since 2.16 + * @G_REGEX_ERROR_MALFORMED_CONDITION: Malformed number or name after "(?(". + *     Since 2.16 + * @G_REGEX_ERROR_TOO_MANY_CONDITIONAL_BRANCHES: Conditional group contains + *     more than two branches. Since 2.16 + * @G_REGEX_ERROR_ASSERTION_EXPECTED: Assertion expected after "(?(". + *     Since 2.16 + * @G_REGEX_ERROR_UNKNOWN_POSIX_CLASS_NAME: Unknown POSIX class name. + *     Since 2.16 + * @G_REGEX_ERROR_POSIX_COLLATING_ELEMENTS_NOT_SUPPORTED: POSIX collating + *     elements are not supported. Since 2.16 + * @G_REGEX_ERROR_HEX_CODE_TOO_LARGE: Character value in "\\x{...}" sequence + *     is too large. Since 2.16 + * @G_REGEX_ERROR_INVALID_CONDITION: Invalid condition "(?(0)". Since 2.16 + * @G_REGEX_ERROR_SINGLE_BYTE_MATCH_IN_LOOKBEHIND: \\C not allowed in + *     lookbehind assertion. Since 2.16 + * @G_REGEX_ERROR_INFINITE_LOOP: Recursive call could loop indefinitely. + *     Since 2.16 + * @G_REGEX_ERROR_MISSING_SUBPATTERN_NAME_TERMINATOR: Missing terminator + *     in subpattern name. Since 2.16 + * @G_REGEX_ERROR_DUPLICATE_SUBPATTERN_NAME: Two named subpatterns have + *     the same name. Since 2.16 + * @G_REGEX_ERROR_MALFORMED_PROPERTY: Malformed "\\P" or "\\p" sequence. + *     Since 2.16 + * @G_REGEX_ERROR_UNKNOWN_PROPERTY: Unknown property name after "\\P" or + *     "\\p". Since 2.16 + * @G_REGEX_ERROR_SUBPATTERN_NAME_TOO_LONG: Subpattern name is too long + *     (maximum 32 characters). Since 2.16 + * @G_REGEX_ERROR_TOO_MANY_SUBPATTERNS: Too many named subpatterns (maximum + *     10,000). Since 2.16 + * @G_REGEX_ERROR_INVALID_OCTAL_VALUE: Octal value is greater than "\\377". + *     Since 2.16 + * @G_REGEX_ERROR_TOO_MANY_BRANCHES_IN_DEFINE: "DEFINE" group contains more + *     than one branch. Since 2.16 + * @G_REGEX_ERROR_DEFINE_REPETION: Repeating a "DEFINE" group is not allowed. + *     Since 2.16 + * @G_REGEX_ERROR_INCONSISTENT_NEWLINE_OPTIONS: Inconsistent newline options. + *     Since 2.16 + * @G_REGEX_ERROR_MISSING_BACK_REFERENCE: "\\g" is not followed by a braced + *     name or an optionally braced non-zero number. Since 2.16 + * + * Error codes returned by regular expressions functions. + * + * Since: 2.14 + */ +typedef enum +{ +  G_REGEX_ERROR_COMPILE, +  G_REGEX_ERROR_OPTIMIZE, +  G_REGEX_ERROR_REPLACE, +  G_REGEX_ERROR_MATCH, +  G_REGEX_ERROR_INTERNAL, + +  /* These are the error codes from PCRE + 100 */ +  G_REGEX_ERROR_STRAY_BACKSLASH = 101, +  G_REGEX_ERROR_MISSING_CONTROL_CHAR = 102, +  G_REGEX_ERROR_UNRECOGNIZED_ESCAPE = 103, +  G_REGEX_ERROR_QUANTIFIERS_OUT_OF_ORDER = 104, +  G_REGEX_ERROR_QUANTIFIER_TOO_BIG = 105, +  G_REGEX_ERROR_UNTERMINATED_CHARACTER_CLASS = 106, +  G_REGEX_ERROR_INVALID_ESCAPE_IN_CHARACTER_CLASS = 107, +  G_REGEX_ERROR_RANGE_OUT_OF_ORDER = 108, +  G_REGEX_ERROR_NOTHING_TO_REPEAT = 109, +  G_REGEX_ERROR_UNRECOGNIZED_CHARACTER = 112, +  G_REGEX_ERROR_POSIX_NAMED_CLASS_OUTSIDE_CLASS = 113, +  G_REGEX_ERROR_UNMATCHED_PARENTHESIS = 114, +  G_REGEX_ERROR_INEXISTENT_SUBPATTERN_REFERENCE = 115, +  G_REGEX_ERROR_UNTERMINATED_COMMENT = 118, +  G_REGEX_ERROR_EXPRESSION_TOO_LARGE = 120, +  G_REGEX_ERROR_MEMORY_ERROR = 121, +  G_REGEX_ERROR_VARIABLE_LENGTH_LOOKBEHIND = 125, +  G_REGEX_ERROR_MALFORMED_CONDITION = 126, +  G_REGEX_ERROR_TOO_MANY_CONDITIONAL_BRANCHES = 127, +  G_REGEX_ERROR_ASSERTION_EXPECTED = 128, +  G_REGEX_ERROR_UNKNOWN_POSIX_CLASS_NAME = 130, +  G_REGEX_ERROR_POSIX_COLLATING_ELEMENTS_NOT_SUPPORTED = 131, +  G_REGEX_ERROR_HEX_CODE_TOO_LARGE = 134, +  G_REGEX_ERROR_INVALID_CONDITION = 135, +  G_REGEX_ERROR_SINGLE_BYTE_MATCH_IN_LOOKBEHIND = 136, +  G_REGEX_ERROR_INFINITE_LOOP = 140, +  G_REGEX_ERROR_MISSING_SUBPATTERN_NAME_TERMINATOR = 142, +  G_REGEX_ERROR_DUPLICATE_SUBPATTERN_NAME = 143, +  G_REGEX_ERROR_MALFORMED_PROPERTY = 146, +  G_REGEX_ERROR_UNKNOWN_PROPERTY = 147, +  G_REGEX_ERROR_SUBPATTERN_NAME_TOO_LONG = 148, +  G_REGEX_ERROR_TOO_MANY_SUBPATTERNS = 149, +  G_REGEX_ERROR_INVALID_OCTAL_VALUE = 151, +  G_REGEX_ERROR_TOO_MANY_BRANCHES_IN_DEFINE = 154, +  G_REGEX_ERROR_DEFINE_REPETION = 155, +  G_REGEX_ERROR_INCONSISTENT_NEWLINE_OPTIONS = 156, +  G_REGEX_ERROR_MISSING_BACK_REFERENCE = 157 +} GRegexError; + +/** + * G_REGEX_ERROR: + * + * Error domain for regular expressions. Errors in this domain will be + * from the #GRegexError enumeration. See #GError for information on + * error domains. + * + * Since: 2.14 + */ +#define G_REGEX_ERROR g_regex_error_quark () + +GQuark g_regex_error_quark (void); + +/** + * GRegexCompileFlags: + * @G_REGEX_CASELESS: Letters in the pattern match both upper- and + *     lowercase letters. This option can be changed within a pattern + *     by a "(?i)" option setting. + * @G_REGEX_MULTILINE: By default, GRegex treats the strings as consisting + *     of a single line of characters (even if it actually contains + *     newlines). The "start of line" metacharacter ("^") matches only + *     at the start of the string, while the "end of line" metacharacter + *     ("$") matches only at the end of the string, or before a terminating + *     newline (unless #G_REGEX_DOLLAR_ENDONLY is set). When + *     #G_REGEX_MULTILINE is set, the "start of line" and "end of line" + *     constructs match immediately following or immediately before any + *     newline in the string, respectively, as well as at the very start + *     and end. This can be changed within a pattern by a "(?m)" option + *     setting. + * @G_REGEX_DOTALL: A dot metacharater (".") in the pattern matches all + *     characters, including newlines. Without it, newlines are excluded. + *     This option can be changed within a pattern by a ("?s") option setting. + * @G_REGEX_EXTENDED: Whitespace data characters in the pattern are + *     totally ignored except when escaped or inside a character class. + *     Whitespace does not include the VT character (code 11). In addition, + *     characters between an unescaped "#" outside a character class and + *     the next newline character, inclusive, are also ignored. This can + *     be changed within a pattern by a "(?x)" option setting. + * @G_REGEX_ANCHORED: The pattern is forced to be "anchored", that is, + *     it is constrained to match only at the first matching point in the + *     string that is being searched. This effect can also be achieved by + *     appropriate constructs in the pattern itself such as the "^" + *     metacharater. + * @G_REGEX_DOLLAR_ENDONLY: A dollar metacharacter ("$") in the pattern + *     matches only at the end of the string. Without this option, a + *     dollar also matches immediately before the final character if + *     it is a newline (but not before any other newlines). This option + *     is ignored if #G_REGEX_MULTILINE is set. + * @G_REGEX_UNGREEDY: Inverts the "greediness" of the quantifiers so that + *     they are not greedy by default, but become greedy if followed by "?". + *     It can also be set by a "(?U)" option setting within the pattern. + * @G_REGEX_RAW: Usually strings must be valid UTF-8 strings, using this + *     flag they are considered as a raw sequence of bytes. + *     @G_REGEX_NO_AUTO_CAPTURE: Disables the use of numbered capturing + *     parentheses in the pattern. Any opening parenthesis that is not + *     followed by "?" behaves as if it were followed by "?:" but named + *     parentheses can still be used for capturing (and they acquire numbers + *     in the usual way). + * @G_REGEX_OPTIMIZE: Optimize the regular expression. If the pattern will + *     be used many times, then it may be worth the effort to optimize it + *     to improve the speed of matches. + * @G_REGEX_DUPNAMES: Names used to identify capturing subpatterns need not + *     be unique. This can be helpful for certain types of pattern when it + *     is known that only one instance of the named subpattern can ever be + *     matched. + * @G_REGEX_NEWLINE_CR: Usually any newline character is recognized, if this + *     option is set, the only recognized newline character is '\r'. + * @G_REGEX_NEWLINE_LF: Usually any newline character is recognized, if this + *     option is set, the only recognized newline character is '\n'. + * @G_REGEX_NEWLINE_CRLF: Usually any newline character is recognized, if this + *     option is set, the only recognized newline character sequence is '\r\n'. + * + * Flags specifying compile-time options. + * + * Since: 2.14 + */ +/* Remember to update G_REGEX_COMPILE_MASK in gregex.c after + * adding a new flag. */ +typedef enum +{ +  G_REGEX_CASELESS          = 1 << 0, +  G_REGEX_MULTILINE         = 1 << 1, +  G_REGEX_DOTALL            = 1 << 2, +  G_REGEX_EXTENDED          = 1 << 3, +  G_REGEX_ANCHORED          = 1 << 4, +  G_REGEX_DOLLAR_ENDONLY    = 1 << 5, +  G_REGEX_UNGREEDY          = 1 << 9, +  G_REGEX_RAW               = 1 << 11, +  G_REGEX_NO_AUTO_CAPTURE   = 1 << 12, +  G_REGEX_OPTIMIZE          = 1 << 13, +  G_REGEX_DUPNAMES          = 1 << 19, +  G_REGEX_NEWLINE_CR        = 1 << 20, +  G_REGEX_NEWLINE_LF        = 1 << 21, +  G_REGEX_NEWLINE_CRLF      = G_REGEX_NEWLINE_CR | G_REGEX_NEWLINE_LF +} GRegexCompileFlags; + +/** + * GRegexMatchFlags: + * @G_REGEX_MATCH_ANCHORED: The pattern is forced to be "anchored", that is, + *     it is constrained to match only at the first matching point in the + *     string that is being searched. This effect can also be achieved by + *     appropriate constructs in the pattern itself such as the "^" + *     metacharater. + * @G_REGEX_MATCH_NOTBOL: Specifies that first character of the string is + *     not the beginning of a line, so the circumflex metacharacter should + *     not match before it. Setting this without #G_REGEX_MULTILINE (at + *     compile time) causes circumflex never to match. This option affects + *     only the behaviour of the circumflex metacharacter, it does not + *     affect "\A". + * @G_REGEX_MATCH_NOTEOL: Specifies that the end of the subject string is + *     not the end of a line, so the dollar metacharacter should not match + *     it nor (except in multiline mode) a newline immediately before it. + *     Setting this without #G_REGEX_MULTILINE (at compile time) causes + *     dollar never to match. This option affects only the behaviour of + *     the dollar metacharacter, it does not affect "\Z" or "\z". + * @G_REGEX_MATCH_NOTEMPTY: An empty string is not considered to be a valid + *     match if this option is set. If there are alternatives in the pattern, + *     they are tried. If all the alternatives match the empty string, the + *     entire match fails. For example, if the pattern "a?b?" is applied to + *     a string not beginning with "a" or "b", it matches the empty string + *     at the start of the string. With this flag set, this match is not + *     valid, so GRegex searches further into the string for occurrences + *     of "a" or "b". + * @G_REGEX_MATCH_PARTIAL: Turns on the partial matching feature, for more + *     documentation on partial matching see g_match_info_is_partial_match(). + * @G_REGEX_MATCH_NEWLINE_CR: Overrides the newline definition set when + *     creating a new #GRegex, setting the '\r' character as line terminator. + * @G_REGEX_MATCH_NEWLINE_LF: Overrides the newline definition set when + *     creating a new #GRegex, setting the '\n' character as line terminator. + * @G_REGEX_MATCH_NEWLINE_CRLF: Overrides the newline definition set when + *     creating a new #GRegex, setting the '\r\n' characters as line terminator. + * @G_REGEX_MATCH_NEWLINE_ANY: Overrides the newline definition set when + *     creating a new #GRegex, any newline character or character sequence + *     is recognized. + * + * Flags specifying match-time options. + * + * Since: 2.14 + */ +/* Remember to update G_REGEX_MATCH_MASK in gregex.c after + * adding a new flag. */ +typedef enum +{ +  G_REGEX_MATCH_ANCHORED      = 1 << 4, +  G_REGEX_MATCH_NOTBOL        = 1 << 7, +  G_REGEX_MATCH_NOTEOL        = 1 << 8, +  G_REGEX_MATCH_NOTEMPTY      = 1 << 10, +  G_REGEX_MATCH_PARTIAL       = 1 << 15, +  G_REGEX_MATCH_NEWLINE_CR    = 1 << 20, +  G_REGEX_MATCH_NEWLINE_LF    = 1 << 21, +  G_REGEX_MATCH_NEWLINE_CRLF  = G_REGEX_MATCH_NEWLINE_CR | G_REGEX_MATCH_NEWLINE_LF, +  G_REGEX_MATCH_NEWLINE_ANY   = 1 << 22 +} GRegexMatchFlags; + +/** + * GRegex: + * + * A GRegex is the "compiled" form of a regular expression pattern. This + * structure is opaque and its fields cannot be accessed directly. + * + * Since: 2.14 + */ +typedef struct _GRegex		GRegex; + + +typedef struct _GMatchInfo	GMatchInfo; + +/** + * GRegexEvalCallback: + * @match_info: the #GMatchInfo generated by the match. + *     Use g_match_info_get_regex() and g_match_info_get_string() if you + *     need the #GRegex or the matched string. + * @result: a #GString containing the new string + * @user_data: user data passed to g_regex_replace_eval() + * + * Specifies the type of the function passed to g_regex_replace_eval(). + * It is called for each occurance of the pattern in the string passed + * to g_regex_replace_eval(), and it should append the replacement to + * @result. + * + * Returns: %FALSE to continue the replacement process, %TRUE to stop it + * + * Since: 2.14 + */ +typedef gboolean (*GRegexEvalCallback)		(const GMatchInfo *match_info, +						 GString          *result, +						 gpointer          user_data); + + +GRegex		 *g_regex_new			(const gchar         *pattern, +						 GRegexCompileFlags   compile_options, +						 GRegexMatchFlags     match_options, +						 GError             **error); +GRegex           *g_regex_ref			(GRegex              *regex); +void		  g_regex_unref			(GRegex              *regex); +const gchar	 *g_regex_get_pattern		(const GRegex        *regex); +gint		  g_regex_get_max_backref	(const GRegex        *regex); +gint		  g_regex_get_capture_count	(const GRegex        *regex); +gint		  g_regex_get_string_number	(const GRegex        *regex,  +						 const gchar         *name); +gchar		 *g_regex_escape_string		(const gchar         *string, +						 gint                 length); + +GRegexCompileFlags g_regex_get_compile_flags    (const GRegex        *regex); +GRegexMatchFlags   g_regex_get_match_flags      (const GRegex        *regex); + +/* Matching. */ +gboolean	  g_regex_match_simple		(const gchar         *pattern, +						 const gchar         *string, +						 GRegexCompileFlags   compile_options, +						 GRegexMatchFlags     match_options); +gboolean	  g_regex_match			(const GRegex        *regex, +						 const gchar         *string, +						 GRegexMatchFlags     match_options, +						 GMatchInfo         **match_info); +gboolean	  g_regex_match_full		(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 GRegexMatchFlags     match_options, +						 GMatchInfo         **match_info, +						 GError             **error); +gboolean	  g_regex_match_all		(const GRegex        *regex, +						 const gchar         *string, +						 GRegexMatchFlags     match_options, +						 GMatchInfo         **match_info); +gboolean	  g_regex_match_all_full	(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 GRegexMatchFlags     match_options, +						 GMatchInfo         **match_info, +						 GError             **error); + +/* String splitting. */ +gchar		**g_regex_split_simple		(const gchar         *pattern, +						 const gchar         *string, +						 GRegexCompileFlags   compile_options, +						 GRegexMatchFlags     match_options); +gchar		**g_regex_split			(const GRegex        *regex, +						 const gchar         *string, +						 GRegexMatchFlags     match_options); +gchar		**g_regex_split_full		(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 GRegexMatchFlags     match_options, +						 gint                 max_tokens, +						 GError             **error); + +/* String replacement. */ +gchar		 *g_regex_replace		(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 const gchar         *replacement, +						 GRegexMatchFlags     match_options, +						 GError             **error); +gchar		 *g_regex_replace_literal	(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 const gchar         *replacement, +						 GRegexMatchFlags     match_options, +						 GError             **error); +gchar		 *g_regex_replace_eval		(const GRegex        *regex, +						 const gchar         *string, +						 gssize               string_len, +						 gint                 start_position, +						 GRegexMatchFlags     match_options, +						 GRegexEvalCallback   eval, +						 gpointer             user_data, +						 GError             **error); +gboolean	  g_regex_check_replacement	(const gchar         *replacement, +						 gboolean            *has_references, +						 GError             **error); + +/* Match info */ +GRegex		 *g_match_info_get_regex	(const GMatchInfo    *match_info); +const gchar      *g_match_info_get_string       (const GMatchInfo    *match_info); + +void		  g_match_info_free		(GMatchInfo          *match_info); +gboolean	  g_match_info_next		(GMatchInfo          *match_info, +						 GError             **error); +gboolean	  g_match_info_matches		(const GMatchInfo    *match_info); +gint		  g_match_info_get_match_count	(const GMatchInfo    *match_info); +gboolean	  g_match_info_is_partial_match	(const GMatchInfo    *match_info); +gchar		 *g_match_info_expand_references(const GMatchInfo    *match_info, +						 const gchar         *string_to_expand, +						 GError             **error); +gchar		 *g_match_info_fetch		(const GMatchInfo    *match_info, +						 gint                 match_num); +gboolean	  g_match_info_fetch_pos	(const GMatchInfo    *match_info, +						 gint                 match_num, +						 gint                *start_pos, +						 gint                *end_pos); +gchar		 *g_match_info_fetch_named	(const GMatchInfo    *match_info, +						 const gchar         *name); +gboolean	  g_match_info_fetch_named_pos	(const GMatchInfo    *match_info, +						 const gchar         *name, +						 gint                *start_pos, +						 gint                *end_pos); +gchar		**g_match_info_fetch_all	(const GMatchInfo    *match_info); + +G_END_DECLS + +#endif  /*  __G_REGEX_H__ */  | 
