fix some crashes
This commit is contained in:
parent
30383a1cdc
commit
7d8d337b2c
11 changed files with 23 additions and 6 deletions
|
@ -1372,6 +1372,7 @@ void Image::shrink_x2() {
|
||||||
|
|
||||||
int new_size = data.size() - ofs;
|
int new_size = data.size() - ofs;
|
||||||
new_img.resize(new_size);
|
new_img.resize(new_size);
|
||||||
|
ERR_FAIL_COND(new_img.size() == 0);
|
||||||
|
|
||||||
{
|
{
|
||||||
PoolVector<uint8_t>::Write w = new_img.write();
|
PoolVector<uint8_t>::Write w = new_img.write();
|
||||||
|
@ -1391,6 +1392,7 @@ void Image::shrink_x2() {
|
||||||
ERR_FAIL_COND(!_can_modify(format));
|
ERR_FAIL_COND(!_can_modify(format));
|
||||||
int ps = get_format_pixel_size(format);
|
int ps = get_format_pixel_size(format);
|
||||||
new_img.resize((width / 2) * (height / 2) * ps);
|
new_img.resize((width / 2) * (height / 2) * ps);
|
||||||
|
ERR_FAIL_COND(new_img.size() == 0);
|
||||||
|
|
||||||
{
|
{
|
||||||
PoolVector<uint8_t>::Write w = new_img.write();
|
PoolVector<uint8_t>::Write w = new_img.write();
|
||||||
|
|
|
@ -4644,7 +4644,6 @@ Transform2D RasterizerStorageGLES3::multimesh_instance_get_transform_2d(RID p_mu
|
||||||
}
|
}
|
||||||
|
|
||||||
Color RasterizerStorageGLES3::multimesh_instance_get_color(RID p_multimesh, int p_index) const {
|
Color RasterizerStorageGLES3::multimesh_instance_get_color(RID p_multimesh, int p_index) const {
|
||||||
|
|
||||||
MultiMesh *multimesh = multimesh_owner.getornull(p_multimesh);
|
MultiMesh *multimesh = multimesh_owner.getornull(p_multimesh);
|
||||||
ERR_FAIL_COND_V(!multimesh, Color());
|
ERR_FAIL_COND_V(!multimesh, Color());
|
||||||
ERR_FAIL_INDEX_V(p_index, multimesh->size, Color());
|
ERR_FAIL_INDEX_V(p_index, multimesh->size, Color());
|
||||||
|
|
|
@ -866,7 +866,7 @@ void RigidBodyBullet::on_enter_area(AreaBullet *p_area) {
|
||||||
|
|
||||||
if (p_area->is_spOv_gravityPoint()) {
|
if (p_area->is_spOv_gravityPoint()) {
|
||||||
++countGravityPointSpaces;
|
++countGravityPointSpaces;
|
||||||
assert(0 < countGravityPointSpaces);
|
ERR_FAIL_COND(countGravityPointSpaces <= 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -888,7 +888,7 @@ void RigidBodyBullet::on_exit_area(AreaBullet *p_area) {
|
||||||
if (wasTheAreaFound) {
|
if (wasTheAreaFound) {
|
||||||
if (p_area->is_spOv_gravityPoint()) {
|
if (p_area->is_spOv_gravityPoint()) {
|
||||||
--countGravityPointSpaces;
|
--countGravityPointSpaces;
|
||||||
assert(0 <= countGravityPointSpaces);
|
ERR_FAIL_COND(countGravityPointSpaces < 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
--areaWhereIamCount;
|
--areaWhereIamCount;
|
||||||
|
|
|
@ -1556,14 +1556,14 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||||
//error
|
//error
|
||||||
// function, file, line, error, explanation
|
// function, file, line, error, explanation
|
||||||
String err_file;
|
String err_file;
|
||||||
if (p_instance)
|
if (p_instance && p_instance->script->is_valid() && p_instance->script->path != "")
|
||||||
err_file = p_instance->script->path;
|
err_file = p_instance->script->path;
|
||||||
else if (script)
|
else if (script)
|
||||||
err_file = script->path;
|
err_file = script->path;
|
||||||
if (err_file == "")
|
if (err_file == "")
|
||||||
err_file = "<built-in>";
|
err_file = "<built-in>";
|
||||||
String err_func = name;
|
String err_func = name;
|
||||||
if (p_instance && p_instance->script->name != "")
|
if (p_instance && p_instance->script->is_valid() && p_instance->script->name != "")
|
||||||
err_func = p_instance->script->name + "." + err_func;
|
err_func = p_instance->script->name + "." + err_func;
|
||||||
int err_line = line;
|
int err_line = line;
|
||||||
if (err_text == "") {
|
if (err_text == "") {
|
||||||
|
|
|
@ -1074,6 +1074,7 @@ Vector2 CanvasItem::make_canvas_position_local(const Vector2 &screen_point) cons
|
||||||
|
|
||||||
Ref<InputEvent> CanvasItem::make_input_local(const Ref<InputEvent> &p_event) const {
|
Ref<InputEvent> CanvasItem::make_input_local(const Ref<InputEvent> &p_event) const {
|
||||||
|
|
||||||
|
ERR_FAIL_COND_V(p_event.is_null(), p_event);
|
||||||
ERR_FAIL_COND_V(!is_inside_tree(), p_event);
|
ERR_FAIL_COND_V(!is_inside_tree(), p_event);
|
||||||
|
|
||||||
return p_event->xformed_by((get_canvas_transform() * get_global_transform()).affine_inverse());
|
return p_event->xformed_by((get_canvas_transform() * get_global_transform()).affine_inverse());
|
||||||
|
|
|
@ -506,6 +506,8 @@ bool Spatial::is_set_as_toplevel() const {
|
||||||
Ref<World> Spatial::get_world() const {
|
Ref<World> Spatial::get_world() const {
|
||||||
|
|
||||||
ERR_FAIL_COND_V(!is_inside_world(), Ref<World>());
|
ERR_FAIL_COND_V(!is_inside_world(), Ref<World>());
|
||||||
|
ERR_FAIL_COND_V(!data.viewport, Ref<World>());
|
||||||
|
|
||||||
return data.viewport->find_world();
|
return data.viewport->find_world();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,7 @@ void VisualInstance::_notification(int p_what) {
|
||||||
if (skeleton)
|
if (skeleton)
|
||||||
VisualServer::get_singleton()->instance_attach_skeleton( instance, skeleton->get_skeleton() );
|
VisualServer::get_singleton()->instance_attach_skeleton( instance, skeleton->get_skeleton() );
|
||||||
*/
|
*/
|
||||||
|
ERR_FAIL_COND(get_world().is_null());
|
||||||
VisualServer::get_singleton()->instance_set_scenario(instance, get_world()->get_scenario());
|
VisualServer::get_singleton()->instance_set_scenario(instance, get_world()->get_scenario());
|
||||||
_update_visibility();
|
_update_visibility();
|
||||||
|
|
||||||
|
|
|
@ -71,6 +71,8 @@ void Node::_notification(int p_notification) {
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
case NOTIFICATION_ENTER_TREE: {
|
case NOTIFICATION_ENTER_TREE: {
|
||||||
|
ERR_FAIL_COND(!get_viewport());
|
||||||
|
ERR_FAIL_COND(!get_tree());
|
||||||
|
|
||||||
if (data.pause_mode == PAUSE_MODE_INHERIT) {
|
if (data.pause_mode == PAUSE_MODE_INHERIT) {
|
||||||
|
|
||||||
|
@ -94,6 +96,8 @@ void Node::_notification(int p_notification) {
|
||||||
|
|
||||||
} break;
|
} break;
|
||||||
case NOTIFICATION_EXIT_TREE: {
|
case NOTIFICATION_EXIT_TREE: {
|
||||||
|
ERR_FAIL_COND(!get_viewport());
|
||||||
|
ERR_FAIL_COND(!get_tree());
|
||||||
|
|
||||||
get_tree()->node_count--;
|
get_tree()->node_count--;
|
||||||
orphan_node_count++;
|
orphan_node_count++;
|
||||||
|
@ -840,6 +844,8 @@ bool Node::is_processing_internal() const {
|
||||||
void Node::set_process_priority(int p_priority) {
|
void Node::set_process_priority(int p_priority) {
|
||||||
data.process_priority = p_priority;
|
data.process_priority = p_priority;
|
||||||
|
|
||||||
|
ERR_FAIL_COND(!data.tree);
|
||||||
|
|
||||||
if (is_processing())
|
if (is_processing())
|
||||||
data.tree->make_group_changed("idle_process");
|
data.tree->make_group_changed("idle_process");
|
||||||
|
|
||||||
|
|
|
@ -1701,6 +1701,8 @@ bool Viewport::_gui_drop(Control *p_at_control, Point2 p_at_pos, bool p_just_che
|
||||||
|
|
||||||
void Viewport::_gui_input_event(Ref<InputEvent> p_event) {
|
void Viewport::_gui_input_event(Ref<InputEvent> p_event) {
|
||||||
|
|
||||||
|
ERR_FAIL_COND(p_event.is_null())
|
||||||
|
|
||||||
//?
|
//?
|
||||||
/*
|
/*
|
||||||
if (!is_visible()) {
|
if (!is_visible()) {
|
||||||
|
|
|
@ -1487,8 +1487,10 @@ uint32_t CubeMap::get_flags() const {
|
||||||
|
|
||||||
void CubeMap::set_side(Side p_side, const Ref<Image> &p_image) {
|
void CubeMap::set_side(Side p_side, const Ref<Image> &p_image) {
|
||||||
|
|
||||||
|
ERR_FAIL_COND(p_image.is_null());
|
||||||
ERR_FAIL_COND(p_image->empty());
|
ERR_FAIL_COND(p_image->empty());
|
||||||
ERR_FAIL_INDEX(p_side, 6);
|
ERR_FAIL_INDEX(p_side, 6);
|
||||||
|
|
||||||
if (!_is_valid()) {
|
if (!_is_valid()) {
|
||||||
format = p_image->get_format();
|
format = p_image->get_format();
|
||||||
w = p_image->get_width();
|
w = p_image->get_width();
|
||||||
|
|
|
@ -216,6 +216,9 @@ Ref<AudioStreamSample> AudioEffectRecord::get_recording() const {
|
||||||
|
|
||||||
PoolVector<uint8_t> dst_data;
|
PoolVector<uint8_t> dst_data;
|
||||||
|
|
||||||
|
ERR_FAIL_COND_V(current_instance.is_null(), NULL);
|
||||||
|
ERR_FAIL_COND_V(current_instance->recording_data.size(), NULL);
|
||||||
|
|
||||||
if (dst_format == AudioStreamSample::FORMAT_8_BITS) {
|
if (dst_format == AudioStreamSample::FORMAT_8_BITS) {
|
||||||
int data_size = current_instance->recording_data.size();
|
int data_size = current_instance->recording_data.size();
|
||||||
dst_data.resize(data_size);
|
dst_data.resize(data_size);
|
||||||
|
|
Loading…
Reference in a new issue