You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-08 12:40:44 +00:00
Made RegEx API similar to old version
This commit is contained in:
@@ -464,8 +464,8 @@ bool test_26() {
|
|||||||
OS::get_singleton()->print("\n\nTest 26: RegEx\n");
|
OS::get_singleton()->print("\n\nTest 26: RegEx\n");
|
||||||
RegEx regexp("(.*):(.*)");
|
RegEx regexp("(.*):(.*)");
|
||||||
|
|
||||||
bool res = regexp.match("name:password");
|
int res = regexp.find("name:password");
|
||||||
printf("\tmatch: %s\n", res?"true":"false");
|
printf("\tmatch: %s\n", (res>=0)?"true":"false");
|
||||||
|
|
||||||
printf("\t%i captures:\n", regexp.get_capture_count());
|
printf("\t%i captures:\n", regexp.get_capture_count());
|
||||||
for (int i = 0; i<regexp.get_capture_count(); i++)
|
for (int i = 0; i<regexp.get_capture_count(); i++)
|
||||||
|
|||||||
@@ -8,11 +8,11 @@ func update_expression():
|
|||||||
|
|
||||||
func update_text():
|
func update_text():
|
||||||
var text = get_node("Text").get_text()
|
var text = get_node("Text").get_text()
|
||||||
regex.match(text)
|
regex.find(text)
|
||||||
var list = get_node("List")
|
var list = get_node("List")
|
||||||
for child in list.get_children():
|
for child in list.get_children():
|
||||||
child.queue_free()
|
child.queue_free()
|
||||||
for res in regex.get_capture_list():
|
for res in regex.get_captures():
|
||||||
var label = Label.new()
|
var label = Label.new()
|
||||||
label.set_text(res)
|
label.set_text(res)
|
||||||
list.add_child(label)
|
list.add_child(label)
|
||||||
|
|||||||
Binary file not shown.
@@ -16,13 +16,16 @@
|
|||||||
void RegEx::_bind_methods() {
|
void RegEx::_bind_methods() {
|
||||||
|
|
||||||
ObjectTypeDB::bind_method(_MD("compile","pattern"),&RegEx::compile);
|
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","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;
|
StringArray ret;
|
||||||
int count = get_capture_count();
|
int count = get_capture_count();
|
||||||
@@ -77,8 +80,7 @@ Error RegEx::compile(const String& p_pattern) {
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
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( !exp.valid(), false );
|
||||||
ERR_FAIL_COND_V( p_text.length() < p_start, false );
|
ERR_FAIL_COND_V( p_text.length() < p_start, false );
|
||||||
@@ -88,10 +90,10 @@ bool RegEx::match(const String& p_text, int p_start, int p_end) const {
|
|||||||
|
|
||||||
if (res) {
|
if (res) {
|
||||||
text = p_text;
|
text = p_text;
|
||||||
return true;
|
return captures[0].start;
|
||||||
}
|
}
|
||||||
text.clear();
|
text.clear();
|
||||||
return false;
|
return -1;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ class RegEx : public Reference {
|
|||||||
protected:
|
protected:
|
||||||
|
|
||||||
static void _bind_methods();
|
static void _bind_methods();
|
||||||
StringArray _bind_get_capture_list() const;
|
StringArray _bind_get_captures() const;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@@ -37,7 +37,7 @@ public:
|
|||||||
int get_capture_count() const;
|
int get_capture_count() const;
|
||||||
String get_capture(int capture) const;
|
String get_capture(int capture) const;
|
||||||
Error compile(const String& p_pattern);
|
Error compile(const String& p_pattern);
|
||||||
bool match(const String& p_text, int p_start = 0, int p_end = -1) const;
|
int find(const String& p_text, int p_start = 0, int p_end = -1) const;
|
||||||
|
|
||||||
RegEx();
|
RegEx();
|
||||||
RegEx(const String& p_pattern);
|
RegEx(const String& p_pattern);
|
||||||
|
|||||||
Reference in New Issue
Block a user