2001-10-19 14:36:57 +00:00
/*
2004-03-30 19:35:44 +00:00
* Copyright ( C ) 2001 - 2004 Sistina Software , Inc . All rights reserved .
* Copyright ( C ) 2004 Red Hat , Inc . All rights reserved .
2001-10-19 14:36:57 +00:00
*
2004-03-30 19:35:44 +00:00
* This file is part of LVM2 .
*
* This copyrighted material is made available to anyone wishing to use ,
* modify , copy , or redistribute it subject to the terms and conditions
* of the GNU General Public License v .2 .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software Foundation ,
* Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
2001-10-19 14:36:57 +00:00
*/
# ifndef _LVM_PARSE_REGEX_H
# define _LVM_PARSE_REGEX_H
enum {
CAT ,
STAR ,
PLUS ,
OR ,
QUEST ,
2002-08-29 14:46:30 +00:00
CHARSET
2001-10-19 14:36:57 +00:00
} ;
2002-08-29 14:46:30 +00:00
/*
* We ' re never going to be running the regex on non - printable
* chars , so we can use a couple of these chars to represent the
* start and end of a string .
*/
# define HAT_CHAR 0x2
2003-02-20 14:53:56 +00:00
# define DOLLAR_CHAR 0x3
2002-08-29 14:46:30 +00:00
2001-10-19 14:36:57 +00:00
struct rx_node {
int type ;
2005-10-16 23:03:59 +00:00
dm_bitset_t charset ;
2001-10-19 14:36:57 +00:00
struct rx_node * left , * right ;
/* used to build the dfa for the toker */
int nullable , final ;
2005-10-16 23:03:59 +00:00
dm_bitset_t firstpos ;
dm_bitset_t lastpos ;
dm_bitset_t followpos ;
2001-10-19 14:36:57 +00:00
} ;
2005-10-16 23:03:59 +00:00
struct rx_node * rx_parse_str ( struct dm_pool * mem , const char * str ) ;
struct rx_node * rx_parse_tok ( struct dm_pool * mem ,
2001-10-19 14:36:57 +00:00
const char * begin , const char * end ) ;
# endif