Fixed too many little issues, check the issues closed today.

This commit is contained in:
Juan Linietsky 2014-09-21 01:43:42 -03:00
parent c5b905fca8
commit 11a5ed508b
24 changed files with 306 additions and 44 deletions

View File

@ -306,6 +306,16 @@ MainLoop *_OS::get_main_loop() const {
return OS::get_singleton()->get_main_loop(); return OS::get_singleton()->get_main_loop();
} }
void _OS::set_time_scale(float p_scale) {
OS::get_singleton()->set_time_scale(p_scale);
}
float _OS::get_time_scale() {
return OS::get_singleton()->get_time_scale();
}
/* /*
enum Weekday { enum Weekday {
DAY_SUNDAY, DAY_SUNDAY,
@ -613,6 +623,9 @@ void _OS::_bind_methods() {
ObjectTypeDB::bind_method(_MD("set_target_fps","target_fps"),&_OS::set_target_fps); ObjectTypeDB::bind_method(_MD("set_target_fps","target_fps"),&_OS::set_target_fps);
ObjectTypeDB::bind_method(_MD("get_target_fps"),&_OS::get_target_fps); ObjectTypeDB::bind_method(_MD("get_target_fps"),&_OS::get_target_fps);
ObjectTypeDB::bind_method(_MD("set_time_scale","time_scale"),&_OS::set_time_scale);
ObjectTypeDB::bind_method(_MD("get_time_scale"),&_OS::get_time_scale);
ObjectTypeDB::bind_method(_MD("has_touchscreen_ui_hint"),&_OS::has_touchscreen_ui_hint); ObjectTypeDB::bind_method(_MD("has_touchscreen_ui_hint"),&_OS::has_touchscreen_ui_hint);

View File

@ -201,6 +201,9 @@ public:
String get_data_dir() const; String get_data_dir() const;
void set_time_scale(float p_scale);
float get_time_scale();
static _OS *get_singleton() { return singleton; } static _OS *get_singleton() { return singleton; }
_OS(); _OS();

View File

@ -1505,10 +1505,12 @@ void Object::_bind_methods() {
BIND_VMETHOD( miget ); BIND_VMETHOD( miget );
MethodInfo plget("_get_property_list"); MethodInfo plget("_get_property_list");
plget.return_val.type=Variant::ARRAY; plget.return_val.type=Variant::ARRAY;
BIND_VMETHOD( plget ); BIND_VMETHOD( plget );
#endif #endif
BIND_VMETHOD( MethodInfo("_init") );

View File

@ -474,6 +474,16 @@ OS::MouseMode OS::get_mouse_mode() const{
return MOUSE_MODE_VISIBLE; return MOUSE_MODE_VISIBLE;
} }
void OS::set_time_scale(float p_scale) {
_time_scale=p_scale;
}
float OS::get_time_scale() const {
return _time_scale;
}
OS::OS() { OS::OS() {
last_error=NULL; last_error=NULL;
@ -489,6 +499,7 @@ OS::OS() {
_fps=1; _fps=1;
_target_fps=0; _target_fps=0;
_render_thread_mode=RENDER_THREAD_SAFE; _render_thread_mode=RENDER_THREAD_SAFE;
_time_scale=1.0;
Math::seed(1234567); Math::seed(1234567);
} }

View File

@ -55,6 +55,7 @@ class OS {
int _orientation; int _orientation;
float _fps; float _fps;
int _target_fps; int _target_fps;
float _time_scale;
char *last_error; char *last_error;
@ -332,6 +333,10 @@ public:
virtual Error dialog_show(String p_title, String p_description, Vector<String> p_buttons, Object* p_obj, String p_callback); virtual Error dialog_show(String p_title, String p_description, Vector<String> p_buttons, Object* p_obj, String p_callback);
virtual Error dialog_input_text(String p_title, String p_description, String p_partial, Object* p_obj, String p_callback); virtual Error dialog_input_text(String p_title, String p_description, String p_partial, Object* p_obj, String p_callback);
void set_time_scale(float p_scale);
float get_time_scale() const;
OS(); OS();
virtual ~OS(); virtual ~OS();

View File

@ -2467,13 +2467,8 @@ int String::findn(String p_str,int p_from) const {
}; };
CharType src=srcd[read_pos]; CharType src=_find_lower(srcd[read_pos]);
CharType dst=p_str[j]; CharType dst=_find_lower(p_str[j]);
if (src>='a' && src<='z')
src-='a'-'A';
if (dst>='a' && dst<='z')
dst-='a'-'A';
if (src!=dst) { if (src!=dst) {
found=false; found=false;
@ -2490,10 +2485,101 @@ int String::findn(String p_str,int p_from) const {
int String::rfind(String p_str,int p_from) const { int String::rfind(String p_str,int p_from) const {
//stabilish a limit
int limit = length()-p_str.length();
if (limit<0)
return -1;
//stabilish a starting point
if (p_from<0)
p_from=limit;
else if (p_from>limit)
p_from=limit;
int src_len=p_str.length();
int len=length();
if(src_len==0 || len==0)
return -1; //wont find anything!
const CharType *src = c_str();
for (int i=p_from;i>=0;i--) {
bool found=true;
for (int j=0;j<src_len;j++) {
int read_pos=i+j;
if (read_pos>=len) {
ERR_PRINT("read_pos>=len");
return -1;
};
if (src[read_pos]!=p_str[j]) {
found=false;
break;
}
}
if (found)
return i;
}
return -1; return -1;
} }
int String::rfindn(String p_str,int p_from) const { int String::rfindn(String p_str,int p_from) const {
//stabilish a limit
int limit = length()-p_str.length();
if (limit<0)
return -1;
//stabilish a starting point
if (p_from<0)
p_from=limit;
else if (p_from>limit)
p_from=limit;
int src_len=p_str.length();
int len=length();
if(src_len==0 || len==0)
return -1; //wont find anything!
const CharType *src = c_str();
for (int i=p_from;i>=0;i--) {
bool found=true;
for (int j=0;j<src_len;j++) {
int read_pos=i+j;
if (read_pos>=len) {
ERR_PRINT("read_pos>=len");
return -1;
};
CharType srcc=_find_lower(src[read_pos]);
CharType dstc=_find_lower(p_str[j]);
if (srcc!=dstc) {
found=false;
break;
}
}
if (found)
return i;
}
return -1; return -1;
} }

Binary file not shown.

View File

@ -9,6 +9,11 @@ func goto_scene(scene):
var s = ResourceLoader.load(scene) var s = ResourceLoader.load(scene)
#queue erasing old (don't use free because that scene is calling this method) #queue erasing old (don't use free because that scene is calling this method)
current_scene.queue_free() current_scene.queue_free()
# Remove the scene before loading the previous one.
# The node is removed when deleted anyway, but this will fix issues that
# might arise if both have a root node with the same name,
# as adding both together will cause the second to be renamed. (not usually a problem, but you might be wanting to look for the node later and not find it)
get_scene().get_root().remove(current_scene)
#instance the new scene #instance the new scene
current_scene = s.instance() current_scene = s.instance()
#add it to the active scene, as child of root #add it to the active scene, as child of root

View File

@ -5748,7 +5748,7 @@ void RasterizerGLES2::_setup_skeleton(const Skeleton *p_skeleton) {
void RasterizerGLES2::_render_list_forward(RenderList *p_render_list,const Transform& p_view_transform, const Transform& p_view_transform_inverse,const CameraMatrix& p_projection,bool p_reverse_cull,bool p_fragment_light,bool p_alpha_pass) { void RasterizerGLES2::_render_list_forward(RenderList *p_render_list,const Transform& p_view_transform, const Transform& p_view_transform_inverse,const CameraMatrix& p_projection,bool p_reverse_cull,bool p_fragment_light,bool p_alpha_pass) {
if (current_rt && current_rt_vflip) { if (current_rt && current_rt_vflip) {
p_reverse_cull=!p_reverse_cull; //p_reverse_cull=!p_reverse_cull;
glFrontFace(GL_CCW); glFrontFace(GL_CCW);
} }
@ -5881,10 +5881,12 @@ void RasterizerGLES2::_render_list_forward(RenderList *p_render_list,const Trans
if (desired_blend) { if (desired_blend) {
glEnable(GL_BLEND); glEnable(GL_BLEND);
if (!current_rt || !current_rt_transparent)
glColorMask(1,1,1,0); glColorMask(1,1,1,0);
} else { } else {
glDisable(GL_BLEND); glDisable(GL_BLEND);
glColorMask(1,1,1,1); glColorMask(1,1,1,1);
} }
prev_blend=desired_blend; prev_blend=desired_blend;
@ -5892,8 +5894,8 @@ void RasterizerGLES2::_render_list_forward(RenderList *p_render_list,const Trans
if (desired_blend && desired_blend_mode!=current_blend_mode) { if (desired_blend && desired_blend_mode!=current_blend_mode) {
switch(desired_blend_mode) {
switch(desired_blend_mode) {
case VS::MATERIAL_BLEND_MODE_MIX: { case VS::MATERIAL_BLEND_MODE_MIX: {
glBlendEquation(GL_FUNC_ADD); glBlendEquation(GL_FUNC_ADD);

View File

@ -153,6 +153,7 @@ void Main::print_help(const char* p_binary) {
OS::get_singleton()->print("\t-d,-debug : Debug (local stdout debugger).\n"); OS::get_singleton()->print("\t-d,-debug : Debug (local stdout debugger).\n");
OS::get_singleton()->print("\t-rdebug ADDRESS : Remote debug (<ip>:<port> host address).\n"); OS::get_singleton()->print("\t-rdebug ADDRESS : Remote debug (<ip>:<port> host address).\n");
OS::get_singleton()->print("\t-fdelay [msec]: Simulate high CPU load (delay each frame by [msec]).\n"); OS::get_singleton()->print("\t-fdelay [msec]: Simulate high CPU load (delay each frame by [msec]).\n");
OS::get_singleton()->print("\t-timescale [msec]: Simulate high CPU load (delay each frame by [msec]).\n");
OS::get_singleton()->print("\t-bp : breakpoint list as source::line comma separated pairs, no spaces (%%20,%%2C,etc instead).\n"); OS::get_singleton()->print("\t-bp : breakpoint list as source::line comma separated pairs, no spaces (%%20,%%2C,etc instead).\n");
OS::get_singleton()->print("\t-v : Verbose stdout mode\n"); OS::get_singleton()->print("\t-v : Verbose stdout mode\n");
OS::get_singleton()->print("\t-lang [locale]: Use a specific locale\n"); OS::get_singleton()->print("\t-lang [locale]: Use a specific locale\n");
@ -420,6 +421,17 @@ Error Main::setup(const char *execpath,int argc, char *argv[],bool p_second_phas
} }
} else if (I->get()=="-timescale") { // resolution
if (I->next()) {
OS::get_singleton()->set_time_scale(I->next()->get().to_double());
N=I->next()->next();
} else {
goto error;
}
} else if (I->get() == "-pack") { } else if (I->get() == "-pack") {
@ -1292,6 +1304,8 @@ bool Main::iteration() {
time_accum+=step; time_accum+=step;
float time_scale = OS::get_singleton()->get_time_scale();
bool exit=false; bool exit=false;
@ -1307,15 +1321,15 @@ bool Main::iteration() {
Physics2DServer::get_singleton()->sync(); Physics2DServer::get_singleton()->sync();
Physics2DServer::get_singleton()->flush_queries(); Physics2DServer::get_singleton()->flush_queries();
if (OS::get_singleton()->get_main_loop()->iteration( frame_slice )) { if (OS::get_singleton()->get_main_loop()->iteration( frame_slice*time_scale )) {
exit=true; exit=true;
break; break;
} }
message_queue->flush(); message_queue->flush();
PhysicsServer::get_singleton()->step(frame_slice); PhysicsServer::get_singleton()->step(frame_slice*time_scale);
Physics2DServer::get_singleton()->step(frame_slice); Physics2DServer::get_singleton()->step(frame_slice*time_scale);
time_accum-=frame_slice; time_accum-=frame_slice;
message_queue->flush(); message_queue->flush();
@ -1328,13 +1342,13 @@ bool Main::iteration() {
uint64_t idle_begin = OS::get_singleton()->get_ticks_usec(); uint64_t idle_begin = OS::get_singleton()->get_ticks_usec();
OS::get_singleton()->get_main_loop()->idle( step ); OS::get_singleton()->get_main_loop()->idle( step*time_scale );
message_queue->flush(); message_queue->flush();
if (SpatialSoundServer::get_singleton()) if (SpatialSoundServer::get_singleton())
SpatialSoundServer::get_singleton()->update( step ); SpatialSoundServer::get_singleton()->update( step*time_scale );
if (SpatialSound2DServer::get_singleton()) if (SpatialSound2DServer::get_singleton())
SpatialSound2DServer::get_singleton()->update( step ); SpatialSound2DServer::get_singleton()->update( step*time_scale );
if (OS::get_singleton()->can_draw()) { if (OS::get_singleton()->can_draw()) {

View File

@ -2117,9 +2117,15 @@ void GDParser::_parse_class(ClassNode *p_class) {
break; break;
} }
}; }; //fallthrough to use the same
case Variant::REAL: { case Variant::REAL: {
float sign=1.0;
if (tokenizer->get_token()==GDTokenizer::TK_OP_SUB) {
sign=-1;
tokenizer->advance();
}
if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) { if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) {
current_export=PropertyInfo(); current_export=PropertyInfo();
@ -2130,7 +2136,7 @@ void GDParser::_parse_class(ClassNode *p_class) {
//enumeration //enumeration
current_export.hint=PROPERTY_HINT_RANGE; current_export.hint=PROPERTY_HINT_RANGE;
current_export.hint_string=tokenizer->get_token_constant().operator String(); current_export.hint_string=rtos(sign*double(tokenizer->get_token_constant()));
tokenizer->advance(); tokenizer->advance();
if (tokenizer->get_token()==GDTokenizer::TK_PARENTHESIS_CLOSE) { if (tokenizer->get_token()==GDTokenizer::TK_PARENTHESIS_CLOSE) {
@ -2147,6 +2153,12 @@ void GDParser::_parse_class(ClassNode *p_class) {
tokenizer->advance(); tokenizer->advance();
sign=1.0;
if (tokenizer->get_token()==GDTokenizer::TK_OP_SUB) {
sign=-1;
tokenizer->advance();
}
if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) { if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) {
current_export=PropertyInfo(); current_export=PropertyInfo();
@ -2154,7 +2166,7 @@ void GDParser::_parse_class(ClassNode *p_class) {
return; return;
} }
current_export.hint_string+=","+tokenizer->get_token_constant().operator String(); current_export.hint_string+=","+rtos(sign*double(tokenizer->get_token_constant()));
tokenizer->advance(); tokenizer->advance();
if (tokenizer->get_token()==GDTokenizer::TK_PARENTHESIS_CLOSE) if (tokenizer->get_token()==GDTokenizer::TK_PARENTHESIS_CLOSE)
@ -2168,6 +2180,11 @@ void GDParser::_parse_class(ClassNode *p_class) {
} }
tokenizer->advance(); tokenizer->advance();
sign=1.0;
if (tokenizer->get_token()==GDTokenizer::TK_OP_SUB) {
sign=-1;
tokenizer->advance();
}
if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) { if (tokenizer->get_token()!=GDTokenizer::TK_CONSTANT || !tokenizer->get_token_constant().is_num()) {
@ -2176,7 +2193,7 @@ void GDParser::_parse_class(ClassNode *p_class) {
return; return;
} }
current_export.hint_string+=","+tokenizer->get_token_constant().operator String(); current_export.hint_string+=","+rtos(sign*double(tokenizer->get_token_constant()));
tokenizer->advance(); tokenizer->advance();
} break; } break;

View File

@ -1331,7 +1331,7 @@ OS_Windows::MouseMode OS_Windows::get_mouse_mode() const{
void OS_Windows::warp_mouse_pos(const Point2& p_to) { void OS_Windows::warp_mouse_pos(const Point2& p_to) {
if (p_mode==MOUSE_MODE_CAPTURED) { if (mouse_mode==MOUSE_MODE_CAPTURED) {
old_x=p_to.x; old_x=p_to.x;
old_y=p_to.y; old_y=p_to.y;

View File

@ -484,7 +484,7 @@ void Particles2D::_notification(int p_what) {
Particle *pdata=&particles[0]; Particle *pdata=&particles[0];
int particle_count=particles.size(); int particle_count=particles.size();
Rect2 r(Point2(),size);
RID texrid; RID texrid;
if (texture.is_valid()) if (texture.is_valid())
@ -606,9 +606,10 @@ void Particles2D::_notification(int p_what) {
if (texrid.is_valid()) { if (texrid.is_valid()) {
VisualServer::get_singleton()->canvas_item_add_texture_rect(ci,r,texrid,false,color); texture->draw(ci,Point2(),color);
//VisualServer::get_singleton()->canvas_item_add_texture_rect(ci,r,texrid,false,color);
} else { } else {
VisualServer::get_singleton()->canvas_item_add_rect(ci,r,color); VisualServer::get_singleton()->canvas_item_add_rect(ci,Rect2(Point2(),size),color);
} }

View File

@ -329,6 +329,7 @@ Map<TileMap::PosKey,TileMap::Quadrant>::Element *TileMap::_create_quadrant(const
VisualServer::get_singleton()->canvas_item_set_parent( q.canvas_item, get_canvas_item() ); VisualServer::get_singleton()->canvas_item_set_parent( q.canvas_item, get_canvas_item() );
VisualServer::get_singleton()->canvas_item_set_transform( q.canvas_item, xform ); VisualServer::get_singleton()->canvas_item_set_transform( q.canvas_item, xform );
q.static_body=Physics2DServer::get_singleton()->body_create(Physics2DServer::BODY_MODE_STATIC); q.static_body=Physics2DServer::get_singleton()->body_create(Physics2DServer::BODY_MODE_STATIC);
Physics2DServer::get_singleton()->body_attach_object_instance_ID(q.static_body,get_instance_ID());
Physics2DServer::get_singleton()->body_set_layer_mask(q.static_body,collision_layer); Physics2DServer::get_singleton()->body_set_layer_mask(q.static_body,collision_layer);
Physics2DServer::get_singleton()->body_set_param(q.static_body,Physics2DServer::BODY_PARAM_FRICTION,friction); Physics2DServer::get_singleton()->body_set_param(q.static_body,Physics2DServer::BODY_PARAM_FRICTION,friction);
Physics2DServer::get_singleton()->body_set_param(q.static_body,Physics2DServer::BODY_PARAM_BOUNCE,bounce); Physics2DServer::get_singleton()->body_set_param(q.static_body,Physics2DServer::BODY_PARAM_BOUNCE,bounce);

View File

@ -197,7 +197,7 @@ protected:
public: public:
OmniLight() : Light( VisualServer::LIGHT_OMNI ) {} OmniLight() : Light( VisualServer::LIGHT_OMNI ) { set_parameter(PARAM_SHADOW_Z_OFFSET,0.001);}
}; };
class SpotLight : public Light { class SpotLight : public Light {

View File

@ -399,6 +399,20 @@ void Sprite3D::_draw() {
int x_axis = ((axis + 1) % 3); int x_axis = ((axis + 1) % 3);
int y_axis = ((axis + 2) % 3); int y_axis = ((axis + 2) % 3);
if (axis!=Vector3::AXIS_Z) {
SWAP(x_axis,y_axis);
for(int i=0;i<4;i++) {
//uvs[i] = Vector2(1.0,1.0)-uvs[i];
//SWAP(vertices[i].x,vertices[i].y);
if (axis==Vector3::AXIS_Y) {
vertices[i].y = - vertices[i].y;
} else if (axis==Vector3::AXIS_X) {
vertices[i].x = - vertices[i].x;
}
}
}
AABB aabb; AABB aabb;
for(int i=0;i<4;i++) { for(int i=0;i<4;i++) {
@ -407,8 +421,8 @@ void Sprite3D::_draw() {
VS::get_singleton()->immediate_uv(immediate,uvs[i]); VS::get_singleton()->immediate_uv(immediate,uvs[i]);
Vector3 vtx; Vector3 vtx;
vtx[x_axis]=vertices[i][x_axis]; vtx[x_axis]=vertices[i][0];
vtx[y_axis]=vertices[i][y_axis]; vtx[y_axis]=vertices[i][1];
VS::get_singleton()->immediate_vertex(immediate,vtx); VS::get_singleton()->immediate_vertex(immediate,vtx);
if (i==0) { if (i==0) {
aabb.pos=vtx; aabb.pos=vtx;
@ -661,6 +675,20 @@ void AnimatedSprite3D::_draw() {
int x_axis = ((axis + 1) % 3); int x_axis = ((axis + 1) % 3);
int y_axis = ((axis + 2) % 3); int y_axis = ((axis + 2) % 3);
if (axis!=Vector3::AXIS_Z) {
SWAP(x_axis,y_axis);
for(int i=0;i<4;i++) {
//uvs[i] = Vector2(1.0,1.0)-uvs[i];
//SWAP(vertices[i].x,vertices[i].y);
if (axis==Vector3::AXIS_Y) {
vertices[i].y = - vertices[i].y;
} else if (axis==Vector3::AXIS_X) {
vertices[i].x = - vertices[i].x;
}
}
}
AABB aabb; AABB aabb;
for(int i=0;i<4;i++) { for(int i=0;i<4;i++) {
@ -669,8 +697,8 @@ void AnimatedSprite3D::_draw() {
VS::get_singleton()->immediate_uv(immediate,uvs[i]); VS::get_singleton()->immediate_uv(immediate,uvs[i]);
Vector3 vtx; Vector3 vtx;
vtx[x_axis]=vertices[i][x_axis]; vtx[x_axis]=vertices[i][0];
vtx[y_axis]=vertices[i][y_axis]; vtx[y_axis]=vertices[i][1];
VS::get_singleton()->immediate_vertex(immediate,vtx); VS::get_singleton()->immediate_vertex(immediate,vtx);
if (i==0) { if (i==0) {
aabb.pos=vtx; aabb.pos=vtx;

View File

@ -677,6 +677,7 @@ void LineEdit::selection_delete() {
undo_text = text; undo_text = text;
text.erase(selection.begin,selection.end-selection.begin); text.erase(selection.begin,selection.end-selection.begin);
cursor_pos-=CLAMP( cursor_pos-selection.begin, 0, selection.end-selection.begin);
if (cursor_pos>=text.length()) { if (cursor_pos>=text.length()) {

View File

@ -2611,20 +2611,53 @@ bool TextEdit::search(const String &p_key,uint32_t p_search_flags, int p_from_li
int line=-1; int line=-1;
int pos=-1; int pos=-1;
line=p_from_line;
for(int i=0;i<text.size()+1;i++) { for(int i=0;i<text.size()+1;i++) {
//backwards is broken... //backwards is broken...
int idx=(p_search_flags&SEARCH_BACKWARDS)?(text.size()-i):i; //do backwards seearch //int idx=(p_search_flags&SEARCH_BACKWARDS)?(text.size()-i):i; //do backwards seearch
line = (idx+p_from_line)%text.size();
if (line<0) {
line=text.size()-1;
}
if (line==text.size()) {
line=0;
}
String text_line = text[line]; String text_line = text[line];
int from_column=(idx==0)?p_from_column:0; int from_column=0;
if (idx==text.size()) { if (line==p_from_line) {
text_line=text_line.substr(0,p_from_column); //wrap around for missing begining.
if (i==text.size()) {
//wrapped
if (p_search_flags&SEARCH_BACKWARDS) {
text_line=text_line.substr(from_column,text_line.length());
from_column=text_line.length();
} else {
text_line=text_line.substr(0,from_column);
from_column=0;
}
} else {
from_column=p_from_column;
}
} else {
//text_line=text_line.substr(0,p_from_column); //wrap around for missing begining.
if (p_search_flags&SEARCH_BACKWARDS)
from_column=text_line.length()-1;
else
from_column=0;
} }
pos=-1; pos=-1;
if (!(p_search_flags&SEARCH_BACKWARDS)) { if (!(p_search_flags&SEARCH_BACKWARDS)) {
pos = (p_search_flags&SEARCH_MATCH_CASE)?text_line.find(p_key,from_column):text_line.findn(p_key,from_column); pos = (p_search_flags&SEARCH_MATCH_CASE)?text_line.find(p_key,from_column):text_line.findn(p_key,from_column);
} else { } else {
@ -2642,6 +2675,11 @@ bool TextEdit::search(const String &p_key,uint32_t p_search_flags, int p_from_li
if (pos!=-1) if (pos!=-1)
break; break;
if (p_search_flags&SEARCH_BACKWARDS)
line--;
else
line++;
} }
if (pos==-1) { if (pos==-1) {

View File

@ -3009,20 +3009,23 @@ TreeItem* Tree::_find_item_at_pos(TreeItem*p_item, const Point2& p_pos,int& r_co
String Tree::get_tooltip(const Point2& p_pos) const { String Tree::get_tooltip(const Point2& p_pos) const {
if (root) { if (root) {
Point2 pos=p_pos; Point2 pos=p_pos;
pos -= cache.bg->get_offset(); pos -= cache.bg->get_offset();
pos.y-=_get_title_button_height(); pos.y-=_get_title_button_height();
if (pos.y<0) if (pos.y<0)
return Control::get_tooltip(p_pos); return Control::get_tooltip(p_pos);
if (h_scroll->is_visible())
pos.x+=h_scroll->get_val(); pos.x+=h_scroll->get_val();
if (v_scroll->is_visible())
pos.y+=v_scroll->get_val(); pos.y+=v_scroll->get_val();
int col,h; int col,h;
TreeItem *it = _find_item_at_pos(root,pos,col,h); TreeItem *it = _find_item_at_pos(root,pos,col,h);
if (it) {
if (it) {
String ret; String ret;
if (it->get_tooltip(col)=="") if (it->get_tooltip(col)=="")

View File

@ -1107,7 +1107,7 @@ void Node::get_groups(List<GroupInfo> *p_groups) const {
void Node::_print_tree(const Node *p_node) { void Node::_print_tree(const Node *p_node) {
printf("%ls\n", String(p_node->get_path_to(this)).c_str()); print_line(String(p_node->get_path_to(this)));
for (int i=0;i<data.children.size();i++) for (int i=0;i<data.children.size();i++)
data.children[i]->_print_tree(p_node); data.children[i]->_print_tree(p_node);
} }

View File

@ -246,13 +246,27 @@ bool FindReplaceDialog::_search() {
if (is_backwards()) if (is_backwards())
flags|=TextEdit::SEARCH_BACKWARDS; flags|=TextEdit::SEARCH_BACKWARDS;
int line,col; int line=text_edit->cursor_get_line(),col=text_edit->cursor_get_column();
bool found = text_edit->search(text,flags,text_edit->cursor_get_line(),text_edit->cursor_get_column(),line,col);
if (is_backwards()) {
col-=1;
if (col<0) {
line-=1;
if (line<0) {
line=text_edit->get_line_count()-1;
}
col=text_edit->get_line(line).length();
}
}
bool found = text_edit->search(text,flags,line,col,line,col);
if (found) { if (found) {
// print_line("found"); // print_line("found");
text_edit->cursor_set_line(line); text_edit->cursor_set_line(line);
if (is_backwards())
text_edit->cursor_set_column(col);
else
text_edit->cursor_set_column(col+text.length()); text_edit->cursor_set_column(col+text.length());
text_edit->select(line,col,line,col+text.length()); text_edit->select(line,col,line,col+text.length());
set_error(""); set_error("");

View File

@ -79,8 +79,14 @@ void EditorPath::_notification(int p_what) {
} else if (obj->cast_to<Node>()) { } else if (obj->cast_to<Node>()) {
name=obj->cast_to<Node>()->get_name(); name=obj->cast_to<Node>()->get_name();
} else } else if (obj->cast_to<Resource>() && obj->cast_to<Resource>()->get_name()!="") {
name=obj->cast_to<Resource>()->get_name();
} else {
name=obj->get_type(); name=obj->get_type();
}
set_tooltip(obj->get_type());
label_font->draw(ci,Point2i(ofs,(size.height-label_font->get_height())/2+label_font->get_ascent()),name,Color(1,1,1),left); label_font->draw(ci,Point2i(ofs,(size.height-label_font->get_height())/2+label_font->get_ascent()),name,Color(1,1,1),left);
} else { } else {

View File

@ -484,6 +484,16 @@ Node *SceneTreeDock::_duplicate(Node *p_node, Map<Node*,Node*> &duplimap) {
} }
List<Node::GroupInfo> group_info;
p_node->get_groups(&group_info);
for (List<Node::GroupInfo>::Element *E=group_info.front();E;E=E->next()) {
if (E->get().persistent)
node->add_to_group(E->get().name,true);
}
node->set_name(p_node->get_name()); node->set_name(p_node->get_name());
duplimap[p_node]=node; duplimap[p_node]=node;

View File

@ -224,7 +224,9 @@ void SceneTreeEditor::_add_nodes(Node *p_node,TreeItem *p_parent) {
if (p_node!=get_scene_node() && p_node->get_filename()!="" && can_open_instance) { if (p_node!=get_scene_node() && p_node->get_filename()!="" && can_open_instance) {
item->add_button(0,get_icon("InstanceOptions","EditorIcons"),BUTTON_SUBSCENE); item->add_button(0,get_icon("InstanceOptions","EditorIcons"),BUTTON_SUBSCENE);
item->set_tooltip(0,"Instance: "+p_node->get_filename()); item->set_tooltip(0,"Instance: "+p_node->get_filename()+"\nType: "+p_node->get_type());
} else {
item->set_tooltip(0,String(p_node->get_name())+"\nType: "+p_node->get_type());
} }
if (can_open_instance) { if (can_open_instance) {