Merge pull request #22681 from akien-mga/fix-warnings
Fix warnings on release builds and some MSVC warnings
This commit is contained in:
commit
344a453bb8
@ -322,13 +322,13 @@ if selected_platform in platform_list:
|
||||
print("WARNING: warnings=yes is deprecated; assuming warnings=all")
|
||||
|
||||
if env.msvc:
|
||||
disable_nonessential_warnings = ['/wd4267', '/wd4244', '/wd4305', '/wd4800'] # Truncations, narrowing conversions...
|
||||
# Truncations, narrowing conversions, signed/unsigned comparisons...
|
||||
disable_nonessential_warnings = ['/wd4267', '/wd4244', '/wd4305', '/wd4018', '/wd4800']
|
||||
if (env["warnings"] == 'extra'):
|
||||
env.Append(CCFLAGS=['/Wall']) # Implies /W4
|
||||
elif (env["warnings"] == 'all' or env["warnings"] == 'yes'):
|
||||
env.Append(CCFLAGS=['/W3'] + disable_nonessential_warnings)
|
||||
elif (env["warnings"] == 'moderate'):
|
||||
# C4244 shouldn't be needed here being a level-3 warning, but it is
|
||||
env.Append(CCFLAGS=['/W2'] + disable_nonessential_warnings)
|
||||
else: # 'no'
|
||||
env.Append(CCFLAGS=['/w'])
|
||||
|
@ -809,10 +809,10 @@ void ClassDB::add_signal(StringName p_class, const MethodInfo &p_signal) {
|
||||
ClassInfo *type = classes.getptr(p_class);
|
||||
ERR_FAIL_COND(!type);
|
||||
|
||||
ClassInfo *check = type;
|
||||
StringName sname = p_signal.name;
|
||||
#ifdef DEBUG_METHODS_ENABLED
|
||||
|
||||
#ifdef DEBUG_METHODS_ENABLED
|
||||
ClassInfo *check = type;
|
||||
while (check) {
|
||||
if (check->signal_map.has(sname)) {
|
||||
ERR_EXPLAIN("Type " + String(p_class) + " already has signal: " + String(sname));
|
||||
|
@ -307,6 +307,7 @@ void Image::_get_mipmap_offset_and_size(int p_mipmap, int &r_offset, int &r_widt
|
||||
r_width = w;
|
||||
r_height = h;
|
||||
}
|
||||
|
||||
int Image::get_mipmap_offset(int p_mipmap) const {
|
||||
|
||||
ERR_FAIL_INDEX_V(p_mipmap, get_mipmap_count() + 1, -1);
|
||||
@ -499,8 +500,6 @@ void Image::convert(Format p_new_format) {
|
||||
|
||||
bool gen_mipmaps = mipmaps;
|
||||
|
||||
//mipmaps=false;
|
||||
|
||||
_copy_internals_from(new_img);
|
||||
|
||||
if (gen_mipmaps)
|
||||
@ -799,6 +798,7 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
if (interpolate_mipmaps) {
|
||||
dst2.create(p_width, p_height, 0, format);
|
||||
}
|
||||
|
||||
bool had_mipmaps = mipmaps;
|
||||
if (interpolate_mipmaps && !had_mipmaps) {
|
||||
generate_mipmaps();
|
||||
@ -951,6 +951,7 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
}
|
||||
|
||||
void Image::crop_from_point(int p_x, int p_y, int p_width, int p_height) {
|
||||
|
||||
if (!_can_modify(format)) {
|
||||
ERR_EXPLAIN("Cannot crop in indexed, compressed or custom image formats.");
|
||||
ERR_FAIL();
|
||||
@ -996,7 +997,7 @@ void Image::crop_from_point(int p_x, int p_y, int p_width, int p_height) {
|
||||
}
|
||||
}
|
||||
|
||||
if (mipmaps > 0)
|
||||
if (has_mipmaps())
|
||||
dst.generate_mipmaps();
|
||||
_copy_internals_from(dst);
|
||||
}
|
||||
@ -1013,10 +1014,10 @@ void Image::flip_y() {
|
||||
ERR_FAIL();
|
||||
}
|
||||
|
||||
bool gm = mipmaps;
|
||||
|
||||
if (gm)
|
||||
bool used_mipmaps = has_mipmaps();
|
||||
if (used_mipmaps) {
|
||||
clear_mipmaps();
|
||||
}
|
||||
|
||||
{
|
||||
PoolVector<uint8_t>::Write w = data.write();
|
||||
@ -1037,8 +1038,9 @@ void Image::flip_y() {
|
||||
}
|
||||
}
|
||||
|
||||
if (gm)
|
||||
if (used_mipmaps) {
|
||||
generate_mipmaps();
|
||||
}
|
||||
}
|
||||
|
||||
void Image::flip_x() {
|
||||
@ -1048,9 +1050,10 @@ void Image::flip_x() {
|
||||
ERR_FAIL();
|
||||
}
|
||||
|
||||
bool gm = mipmaps;
|
||||
if (gm)
|
||||
bool used_mipmaps = has_mipmaps();
|
||||
if (used_mipmaps) {
|
||||
clear_mipmaps();
|
||||
}
|
||||
|
||||
{
|
||||
PoolVector<uint8_t>::Write w = data.write();
|
||||
@ -1071,8 +1074,9 @@ void Image::flip_x() {
|
||||
}
|
||||
}
|
||||
|
||||
if (gm)
|
||||
if (used_mipmaps) {
|
||||
generate_mipmaps();
|
||||
}
|
||||
}
|
||||
|
||||
int Image::_get_dst_image_size(int p_width, int p_height, Format p_format, int &r_mipmaps, int p_mipmaps) {
|
||||
@ -1167,12 +1171,13 @@ void Image::expand_x2_hq2x() {
|
||||
|
||||
ERR_FAIL_COND(!_can_modify(format));
|
||||
|
||||
Format current = format;
|
||||
bool mm = has_mipmaps();
|
||||
if (mm) {
|
||||
bool used_mipmaps = has_mipmaps();
|
||||
if (used_mipmaps) {
|
||||
clear_mipmaps();
|
||||
}
|
||||
|
||||
Format current = format;
|
||||
|
||||
if (current != FORMAT_RGBA8)
|
||||
convert(FORMAT_RGBA8);
|
||||
|
||||
@ -1193,7 +1198,7 @@ void Image::expand_x2_hq2x() {
|
||||
if (current != FORMAT_RGBA8)
|
||||
convert(current);
|
||||
|
||||
if (mipmaps) {
|
||||
if (used_mipmaps) {
|
||||
generate_mipmaps();
|
||||
}
|
||||
}
|
||||
|
@ -175,7 +175,7 @@ int Compression::decompress(uint8_t *p_dst, int p_dst_max_size, const uint8_t *p
|
||||
} break;
|
||||
case MODE_ZSTD: {
|
||||
ZSTD_DCtx *dctx = ZSTD_createDCtx();
|
||||
if (zstd_long_distance_matching) ZSTD_DCtx_setMaxWindowSize(dctx, 1 << zstd_window_log_size);
|
||||
if (zstd_long_distance_matching) ZSTD_DCtx_setMaxWindowSize(dctx, (size_t)1 << zstd_window_log_size);
|
||||
int ret = ZSTD_decompressDCtx(dctx, p_dst, p_dst_max_size, p_src, p_src_size);
|
||||
ZSTD_freeDCtx(dctx);
|
||||
return ret;
|
||||
|
@ -169,11 +169,11 @@ bool PackedSourcePCK::try_open_pack(const String &p_path) {
|
||||
uint32_t version = f->get_32();
|
||||
uint32_t ver_major = f->get_32();
|
||||
uint32_t ver_minor = f->get_32();
|
||||
uint32_t ver_rev = f->get_32();
|
||||
f->get_32(); // ver_rev
|
||||
|
||||
ERR_EXPLAIN("Pack version unsupported: " + itos(version));
|
||||
ERR_FAIL_COND_V(version != PACK_VERSION, false);
|
||||
ERR_EXPLAIN("Pack created with a newer version of the engine: " + itos(ver_major) + "." + itos(ver_minor) + "." + itos(ver_rev));
|
||||
ERR_EXPLAIN("Pack created with a newer version of the engine: " + itos(ver_major) + "." + itos(ver_minor));
|
||||
ERR_FAIL_COND_V(ver_major > VERSION_MAJOR || (ver_major == VERSION_MAJOR && ver_minor > VERSION_MINOR), false);
|
||||
|
||||
for (int i = 0; i < 16; i++) {
|
||||
|
@ -165,7 +165,6 @@ int BSP_Tree::get_points_inside(const Vector3 *p_points, int p_point_count) cons
|
||||
int pass_count = 0;
|
||||
const Node *nodesptr = &nodes[0];
|
||||
const Plane *planesptr = &planes[0];
|
||||
int plane_count = planes.size();
|
||||
int node_count = nodes.size();
|
||||
|
||||
if (node_count == 0) // no nodes!
|
||||
@ -192,9 +191,9 @@ int BSP_Tree::get_points_inside(const Vector3 *p_points, int p_point_count) cons
|
||||
break;
|
||||
}
|
||||
|
||||
uint16_t plane = nodesptr[idx].plane;
|
||||
#ifdef DEBUG_ENABLED
|
||||
|
||||
int plane_count = planes.size();
|
||||
uint16_t plane = nodesptr[idx].plane;
|
||||
ERR_FAIL_INDEX_V(plane, plane_count, false);
|
||||
#endif
|
||||
|
||||
|
@ -227,10 +227,7 @@ static void user_read_data(png_structp png_ptr, png_bytep data, png_size_t p_len
|
||||
PNGReadStatus *rstatus;
|
||||
rstatus = (PNGReadStatus *)png_get_io_ptr(png_ptr);
|
||||
|
||||
png_size_t to_read = p_length;
|
||||
if (rstatus->size >= 0) {
|
||||
to_read = MIN(p_length, rstatus->size - rstatus->offset);
|
||||
}
|
||||
png_size_t to_read = MIN(p_length, rstatus->size - rstatus->offset);
|
||||
memcpy(data, &rstatus->image[rstatus->offset], to_read);
|
||||
rstatus->offset += to_read;
|
||||
|
||||
|
@ -223,7 +223,7 @@ void DocDump::dump(const String &p_file) {
|
||||
hint = "Values: ";
|
||||
for (int j = 0; j < arginfo.hint_string.get_slice_count(","); j++) {
|
||||
if (j > 0) hint += ", ";
|
||||
hint += arginfo.hint_string.get_slice(",", j) + "=" + itos(1 << j);
|
||||
hint += arginfo.hint_string.get_slice(",", j) + "=" + itos((uint64_t)1 << j);
|
||||
}
|
||||
break;
|
||||
case PROPERTY_HINT_FILE: hint = "A file:"; break;
|
||||
|
@ -376,7 +376,7 @@ Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
|
||||
//Register icons + font
|
||||
|
||||
// the resolution and the icon color (dark_theme bool) has not changed, so we do not regenerate the icons
|
||||
if (p_theme != NULL && fabs(p_theme->get_constant("scale", "Editor") - EDSCALE) < 0.00001 && p_theme->get_constant("dark_theme", "Editor") == dark_theme) {
|
||||
if (p_theme != NULL && fabs(p_theme->get_constant("scale", "Editor") - EDSCALE) < 0.00001 && (bool)p_theme->get_constant("dark_theme", "Editor") == dark_theme) {
|
||||
// register already generated icons
|
||||
for (int i = 0; i < editor_icons_count; i++) {
|
||||
theme->set_icon(editor_icons_names[i], "EditorIcons", p_theme->get_icon(editor_icons_names[i], "EditorIcons"));
|
||||
|
@ -42,12 +42,9 @@ Error ImageLoaderBMP::convert_to_image(Ref<Image> p_image,
|
||||
|
||||
if (err == OK) {
|
||||
size_t index = 0;
|
||||
size_t width =
|
||||
static_cast<size_t>(p_header.bmp_info_header.bmp_width < 0 ? -p_header.bmp_info_header.bmp_width : p_header.bmp_info_header.bmp_width);
|
||||
size_t height =
|
||||
static_cast<size_t>(p_header.bmp_info_header.bmp_height < 0 ? -p_header.bmp_info_header.bmp_height : p_header.bmp_info_header.bmp_height);
|
||||
size_t bits_per_pixel =
|
||||
static_cast<size_t>(p_header.bmp_info_header.bmp_bit_count);
|
||||
size_t width = (size_t)p_header.bmp_info_header.bmp_width;
|
||||
size_t height = (size_t)p_header.bmp_info_header.bmp_height;
|
||||
size_t bits_per_pixel = (size_t)p_header.bmp_info_header.bmp_bit_count;
|
||||
|
||||
if (p_header.bmp_info_header.bmp_compression != 0) {
|
||||
err = FAILED;
|
||||
|
@ -155,6 +155,7 @@ String GDScriptFunction::_get_call_error(const Variant::CallError &p_err, const
|
||||
return err_text;
|
||||
}
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
static String _get_var_type(const Variant *p_type) {
|
||||
|
||||
String basestr;
|
||||
@ -164,7 +165,6 @@ static String _get_var_type(const Variant *p_type) {
|
||||
if (!bobj) {
|
||||
basestr = "null instance";
|
||||
} else {
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (ObjectDB::instance_validate(bobj)) {
|
||||
if (bobj->get_script_instance())
|
||||
basestr = bobj->get_class() + " (" + bobj->get_script_instance()->get_script()->get_path().get_file() + ")";
|
||||
@ -173,10 +173,6 @@ static String _get_var_type(const Variant *p_type) {
|
||||
} else {
|
||||
basestr = "previously freed instance";
|
||||
}
|
||||
|
||||
#else
|
||||
basestr = "Object";
|
||||
#endif
|
||||
}
|
||||
|
||||
} else {
|
||||
@ -185,6 +181,7 @@ static String _get_var_type(const Variant *p_type) {
|
||||
|
||||
return basestr;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(__GNUC__)
|
||||
#define OPCODES_TABLE \
|
||||
@ -676,6 +673,7 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
OPCODE(OPCODE_SET_MEMBER) {
|
||||
|
||||
CHECK_SPACE(3);
|
||||
#ifdef DEBUG_ENABLED
|
||||
int indexname = _code_ptr[ip + 1];
|
||||
GD_ERR_BREAK(indexname < 0 || indexname >= _global_names_count);
|
||||
const StringName *index = &_global_names_ptr[indexname];
|
||||
@ -683,7 +681,6 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
|
||||
bool valid;
|
||||
bool ok = ClassDB::set_property(p_instance->owner, *index, *src, &valid);
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (!ok) {
|
||||
err_text = "Internal error setting property: " + String(*index);
|
||||
OPCODE_BREAK;
|
||||
@ -699,13 +696,13 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
OPCODE(OPCODE_GET_MEMBER) {
|
||||
|
||||
CHECK_SPACE(3);
|
||||
#ifdef DEBUG_ENABLED
|
||||
int indexname = _code_ptr[ip + 1];
|
||||
GD_ERR_BREAK(indexname < 0 || indexname >= _global_names_count);
|
||||
const StringName *index = &_global_names_ptr[indexname];
|
||||
GET_VARIANT_PTR(dst, 2);
|
||||
bool ok = ClassDB::get_property(p_instance->owner, *index, *dst);
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
bool ok = ClassDB::get_property(p_instance->owner, *index, *dst);
|
||||
if (!ok) {
|
||||
err_text = "Internal error getting property: " + String(*index);
|
||||
OPCODE_BREAK;
|
||||
@ -752,13 +749,13 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
OPCODE(OPCODE_ASSIGN_TYPED_BUILTIN) {
|
||||
|
||||
CHECK_SPACE(4);
|
||||
Variant::Type var_type = (Variant::Type)_code_ptr[ip + 1];
|
||||
GET_VARIANT_PTR(dst, 2);
|
||||
GET_VARIANT_PTR(src, 3);
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
Variant::Type var_type = (Variant::Type)_code_ptr[ip + 1];
|
||||
GD_ERR_BREAK(var_type < 0 || var_type >= Variant::VARIANT_MAX);
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (src->get_type() != var_type) {
|
||||
if (Variant::can_convert_strict(src->get_type(), var_type)) {
|
||||
Variant::CallError ce;
|
||||
@ -1282,10 +1279,11 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
OPCODE_BREAK;
|
||||
}
|
||||
#endif
|
||||
|
||||
Object *obj = argobj->operator Object *();
|
||||
String signal = argname->operator String();
|
||||
#ifdef DEBUG_ENABLED
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (!obj) {
|
||||
err_text = "First argument of yield() is null.";
|
||||
OPCODE_BREAK;
|
||||
@ -1302,13 +1300,13 @@ Variant GDScriptFunction::call(GDScriptInstance *p_instance, const Variant **p_a
|
||||
OPCODE_BREAK;
|
||||
}
|
||||
|
||||
#endif
|
||||
Error err = obj->connect(signal, gdfs.ptr(), "_signal_callback", varray(gdfs), Object::CONNECT_ONESHOT);
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (err != OK) {
|
||||
err_text = "Error connecting to signal: " + signal + " during yield().";
|
||||
OPCODE_BREAK;
|
||||
}
|
||||
#else
|
||||
obj->connect(signal, gdfs.ptr(), "_signal_callback", varray(gdfs), Object::CONNECT_ONESHOT);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -56,7 +56,9 @@ T *GDScriptParser::alloc_node() {
|
||||
return t;
|
||||
}
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
static String _find_function_name(const GDScriptParser::OperatorNode *p_call);
|
||||
#endif // DEBUG_ENABLED
|
||||
|
||||
bool GDScriptParser::_end_statement() {
|
||||
|
||||
@ -747,7 +749,6 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
|
||||
while (!bfn && b) {
|
||||
if (b->variables.has(identifier)) {
|
||||
IdentifierNode *id = alloc_node<IdentifierNode>();
|
||||
LocalVarNode *lv = b->variables[identifier];
|
||||
id->name = identifier;
|
||||
id->declared_block = b;
|
||||
id->line = id_line;
|
||||
@ -755,6 +756,7 @@ GDScriptParser::Node *GDScriptParser::_parse_expression(Node *p_parent, bool p_s
|
||||
bfn = true;
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
LocalVarNode *lv = b->variables[identifier];
|
||||
switch (tokenizer->get_token()) {
|
||||
case GDScriptTokenizer::TK_OP_ASSIGN_ADD:
|
||||
case GDScriptTokenizer::TK_OP_ASSIGN_BIT_AND:
|
||||
|
@ -1042,7 +1042,7 @@ void GraphEdit::set_connection_activity(const StringName &p_from, int p_from_por
|
||||
|
||||
if (E->get().from == p_from && E->get().from_port == p_from_port && E->get().to == p_to && E->get().to_port == p_to_port) {
|
||||
|
||||
if (ABS(E->get().activity != p_activity)) {
|
||||
if (ABS(E->get().activity - p_activity) < CMP_EPSILON) {
|
||||
//update only if changed
|
||||
top_layer->update();
|
||||
connections_layer->update();
|
||||
|
@ -2488,6 +2488,7 @@ void Node::_set_tree(SceneTree *p_tree) {
|
||||
tree_changed_b->tree_changed();
|
||||
}
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
static void _Node_debug_sn(Object *p_obj) {
|
||||
|
||||
Node *n = Object::cast_to<Node>(p_obj);
|
||||
@ -2509,6 +2510,7 @@ static void _Node_debug_sn(Object *p_obj) {
|
||||
path = String(p->get_name()) + "/" + p->get_path_to(n);
|
||||
print_line(itos(p_obj->get_instance_id()) + " - Stray Node: " + path + " (Type: " + n->get_class() + ")");
|
||||
}
|
||||
#endif // DEBUG_ENABLED
|
||||
|
||||
void Node::_print_stray_nodes() {
|
||||
|
||||
@ -2518,7 +2520,6 @@ void Node::_print_stray_nodes() {
|
||||
void Node::print_stray_nodes() {
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
|
||||
ObjectDB::debug_objects(_Node_debug_sn);
|
||||
#endif
|
||||
}
|
||||
|
@ -286,7 +286,7 @@ private:
|
||||
mk.key = 0;
|
||||
for (int i = 0; i < FEATURE_MAX; i++) {
|
||||
if (features[i]) {
|
||||
mk.feature_mask |= (1 << i);
|
||||
mk.feature_mask |= ((uint64_t)1 << i);
|
||||
}
|
||||
}
|
||||
mk.detail_uv = detail_uv;
|
||||
@ -295,7 +295,7 @@ private:
|
||||
mk.cull_mode = cull_mode;
|
||||
for (int i = 0; i < FLAG_MAX; i++) {
|
||||
if (flags[i]) {
|
||||
mk.flags |= (1 << i);
|
||||
mk.flags |= ((uint64_t)1 << i);
|
||||
}
|
||||
}
|
||||
mk.detail_blend_mode = detail_blend_mode;
|
||||
|
Loading…
Reference in New Issue
Block a user