/** * @author Edouard DUPIN * * @copyright 2011, Edouard DUPIN, all right reserved * * @license MPL v2.0 (see license file) */ #include #include #include #define NAME "Hash" etk::Pair testRegExSingle(const etk::String& _expression, const etk::String& _search) { etk::RegEx expression(_expression); TK_INFO("Parse RegEx: \"" << expression.getRegExDecorated() << "\""); TK_INFO(" IN: \"" << etk::regex::autoStr(_search) << "\""); if (expression.parse(_search, 0, _search.size()) == true) { TK_INFO(" match [" << expression.start() << ".." << expression.stop() << "] "); TK_INFO(" ==> '" << etk::regex::autoStr(etk::String(_search, expression.start(), expression.stop() - expression.start())) << "'"); return etk::makePair(expression.start(), expression.stop()); } TK_INFO(" ==> ---------------"); return etk::makePair(0,0); } static etk::String data1 = " a /* plop */ \n int eee = 22; // error value \nint main(void) {\n return 0;\n}\n"; static etk::String data2 = "alpha /* plop */ test"; static etk::String data3 = "pp \n // qdfqdfsdf \nde"; TEST(TestEtkRegEx, MultipleLineComment ) { etk::String expression = "/\\*.*\\*/"; etk::Pair res; res = testRegExSingle(expression, data1); EXPECT_EQ(res, etk::makePair(3,13)); res = testRegExSingle(expression, data2); EXPECT_EQ(res, etk::makePair(6,16)); res = testRegExSingle(expression, data3); EXPECT_EQ(res, etk::makePair(0,0)); } TEST(TestEtkRegEx, MultipleEndDollar ) { etk::String expression = "//.*$"; etk::Pair res; res = testRegExSingle(expression, data1); EXPECT_EQ(res, etk::makePair(30,46)); res = testRegExSingle(expression, data2); EXPECT_EQ(res, etk::makePair(0,0)); res = testRegExSingle(expression, data3); EXPECT_EQ(res, etk::makePair(5,19)); } TEST(TestEtkRegEx, MultipleNoEnd ) { etk::String expression = "/\\*.*"; etk::Pair res; res = testRegExSingle(expression, data1); EXPECT_EQ(res, etk::makePair(3,5)); res = testRegExSingle(expression, data2); EXPECT_EQ(res, etk::makePair(6,8)); res = testRegExSingle(expression, data3); EXPECT_EQ(res, etk::makePair(0,0)); } TEST(TestEtkRegEx, aToZ ) { etk::String expression = "[a-z]"; etk::Pair res; res = testRegExSingle(expression, data1); EXPECT_EQ(res, etk::makePair(1,2)); res = testRegExSingle(expression, data2); EXPECT_EQ(res, etk::makePair(0,1)); res = testRegExSingle(expression, data3); EXPECT_EQ(res, etk::makePair(0,1)); } TEST(TestEtkRegEx, complexString ) { etk::String expression = "a.*plop(z{2,3}|h+)+r"; etk::String dataToParse = " eesd a lzzml plophzzzzzhhhhhrlkmlkml"; etk::Pair res; res = testRegExSingle(expression, dataToParse); EXPECT_EQ(res, etk::makePair(7,31)); } TEST(TestEtkRegEx, multipleUnderscore ) { etk::String expression = "\\@\\w+_\\@"; etk::String dataToParse = " aaa_bbb_ plop_ "; etk::Pair res; res = testRegExSingle(expression, dataToParse); EXPECT_EQ(res, etk::makePair(2,10)); } TEST(TestEtkRegEx, endError ) { etk::String expression = "\\@((0(x|X)[0-9a-fA-F]*)|(\\d+\\.?\\d*|\\.\\d+)((e|E)(\\+|\\-)?\\d+)?)(LL|L|l|UL|ul|u|U|F|f)?\\@"; etk::String dataToParse = "(95"; etk::Pair res; res = testRegExSingle(expression, dataToParse); EXPECT_EQ(res, etk::makePair(7,31)); } void testRegEx() { etk::String data; //etk::String data = "pp \n# plop // qdfqdfsdf \nde"; //etk::String data = "pp \n# plop //\\\n qdfqdfsdf \nde"; //etk::String data = "p#\ne"; //testRegExSingle("#(\\\\\\\\|\\\\\\n|.)*$", data); //testRegExSingle("#.*$", data); //etk::String data = "p//TODO:\ndse"; //etk::String data = "p// TODO:\ndse"; //etk::String data = "p// TODO :\ndse"; //etk::String data = "p// TODO : sdfgsdfsd \ndse"; //testRegExSingle("//[ \\t]*TODO[ \\t]*:.*$", data); data = "abc m_def ghi"; data = " protected:\n" " vec2 m_offset; \n"; //testRegExSingle("\\@m_[A-Za-z_0-9]*\\@", data); data = " * @param[in] _mode Configuring mode.\n" " * @param[in] _time Time in second of the annimation display\n" " */\n" " void setAnnimationTime(enum "; data = "virtual vec2 relativePosition(const vec2& _pos);"; //testRegExSingle("\\@(\\w|_)+[ \\t]*\\(", data); data = "include \n" "#include \n" "'dfgd\'fg'\n" "\"dqf\\\"gsdfg\" // \"\n" "// TODO : sqdkfjsdldkqfj\n" "\n" "namespace ewol {\n" " class Widget;\n" " namespace widget {\n" " class Manager;\n" " class Windows;\n" " };\n" "};\n" "#include \n"; //testRegExSingle("#(\\\\[\\\\\\n]|.)*$", data); data = " 'dfgd\\'fg' \n" " vec2 m_offset; \n"; //testRegExSingle("'((\\\\[\\\\'])|.)*'", data); /* data = "ddfgdfgh"; etk::RegEx reg(".*"); reg.setMaximize(true); TK_INFO("Parse RegEx : '" << reg.getRegExDecorated() << "'"); if (reg.parse(data, 0, data.size()) == true) { //if (reg.processOneElement(data, 0, data.size()) == true) { TK_INFO(" match [" << reg.start() << ".." << reg.stop() << "] "); TK_INFO(" ==> '" << etk::String(data, reg.start(), reg.stop()-reg.start()) << "'"); } data = "plop \"\" sdfsdf s\"swdfsqd sdfgsdfg \" \" sdfsf"; reg = etk::RegEx("\"(\\\\[\\\\\"]|.)*\""); reg.setMaximize(false); TK_INFO("Parse RegEx : '" << reg.getRegExDecorated() << "'"); if (reg.parse(data, 0, data.size()) == true) { //if (reg.processOneElement(data, 0, data.size()) == true) { TK_INFO(" match [" << reg.start() << ".." << reg.stop() << "] "); TK_INFO(" ==> '" << etk::String(data, reg.start(), reg.stop()-reg.start()) << "'"); } //TODO : good : "(\\+|[0-9])*" ==> really bad : "(+|[0-9])*" data = "void limit(const vec2& _origin, const vec2& _size);\n"; reg = etk::RegEx("\\@(\\w|_)+[ \\t]*\\("); reg.setMaximize(false); TK_INFO("Parse RegEx : '" << reg.getRegExDecorated() << "'"); if (reg.parse(data, 0, data.size()) == true) { //if (reg.processOneElement(data, 0, data.size()) == true) { TK_INFO(" match [" << reg.start() << ".." << reg.stop() << "] "); TK_INFO(" ==> '" << etk::String(data, reg.start(), reg.stop()-reg.start()) << "'"); } data = "void limit const vec2& _origin, const vec2& _size);\n"; if (reg.parse(data, 0, data.size()) == true) { //if (reg.processOneElement(data, 0, data.size()) == true) { TK_INFO(" match [" << reg.start() << ".." << reg.stop() << "] "); TK_INFO(" ==> '" << etk::String(data, reg.start(), reg.stop()-reg.start()) << "'"); } */ }