regex: Convert statics to constants

This require a bit of finesse to work around the changes with libunicode, but
nothing too major!
This commit is contained in:
Alex Crichton 2014-10-06 16:32:48 -07:00
parent abb1b2a309
commit a64bb6623c
3 changed files with 39 additions and 24 deletions

View File

@ -162,12 +162,12 @@ impl BuildAst {
/// expression.
pub type Flags = u8;
pub static FLAG_EMPTY: u8 = 0;
pub static FLAG_NOCASE: u8 = 1 << 0; // i
pub static FLAG_MULTI: u8 = 1 << 1; // m
pub static FLAG_DOTNL: u8 = 1 << 2; // s
pub static FLAG_SWAP_GREED: u8 = 1 << 3; // U
pub static FLAG_NEGATED: u8 = 1 << 4; // char class or not word boundary
pub const FLAG_EMPTY: u8 = 0;
pub const FLAG_NOCASE: u8 = 1 << 0; // i
pub const FLAG_MULTI: u8 = 1 << 1; // m
pub const FLAG_DOTNL: u8 = 1 << 2; // s
pub const FLAG_SWAP_GREED: u8 = 1 << 3; // U
pub const FLAG_NEGATED: u8 = 1 << 4; // char class or not word boundary
struct Parser<'a> {
// The input, parsed only as a sequence of UTF8 code points.
@ -1025,7 +1025,7 @@ fn find_class(classes: NamedClasses, name: &str) -> Option<Vec<(char, char)>> {
}
type Class = &'static [(char, char)];
type NamedClasses = &'static [(&'static str, Class)];
type NamedClasses = &'static [(&'static str, &'static Class)];
static ASCII_CLASSES: NamedClasses = &[
// Classes must be in alphabetical order so that bsearch works.
@ -1044,19 +1044,34 @@ static ASCII_CLASSES: NamedClasses = &[
// [:word:] word characters (== [0-9A-Za-z_])
// [:xdigit:] hex digit (== [0-9A-Fa-f])
// Taken from: http://golang.org/pkg/regex/syntax/
("alnum", &[('0', '9'), ('A', 'Z'), ('a', 'z')]),
("alpha", &[('A', 'Z'), ('a', 'z')]),
("ascii", &[('\x00', '\x7F')]),
("blank", &[(' ', ' '), ('\t', '\t')]),
("cntrl", &[('\x00', '\x1F'), ('\x7F', '\x7F')]),
("digit", &[('0', '9')]),
("graph", &[('!', '~')]),
("lower", &[('a', 'z')]),
("print", &[(' ', '~')]),
("punct", &[('!', '/'), (':', '@'), ('[', '`'), ('{', '~')]),
("space", &[('\t', '\t'), ('\n', '\n'), ('\x0B', '\x0B'), ('\x0C', '\x0C'),
('\r', '\r'), (' ', ' ')]),
("upper", &[('A', 'Z')]),
("word", &[('0', '9'), ('A', 'Z'), ('a', 'z'), ('_', '_')]),
("xdigit", &[('0', '9'), ('A', 'F'), ('a', 'f')]),
("alnum", &ALNUM),
("alpha", &ALPHA),
("ascii", &ASCII),
("blank", &BLANK),
("cntrl", &CNTRL),
("digit", &DIGIT),
("graph", &GRAPH),
("lower", &LOWER),
("print", &PRINT),
("punct", &PUNCT),
("space", &SPACE),
("upper", &UPPER),
("word", &WORD),
("xdigit", &XDIGIT),
];
static ALNUM: Class = &[('0', '9'), ('A', 'Z'), ('a', 'z')];
static ALPHA: Class = &[('A', 'Z'), ('a', 'z')];
static ASCII: Class = &[('\x00', '\x7F')];
static BLANK: Class = &[(' ', ' '), ('\t', '\t')];
static CNTRL: Class = &[('\x00', '\x1F'), ('\x7F', '\x7F')];
static DIGIT: Class = &[('0', '9')];
static GRAPH: Class = &[('!', '~')];
static LOWER: Class = &[('a', 'z')];
static PRINT: Class = &[(' ', '~')];
static PUNCT: Class = &[('!', '/'), (':', '@'), ('[', '`'), ('{', '~')];
static SPACE: Class = &[('\t', '\t'), ('\n', '\n'), ('\x0B', '\x0B'),
('\x0C', '\x0C'), ('\r', '\r'), (' ', ' ')];
static UPPER: Class = &[('A', 'Z')];
static WORD: Class = &[('0', '9'), ('A', 'Z'), ('a', 'z'), ('_', '_')];
static XDIGIT: Class = &[('0', '9'), ('A', 'F'), ('a', 'f')];

View File

@ -128,7 +128,7 @@ pub struct ExNative {
#[doc(hidden)]
pub original: &'static str,
#[doc(hidden)]
pub names: &'static [Option<&'static str>],
pub names: &'static &'static [Option<&'static str>],
#[doc(hidden)]
pub prog: fn(MatchKind, &str, uint, uint) -> Vec<Option<uint>>
}

View File

@ -324,7 +324,7 @@ fn exec<'t>(which: ::regex::native::MatchKind, input: &'t str,
::regex::native::Native(::regex::native::ExNative {
original: $regex,
names: CAP_NAMES,
names: &CAP_NAMES,
prog: exec,
})
})