繁体   English   中英

正则表达式解析C ++枚举

[英]Regex to parse C++ enum

如何构造正则表达式来解析C ++枚举? 我试过的枚举看起来像

enum Temperature
{
    C = 0,
    F=1,     // some elements are commented
    R,       // most elements are not gived a value
    K        // sometimes the last element is succeeded by a comma
} temperature;

// different indent style is used
enum Depth {
    m = 0,
    ft = 1,
} depth;

我尝试了几个简单的模式,但没有一个足以捕捉上述所有情况。

任何可以帮助我的regexp向导?

编辑:澄清,我想要名称和价值,例如C和0。

这很有挑战性:)下面是我能想到的最好的。 假设只给出{和}之间的文本,它会捕获所有名称和相应的值:

/(\w+)\s*(?:=\s*(\d+)|)\s*,?\s*(?:(?:\n|$)|\/\/.*?(?:\n|$)|)/

如果我们使用正则表达式匹配枚举而不是用它来解析枚举。 我认为这是可能的。 尝试这些步骤:

第1步。 确保C / C ++源代码可以编译成功。
第2步。 从C / C ++源代码中删除所有注释。
第3步。 匹配枚举

一个可行的Ruby示例代码:

# copy from Mastering Regular Expression 3rd
COMMENT = '/\*[^\*]*\*+(?:[^/*][^*]*\*+)*/'
COMMENT2 = '//[^\n]+'
DOUBLE = '"(?:\\.|[^\\"])*"'
SINGLE = '\'(?:\\.|[^\\\'])*\''
# pattern for match enum
ENUM = '\benum\s*(\w+)\s*\{(\s*\w+(?:\s*=\s*\w+)?(?:\s*,\s*\w+(?:\s*=\s*\w+)?)*)\s*(?:,\s*)?\}\s*\w+\s*;'

foo = File.open("foo.cpp", "r").read()
# strip all comments from foo.cpp
foo.gsub!(/(#{DOUBLE}|#{SINGLE})|#{COMMENT}|#{COMMENT2}/, '\1')
bar = []
# match enum...
foo.scan(/#{ENUM}/) do | m |
    printf("%s: %s\n", m[0], m[1].gsub(/\s/, ''))

end

输出:

Temperature: C=0,F=1,R,K
Depth: m=0,ft=1

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM