summaryrefslogtreecommitdiff
path: root/drivers/nrex/regex.cpp
diff options
context:
space:
mode:
authorZher Huei Lee <lee.zh.92@gmail.com>2015-07-24 14:09:39 +0100
committerZher Huei Lee <lee.zh.92@gmail.com>2015-07-24 14:09:39 +0100
commit87c1e16834a21ac1e42321811cb0efcda4b91b9a (patch)
treec071b6446032791612d4dcf6814871e4c644e810 /drivers/nrex/regex.cpp
parent4ca0399ff6a16c7e5e760d57a7675df61f1f8ef0 (diff)
Made RegEx API similar to old version
Diffstat (limited to 'drivers/nrex/regex.cpp')
-rw-r--r--drivers/nrex/regex.cpp20
1 files changed, 11 insertions, 9 deletions
diff --git a/drivers/nrex/regex.cpp b/drivers/nrex/regex.cpp
index d7c12bd544..708e68cc26 100644
--- a/drivers/nrex/regex.cpp
+++ b/drivers/nrex/regex.cpp
@@ -16,13 +16,16 @@
void RegEx::_bind_methods() {
ObjectTypeDB::bind_method(_MD("compile","pattern"),&RegEx::compile);
- ObjectTypeDB::bind_method(_MD("match","text","start","end"),&RegEx::match, DEFVAL(0), DEFVAL(-1));
+ ObjectTypeDB::bind_method(_MD("find","text","start","end"),&RegEx::find, DEFVAL(0), DEFVAL(-1));
+ ObjectTypeDB::bind_method(_MD("clear"),&RegEx::clear);
+ ObjectTypeDB::bind_method(_MD("is_valid"),&RegEx::is_valid);
+ ObjectTypeDB::bind_method(_MD("get_capture_count"),&RegEx::get_capture_count);
ObjectTypeDB::bind_method(_MD("get_capture","capture"),&RegEx::get_capture);
- ObjectTypeDB::bind_method(_MD("get_capture_list"),&RegEx::_bind_get_capture_list);
+ ObjectTypeDB::bind_method(_MD("get_captures"),&RegEx::_bind_get_captures);
};
-StringArray RegEx::_bind_get_capture_list() const {
+StringArray RegEx::_bind_get_captures() const {
StringArray ret;
int count = get_capture_count();
@@ -64,22 +67,21 @@ String RegEx::get_capture(int capture) const {
}
Error RegEx::compile(const String& p_pattern) {
-
+
clear();
exp.compile(p_pattern.c_str());
ERR_FAIL_COND_V( !exp.valid(), FAILED );
-
+
captures.resize(exp.capture_size());
return OK;
};
-bool RegEx::match(const String& p_text, int p_start, int p_end) const {
+int RegEx::find(const String& p_text, int p_start, int p_end) const {
-
ERR_FAIL_COND_V( !exp.valid(), false );
ERR_FAIL_COND_V( p_text.length() < p_start, false );
ERR_FAIL_COND_V( p_text.length() < p_end, false );
@@ -88,10 +90,10 @@ bool RegEx::match(const String& p_text, int p_start, int p_end) const {
if (res) {
text = p_text;
- return true;
+ return captures[0].start;
}
text.clear();
- return false;
+ return -1;
};