Merge pull request #38621 from akien-mga/stylé-comme-jamais
Style: clang-format: Disable if statements and case labels on single line
This commit is contained in:
commit
6ab92464bc
@ -13,9 +13,9 @@ AlignAfterOpenBracket: DontAlign
|
||||
AlignTrailingComments: false
|
||||
AllowAllParametersOfDeclarationOnNextLine: false
|
||||
# AllowShortBlocksOnASingleLine: false
|
||||
AllowShortCaseLabelsOnASingleLine: true
|
||||
# AllowShortCaseLabelsOnASingleLine: false
|
||||
AllowShortFunctionsOnASingleLine: Inline
|
||||
AllowShortIfStatementsOnASingleLine: true
|
||||
# AllowShortIfStatementsOnASingleLine: false
|
||||
# AllowShortLoopsOnASingleLine: false
|
||||
# AlwaysBreakAfterDefinitionReturnType: None
|
||||
# AlwaysBreakAfterReturnType: None
|
||||
|
@ -1456,16 +1456,19 @@ Variant ClassDB::class_get_default_property_value(const StringName &p_class, con
|
||||
}
|
||||
|
||||
if (!default_values.has(p_class)) {
|
||||
if (r_valid != nullptr) *r_valid = false;
|
||||
if (r_valid != nullptr)
|
||||
*r_valid = false;
|
||||
return Variant();
|
||||
}
|
||||
|
||||
if (!default_values[p_class].has(p_property)) {
|
||||
if (r_valid != nullptr) *r_valid = false;
|
||||
if (r_valid != nullptr)
|
||||
*r_valid = false;
|
||||
return Variant();
|
||||
}
|
||||
|
||||
if (r_valid != nullptr) *r_valid = true;
|
||||
if (r_valid != nullptr)
|
||||
*r_valid = true;
|
||||
return default_values[p_class][p_property];
|
||||
}
|
||||
|
||||
|
@ -406,7 +406,8 @@ bool Color::html_is_valid(const String &p_color) {
|
||||
}
|
||||
|
||||
Color Color::named(const String &p_name) {
|
||||
if (_named_colors.empty()) _populate_named_colors(); // from color_names.inc
|
||||
if (_named_colors.empty())
|
||||
_populate_named_colors(); // from color_names.inc
|
||||
String name = p_name;
|
||||
// Normalize name
|
||||
name = name.replace(" ", "");
|
||||
|
@ -3,7 +3,8 @@
|
||||
|
||||
static Map<String, Color> _named_colors;
|
||||
static void _populate_named_colors() {
|
||||
if (!_named_colors.empty()) return;
|
||||
if (!_named_colors.empty())
|
||||
return;
|
||||
_named_colors.insert("aliceblue", Color(0.94, 0.97, 1.00));
|
||||
_named_colors.insert("antiquewhite", Color(0.98, 0.92, 0.84));
|
||||
_named_colors.insert("aqua", Color(0.00, 1.00, 1.00));
|
||||
|
@ -253,7 +253,8 @@
|
||||
cmd->method = p_method; \
|
||||
SEMIC_SEP_LIST(CMD_ASSIGN_PARAM, N); \
|
||||
unlock(); \
|
||||
if (sync) sync->post(); \
|
||||
if (sync) \
|
||||
sync->post(); \
|
||||
}
|
||||
|
||||
#define CMD_RET_TYPE(N) CommandRet##N<T, M, COMMA_SEP_LIST(TYPE_ARG, N) COMMA(N) R>
|
||||
@ -269,7 +270,8 @@
|
||||
cmd->ret = r_ret; \
|
||||
cmd->sync_sem = ss; \
|
||||
unlock(); \
|
||||
if (sync) sync->post(); \
|
||||
if (sync) \
|
||||
sync->post(); \
|
||||
ss->sem.wait(); \
|
||||
ss->in_use = false; \
|
||||
}
|
||||
@ -286,7 +288,8 @@
|
||||
SEMIC_SEP_LIST(CMD_ASSIGN_PARAM, N); \
|
||||
cmd->sync_sem = ss; \
|
||||
unlock(); \
|
||||
if (sync) sync->post(); \
|
||||
if (sync) \
|
||||
sync->post(); \
|
||||
ss->sem.wait(); \
|
||||
ss->in_use = false; \
|
||||
}
|
||||
@ -418,12 +421,14 @@ class CommandQueueMT {
|
||||
}
|
||||
|
||||
bool flush_one(bool p_lock = true) {
|
||||
if (p_lock) lock();
|
||||
if (p_lock)
|
||||
lock();
|
||||
tryagain:
|
||||
|
||||
// tried to read an empty queue
|
||||
if (read_ptr == write_ptr) {
|
||||
if (p_lock) unlock();
|
||||
if (p_lock)
|
||||
unlock();
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -442,15 +447,18 @@ class CommandQueueMT {
|
||||
|
||||
read_ptr += size;
|
||||
|
||||
if (p_lock) unlock();
|
||||
if (p_lock)
|
||||
unlock();
|
||||
cmd->call();
|
||||
if (p_lock) lock();
|
||||
if (p_lock)
|
||||
lock();
|
||||
|
||||
cmd->post();
|
||||
cmd->~CommandBase();
|
||||
*(uint32_t *)&command_mem[size_ptr] &= ~1;
|
||||
|
||||
if (p_lock) unlock();
|
||||
if (p_lock)
|
||||
unlock();
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* container_type_validate.h */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#ifndef CONTAINER_TYPE_VALIDATE_H
|
||||
#define CONTAINER_TYPE_VALIDATE_H
|
||||
|
||||
|
499
core/image.cpp
499
core/image.cpp
@ -114,23 +114,36 @@ int Image::get_format_pixel_size(Format p_format) {
|
||||
return 1; //luminance
|
||||
case FORMAT_LA8:
|
||||
return 2; //luminance-alpha
|
||||
case FORMAT_R8: return 1;
|
||||
case FORMAT_RG8: return 2;
|
||||
case FORMAT_RGB8: return 3;
|
||||
case FORMAT_RGBA8: return 4;
|
||||
case FORMAT_RGBA4444: return 2;
|
||||
case FORMAT_RGB565: return 2;
|
||||
case FORMAT_R8:
|
||||
return 1;
|
||||
case FORMAT_RG8:
|
||||
return 2;
|
||||
case FORMAT_RGB8:
|
||||
return 3;
|
||||
case FORMAT_RGBA8:
|
||||
return 4;
|
||||
case FORMAT_RGBA4444:
|
||||
return 2;
|
||||
case FORMAT_RGB565:
|
||||
return 2;
|
||||
case FORMAT_RF:
|
||||
return 4; //float
|
||||
case FORMAT_RGF: return 8;
|
||||
case FORMAT_RGBF: return 12;
|
||||
case FORMAT_RGBAF: return 16;
|
||||
case FORMAT_RGF:
|
||||
return 8;
|
||||
case FORMAT_RGBF:
|
||||
return 12;
|
||||
case FORMAT_RGBAF:
|
||||
return 16;
|
||||
case FORMAT_RH:
|
||||
return 2; //half float
|
||||
case FORMAT_RGH: return 4;
|
||||
case FORMAT_RGBH: return 6;
|
||||
case FORMAT_RGBAH: return 8;
|
||||
case FORMAT_RGBE9995: return 4;
|
||||
case FORMAT_RGH:
|
||||
return 4;
|
||||
case FORMAT_RGBH:
|
||||
return 6;
|
||||
case FORMAT_RGBAH:
|
||||
return 8;
|
||||
case FORMAT_RGBE9995:
|
||||
return 4;
|
||||
case FORMAT_DXT1:
|
||||
return 1; //s3tc bc1
|
||||
case FORMAT_DXT3:
|
||||
@ -149,22 +162,32 @@ int Image::get_format_pixel_size(Format p_format) {
|
||||
return 1; //unsigned float
|
||||
case FORMAT_PVRTC2:
|
||||
return 1; //pvrtc
|
||||
case FORMAT_PVRTC2A: return 1;
|
||||
case FORMAT_PVRTC4: return 1;
|
||||
case FORMAT_PVRTC4A: return 1;
|
||||
case FORMAT_PVRTC2A:
|
||||
return 1;
|
||||
case FORMAT_PVRTC4:
|
||||
return 1;
|
||||
case FORMAT_PVRTC4A:
|
||||
return 1;
|
||||
case FORMAT_ETC:
|
||||
return 1; //etc1
|
||||
case FORMAT_ETC2_R11:
|
||||
return 1; //etc2
|
||||
case FORMAT_ETC2_R11S:
|
||||
return 1; //signed: return 1; NOT srgb.
|
||||
case FORMAT_ETC2_RG11: return 1;
|
||||
case FORMAT_ETC2_RG11S: return 1;
|
||||
case FORMAT_ETC2_RGB8: return 1;
|
||||
case FORMAT_ETC2_RGBA8: return 1;
|
||||
case FORMAT_ETC2_RGB8A1: return 1;
|
||||
case FORMAT_ETC2_RA_AS_RG: return 1;
|
||||
case FORMAT_DXT5_RA_AS_RG: return 1;
|
||||
case FORMAT_ETC2_RG11:
|
||||
return 1;
|
||||
case FORMAT_ETC2_RG11S:
|
||||
return 1;
|
||||
case FORMAT_ETC2_RGB8:
|
||||
return 1;
|
||||
case FORMAT_ETC2_RGBA8:
|
||||
return 1;
|
||||
case FORMAT_ETC2_RGB8A1:
|
||||
return 1;
|
||||
case FORMAT_ETC2_RA_AS_RG:
|
||||
return 1;
|
||||
case FORMAT_DXT5_RA_AS_RG:
|
||||
return 1;
|
||||
case FORMAT_MAX: {
|
||||
}
|
||||
}
|
||||
@ -478,36 +501,96 @@ void Image::convert(Format p_new_format) {
|
||||
|
||||
switch (conversion_type) {
|
||||
|
||||
case FORMAT_L8 | (FORMAT_LA8 << 8): _convert<1, false, 1, true, true, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_L8 | (FORMAT_R8 << 8): _convert<1, false, 1, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_L8 | (FORMAT_RG8 << 8): _convert<1, false, 2, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_L8 | (FORMAT_RGB8 << 8): _convert<1, false, 3, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_L8 | (FORMAT_RGBA8 << 8): _convert<1, false, 3, true, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_LA8 | (FORMAT_L8 << 8): _convert<1, true, 1, false, true, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_LA8 | (FORMAT_R8 << 8): _convert<1, true, 1, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_LA8 | (FORMAT_RG8 << 8): _convert<1, true, 2, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_LA8 | (FORMAT_RGB8 << 8): _convert<1, true, 3, false, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_LA8 | (FORMAT_RGBA8 << 8): _convert<1, true, 3, true, true, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_R8 | (FORMAT_L8 << 8): _convert<1, false, 1, false, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_R8 | (FORMAT_LA8 << 8): _convert<1, false, 1, true, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_R8 | (FORMAT_RG8 << 8): _convert<1, false, 2, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_R8 | (FORMAT_RGB8 << 8): _convert<1, false, 3, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_R8 | (FORMAT_RGBA8 << 8): _convert<1, false, 3, true, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RG8 | (FORMAT_L8 << 8): _convert<2, false, 1, false, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RG8 | (FORMAT_LA8 << 8): _convert<2, false, 1, true, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RG8 | (FORMAT_R8 << 8): _convert<2, false, 1, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RG8 | (FORMAT_RGB8 << 8): _convert<2, false, 3, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RG8 | (FORMAT_RGBA8 << 8): _convert<2, false, 3, true, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGB8 | (FORMAT_L8 << 8): _convert<3, false, 1, false, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGB8 | (FORMAT_LA8 << 8): _convert<3, false, 1, true, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGB8 | (FORMAT_R8 << 8): _convert<3, false, 1, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGB8 | (FORMAT_RG8 << 8): _convert<3, false, 2, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGB8 | (FORMAT_RGBA8 << 8): _convert<3, false, 3, true, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGBA8 | (FORMAT_L8 << 8): _convert<3, true, 1, false, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGBA8 | (FORMAT_LA8 << 8): _convert<3, true, 1, true, false, true>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGBA8 | (FORMAT_R8 << 8): _convert<3, true, 1, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGBA8 | (FORMAT_RG8 << 8): _convert<3, true, 2, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_RGBA8 | (FORMAT_RGB8 << 8): _convert<3, true, 3, false, false, false>(width, height, rptr, wptr); break;
|
||||
case FORMAT_L8 | (FORMAT_LA8 << 8):
|
||||
_convert<1, false, 1, true, true, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_L8 | (FORMAT_R8 << 8):
|
||||
_convert<1, false, 1, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_L8 | (FORMAT_RG8 << 8):
|
||||
_convert<1, false, 2, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_L8 | (FORMAT_RGB8 << 8):
|
||||
_convert<1, false, 3, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_L8 | (FORMAT_RGBA8 << 8):
|
||||
_convert<1, false, 3, true, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_LA8 | (FORMAT_L8 << 8):
|
||||
_convert<1, true, 1, false, true, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_LA8 | (FORMAT_R8 << 8):
|
||||
_convert<1, true, 1, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_LA8 | (FORMAT_RG8 << 8):
|
||||
_convert<1, true, 2, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_LA8 | (FORMAT_RGB8 << 8):
|
||||
_convert<1, true, 3, false, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_LA8 | (FORMAT_RGBA8 << 8):
|
||||
_convert<1, true, 3, true, true, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_R8 | (FORMAT_L8 << 8):
|
||||
_convert<1, false, 1, false, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_R8 | (FORMAT_LA8 << 8):
|
||||
_convert<1, false, 1, true, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_R8 | (FORMAT_RG8 << 8):
|
||||
_convert<1, false, 2, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_R8 | (FORMAT_RGB8 << 8):
|
||||
_convert<1, false, 3, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_R8 | (FORMAT_RGBA8 << 8):
|
||||
_convert<1, false, 3, true, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RG8 | (FORMAT_L8 << 8):
|
||||
_convert<2, false, 1, false, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RG8 | (FORMAT_LA8 << 8):
|
||||
_convert<2, false, 1, true, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RG8 | (FORMAT_R8 << 8):
|
||||
_convert<2, false, 1, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RG8 | (FORMAT_RGB8 << 8):
|
||||
_convert<2, false, 3, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RG8 | (FORMAT_RGBA8 << 8):
|
||||
_convert<2, false, 3, true, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGB8 | (FORMAT_L8 << 8):
|
||||
_convert<3, false, 1, false, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGB8 | (FORMAT_LA8 << 8):
|
||||
_convert<3, false, 1, true, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGB8 | (FORMAT_R8 << 8):
|
||||
_convert<3, false, 1, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGB8 | (FORMAT_RG8 << 8):
|
||||
_convert<3, false, 2, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGB8 | (FORMAT_RGBA8 << 8):
|
||||
_convert<3, false, 3, true, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGBA8 | (FORMAT_L8 << 8):
|
||||
_convert<3, true, 1, false, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGBA8 | (FORMAT_LA8 << 8):
|
||||
_convert<3, true, 1, true, false, true>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGBA8 | (FORMAT_R8 << 8):
|
||||
_convert<3, true, 1, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGBA8 | (FORMAT_RG8 << 8):
|
||||
_convert<3, true, 2, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
case FORMAT_RGBA8 | (FORMAT_RGB8 << 8):
|
||||
_convert<3, true, 3, false, false, false>(width, height, rptr, wptr);
|
||||
break;
|
||||
}
|
||||
|
||||
bool gen_mipmaps = mipmaps;
|
||||
@ -949,25 +1032,49 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
|
||||
if (format >= FORMAT_L8 && format <= FORMAT_RGBA8) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 1: _scale_nearest<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2: _scale_nearest<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 3: _scale_nearest<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_nearest<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 1:
|
||||
_scale_nearest<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 2:
|
||||
_scale_nearest<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 3:
|
||||
_scale_nearest<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_nearest<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RF && format <= FORMAT_RGBAF) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 4: _scale_nearest<1, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_nearest<2, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 12: _scale_nearest<3, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 16: _scale_nearest<4, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4:
|
||||
_scale_nearest<1, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_nearest<2, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 12:
|
||||
_scale_nearest<3, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 16:
|
||||
_scale_nearest<4, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
|
||||
} else if (format >= FORMAT_RH && format <= FORMAT_RGBAH) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 2: _scale_nearest<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_nearest<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 6: _scale_nearest<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_nearest<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2:
|
||||
_scale_nearest<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_nearest<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 6:
|
||||
_scale_nearest<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_nearest<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1013,24 +1120,48 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
|
||||
if (format >= FORMAT_L8 && format <= FORMAT_RGBA8) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 1: _scale_bilinear<1, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 2: _scale_bilinear<2, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 3: _scale_bilinear<3, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 4: _scale_bilinear<4, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 1:
|
||||
_scale_bilinear<1, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 2:
|
||||
_scale_bilinear<2, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 3:
|
||||
_scale_bilinear<3, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_bilinear<4, uint8_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RF && format <= FORMAT_RGBAF) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 4: _scale_bilinear<1, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 8: _scale_bilinear<2, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 12: _scale_bilinear<3, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 16: _scale_bilinear<4, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 4:
|
||||
_scale_bilinear<1, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_bilinear<2, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 12:
|
||||
_scale_bilinear<3, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 16:
|
||||
_scale_bilinear<4, float>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RH && format <= FORMAT_RGBAH) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 2: _scale_bilinear<1, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 4: _scale_bilinear<2, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 6: _scale_bilinear<3, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 8: _scale_bilinear<4, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height); break;
|
||||
case 2:
|
||||
_scale_bilinear<1, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_bilinear<2, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 6:
|
||||
_scale_bilinear<3, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_bilinear<4, uint16_t>(src_ptr, w_ptr, src_width, src_height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1046,24 +1177,48 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
|
||||
if (format >= FORMAT_L8 && format <= FORMAT_RGBA8) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 1: _scale_cubic<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2: _scale_cubic<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 3: _scale_cubic<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_cubic<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 1:
|
||||
_scale_cubic<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 2:
|
||||
_scale_cubic<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 3:
|
||||
_scale_cubic<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_cubic<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RF && format <= FORMAT_RGBAF) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 4: _scale_cubic<1, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_cubic<2, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 12: _scale_cubic<3, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 16: _scale_cubic<4, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4:
|
||||
_scale_cubic<1, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_cubic<2, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 12:
|
||||
_scale_cubic<3, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 16:
|
||||
_scale_cubic<4, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RH && format <= FORMAT_RGBAH) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 2: _scale_cubic<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_cubic<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 6: _scale_cubic<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_cubic<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2:
|
||||
_scale_cubic<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_cubic<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 6:
|
||||
_scale_cubic<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_cubic<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
}
|
||||
} break;
|
||||
@ -1071,24 +1226,48 @@ void Image::resize(int p_width, int p_height, Interpolation p_interpolation) {
|
||||
|
||||
if (format >= FORMAT_L8 && format <= FORMAT_RGBA8) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 1: _scale_lanczos<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2: _scale_lanczos<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 3: _scale_lanczos<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_lanczos<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 1:
|
||||
_scale_lanczos<1, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 2:
|
||||
_scale_lanczos<2, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 3:
|
||||
_scale_lanczos<3, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_lanczos<4, uint8_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RF && format <= FORMAT_RGBAF) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 4: _scale_lanczos<1, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_lanczos<2, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 12: _scale_lanczos<3, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 16: _scale_lanczos<4, float>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4:
|
||||
_scale_lanczos<1, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_lanczos<2, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 12:
|
||||
_scale_lanczos<3, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 16:
|
||||
_scale_lanczos<4, float>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
} else if (format >= FORMAT_RH && format <= FORMAT_RGBAH) {
|
||||
switch (get_format_pixel_size(format)) {
|
||||
case 2: _scale_lanczos<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 4: _scale_lanczos<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 6: _scale_lanczos<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 8: _scale_lanczos<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height); break;
|
||||
case 2:
|
||||
_scale_lanczos<1, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 4:
|
||||
_scale_lanczos<2, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 6:
|
||||
_scale_lanczos<3, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
case 8:
|
||||
_scale_lanczos<4, uint16_t>(r_ptr, w_ptr, width, height, p_width, p_height);
|
||||
break;
|
||||
}
|
||||
}
|
||||
} break;
|
||||
@ -1403,23 +1582,51 @@ void Image::shrink_x2() {
|
||||
switch (format) {
|
||||
|
||||
case FORMAT_L8:
|
||||
case FORMAT_R8: _generate_po2_mipmap<uint8_t, 1, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height); break;
|
||||
case FORMAT_LA8: _generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height); break;
|
||||
case FORMAT_RG8: _generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height); break;
|
||||
case FORMAT_RGB8: _generate_po2_mipmap<uint8_t, 3, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height); break;
|
||||
case FORMAT_RGBA8: _generate_po2_mipmap<uint8_t, 4, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height); break;
|
||||
case FORMAT_R8:
|
||||
_generate_po2_mipmap<uint8_t, 1, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height);
|
||||
break;
|
||||
case FORMAT_LA8:
|
||||
_generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height);
|
||||
break;
|
||||
case FORMAT_RG8:
|
||||
_generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height);
|
||||
break;
|
||||
case FORMAT_RGB8:
|
||||
_generate_po2_mipmap<uint8_t, 3, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height);
|
||||
break;
|
||||
case FORMAT_RGBA8:
|
||||
_generate_po2_mipmap<uint8_t, 4, false, Image::average_4_uint8, Image::renormalize_uint8>(r, w, width, height);
|
||||
break;
|
||||
|
||||
case FORMAT_RF: _generate_po2_mipmap<float, 1, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height); break;
|
||||
case FORMAT_RGF: _generate_po2_mipmap<float, 2, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height); break;
|
||||
case FORMAT_RGBF: _generate_po2_mipmap<float, 3, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height); break;
|
||||
case FORMAT_RGBAF: _generate_po2_mipmap<float, 4, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height); break;
|
||||
case FORMAT_RF:
|
||||
_generate_po2_mipmap<float, 1, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGF:
|
||||
_generate_po2_mipmap<float, 2, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGBF:
|
||||
_generate_po2_mipmap<float, 3, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGBAF:
|
||||
_generate_po2_mipmap<float, 4, false, Image::average_4_float, Image::renormalize_float>(reinterpret_cast<const float *>(r), reinterpret_cast<float *>(w), width, height);
|
||||
break;
|
||||
|
||||
case FORMAT_RH: _generate_po2_mipmap<uint16_t, 1, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height); break;
|
||||
case FORMAT_RGH: _generate_po2_mipmap<uint16_t, 2, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height); break;
|
||||
case FORMAT_RGBH: _generate_po2_mipmap<uint16_t, 3, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height); break;
|
||||
case FORMAT_RGBAH: _generate_po2_mipmap<uint16_t, 4, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height); break;
|
||||
case FORMAT_RH:
|
||||
_generate_po2_mipmap<uint16_t, 1, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGH:
|
||||
_generate_po2_mipmap<uint16_t, 2, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGBH:
|
||||
_generate_po2_mipmap<uint16_t, 3, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height);
|
||||
break;
|
||||
case FORMAT_RGBAH:
|
||||
_generate_po2_mipmap<uint16_t, 4, false, Image::average_4_half, Image::renormalize_half>(reinterpret_cast<const uint16_t *>(r), reinterpret_cast<uint16_t *>(w), width, height);
|
||||
break;
|
||||
|
||||
case FORMAT_RGBE9995: _generate_po2_mipmap<uint32_t, 1, false, Image::average_4_rgbe9995, Image::renormalize_rgbe9995>(reinterpret_cast<const uint32_t *>(r), reinterpret_cast<uint32_t *>(w), width, height); break;
|
||||
case FORMAT_RGBE9995:
|
||||
_generate_po2_mipmap<uint32_t, 1, false, Image::average_4_rgbe9995, Image::renormalize_rgbe9995>(reinterpret_cast<const uint32_t *>(r), reinterpret_cast<uint32_t *>(w), width, height);
|
||||
break;
|
||||
default: {
|
||||
}
|
||||
}
|
||||
@ -1485,9 +1692,13 @@ Error Image::generate_mipmaps(bool p_renormalize) {
|
||||
switch (format) {
|
||||
|
||||
case FORMAT_L8:
|
||||
case FORMAT_R8: _generate_po2_mipmap<uint8_t, 1, false, Image::average_4_uint8, Image::renormalize_uint8>(&wp[prev_ofs], &wp[ofs], prev_w, prev_h); break;
|
||||
case FORMAT_R8:
|
||||
_generate_po2_mipmap<uint8_t, 1, false, Image::average_4_uint8, Image::renormalize_uint8>(&wp[prev_ofs], &wp[ofs], prev_w, prev_h);
|
||||
break;
|
||||
case FORMAT_LA8:
|
||||
case FORMAT_RG8: _generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(&wp[prev_ofs], &wp[ofs], prev_w, prev_h); break;
|
||||
case FORMAT_RG8:
|
||||
_generate_po2_mipmap<uint8_t, 2, false, Image::average_4_uint8, Image::renormalize_uint8>(&wp[prev_ofs], &wp[ofs], prev_w, prev_h);
|
||||
break;
|
||||
case FORMAT_RGB8:
|
||||
if (p_renormalize)
|
||||
_generate_po2_mipmap<uint8_t, 3, true, Image::average_4_uint8, Image::renormalize_uint8>(&wp[prev_ofs], &wp[ofs], prev_w, prev_h);
|
||||
@ -1911,12 +2122,24 @@ void Image::create(const char **p_xpm) {
|
||||
break;
|
||||
|
||||
switch (i) {
|
||||
case 0: col_r = v << 4; break;
|
||||
case 1: col_r |= v; break;
|
||||
case 2: col_g = v << 4; break;
|
||||
case 3: col_g |= v; break;
|
||||
case 4: col_b = v << 4; break;
|
||||
case 5: col_b |= v; break;
|
||||
case 0:
|
||||
col_r = v << 4;
|
||||
break;
|
||||
case 1:
|
||||
col_r |= v;
|
||||
break;
|
||||
case 2:
|
||||
col_g = v << 4;
|
||||
break;
|
||||
case 3:
|
||||
col_g |= v;
|
||||
break;
|
||||
case 4:
|
||||
col_b = v << 4;
|
||||
break;
|
||||
case 5:
|
||||
col_b |= v;
|
||||
break;
|
||||
};
|
||||
}
|
||||
|
||||
@ -2901,12 +3124,24 @@ Image::UsedChannels Image::detect_used_channels(CompressSource p_source) {
|
||||
|
||||
void Image::optimize_channels() {
|
||||
switch (detect_used_channels()) {
|
||||
case USED_CHANNELS_L: convert(FORMAT_L8); break;
|
||||
case USED_CHANNELS_LA: convert(FORMAT_LA8); break;
|
||||
case USED_CHANNELS_R: convert(FORMAT_R8); break;
|
||||
case USED_CHANNELS_RG: convert(FORMAT_RG8); break;
|
||||
case USED_CHANNELS_RGB: convert(FORMAT_RGB8); break;
|
||||
case USED_CHANNELS_RGBA: convert(FORMAT_RGBA8); break;
|
||||
case USED_CHANNELS_L:
|
||||
convert(FORMAT_L8);
|
||||
break;
|
||||
case USED_CHANNELS_LA:
|
||||
convert(FORMAT_LA8);
|
||||
break;
|
||||
case USED_CHANNELS_R:
|
||||
convert(FORMAT_R8);
|
||||
break;
|
||||
case USED_CHANNELS_RG:
|
||||
convert(FORMAT_RG8);
|
||||
break;
|
||||
case USED_CHANNELS_RGB:
|
||||
convert(FORMAT_RGB8);
|
||||
break;
|
||||
case USED_CHANNELS_RGBA:
|
||||
convert(FORMAT_RGBA8);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -3152,11 +3387,13 @@ void Image::bumpmap_to_normalmap(float bump_scale) {
|
||||
|
||||
for (int ty = 0; ty < height; ty++) {
|
||||
int py = ty + 1;
|
||||
if (py >= height) py -= height;
|
||||
if (py >= height)
|
||||
py -= height;
|
||||
|
||||
for (int tx = 0; tx < width; tx++) {
|
||||
int px = tx + 1;
|
||||
if (px >= width) px -= width;
|
||||
if (px >= width)
|
||||
px -= width;
|
||||
float here = read_ptr[ty * width + tx];
|
||||
float to_right = read_ptr[ty * width + px];
|
||||
float above = read_ptr[py * width + tx];
|
||||
|
@ -414,7 +414,8 @@ Error DirAccessPack::change_dir(String p_dir) {
|
||||
|
||||
nd = nd.simplify_path();
|
||||
|
||||
if (nd == "") nd = ".";
|
||||
if (nd == "")
|
||||
nd = ".";
|
||||
|
||||
if (nd.begins_with("/")) {
|
||||
nd = nd.replace_first("/", "");
|
||||
|
@ -52,16 +52,20 @@ protected:
|
||||
public:
|
||||
//operator Variant() const;
|
||||
bool operator==(const IP_Address &p_ip) const {
|
||||
if (p_ip.valid != valid) return false;
|
||||
if (!valid) return false;
|
||||
if (p_ip.valid != valid)
|
||||
return false;
|
||||
if (!valid)
|
||||
return false;
|
||||
for (int i = 0; i < 4; i++)
|
||||
if (field32[i] != p_ip.field32[i])
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
bool operator!=(const IP_Address &p_ip) const {
|
||||
if (p_ip.valid != valid) return true;
|
||||
if (!valid) return true;
|
||||
if (p_ip.valid != valid)
|
||||
return true;
|
||||
if (!valid)
|
||||
return true;
|
||||
for (int i = 0; i < 4; i++)
|
||||
if (field32[i] != p_ip.field32[i])
|
||||
return true;
|
||||
|
@ -67,10 +67,14 @@ String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_
|
||||
|
||||
switch (p_var.get_type()) {
|
||||
|
||||
case Variant::NIL: return "null";
|
||||
case Variant::BOOL: return p_var.operator bool() ? "true" : "false";
|
||||
case Variant::INT: return itos(p_var);
|
||||
case Variant::FLOAT: return rtos(p_var);
|
||||
case Variant::NIL:
|
||||
return "null";
|
||||
case Variant::BOOL:
|
||||
return p_var.operator bool() ? "true" : "false";
|
||||
case Variant::INT:
|
||||
return itos(p_var);
|
||||
case Variant::FLOAT:
|
||||
return rtos(p_var);
|
||||
case Variant::PACKED_INT32_ARRAY:
|
||||
case Variant::PACKED_INT64_ARRAY:
|
||||
case Variant::PACKED_FLOAT32_ARRAY:
|
||||
@ -116,7 +120,8 @@ String JSON::_print_var(const Variant &p_var, const String &p_indent, int p_cur_
|
||||
s += end_statement + _make_indent(p_indent, p_cur_indent) + "}";
|
||||
return s;
|
||||
};
|
||||
default: return "\"" + String(p_var).json_escape() + "\"";
|
||||
default:
|
||||
return "\"" + String(p_var).json_escape() + "\"";
|
||||
}
|
||||
}
|
||||
|
||||
@ -199,11 +204,21 @@ Error JSON::_get_token(const CharType *p_str, int &index, int p_len, Token &r_to
|
||||
|
||||
switch (next) {
|
||||
|
||||
case 'b': res = 8; break;
|
||||
case 't': res = 9; break;
|
||||
case 'n': res = 10; break;
|
||||
case 'f': res = 12; break;
|
||||
case 'r': res = 13; break;
|
||||
case 'b':
|
||||
res = 8;
|
||||
break;
|
||||
case 't':
|
||||
res = 9;
|
||||
break;
|
||||
case 'n':
|
||||
res = 10;
|
||||
break;
|
||||
case 'f':
|
||||
res = 12;
|
||||
break;
|
||||
case 'r':
|
||||
res = 13;
|
||||
break;
|
||||
case 'u': {
|
||||
// hex number
|
||||
for (int j = 0; j < 4; j++) {
|
||||
|
@ -49,11 +49,21 @@ void Logger::log_error(const char *p_function, const char *p_file, int p_line, c
|
||||
|
||||
const char *err_type = "ERROR";
|
||||
switch (p_type) {
|
||||
case ERR_ERROR: err_type = "ERROR"; break;
|
||||
case ERR_WARNING: err_type = "WARNING"; break;
|
||||
case ERR_SCRIPT: err_type = "SCRIPT ERROR"; break;
|
||||
case ERR_SHADER: err_type = "SHADER ERROR"; break;
|
||||
default: ERR_PRINT("Unknown error type"); break;
|
||||
case ERR_ERROR:
|
||||
err_type = "ERROR";
|
||||
break;
|
||||
case ERR_WARNING:
|
||||
err_type = "WARNING";
|
||||
break;
|
||||
case ERR_SCRIPT:
|
||||
err_type = "SCRIPT ERROR";
|
||||
break;
|
||||
case ERR_SHADER:
|
||||
err_type = "SHADER ERROR";
|
||||
break;
|
||||
default:
|
||||
ERR_PRINT("Unknown error type");
|
||||
break;
|
||||
}
|
||||
|
||||
const char *err_details;
|
||||
|
@ -121,7 +121,8 @@ static inline int encode_cstring(const char *p_string, uint8_t *p_data) {
|
||||
len++;
|
||||
};
|
||||
|
||||
if (p_data) *p_data = 0;
|
||||
if (p_data)
|
||||
*p_data = 0;
|
||||
return len + 1;
|
||||
}
|
||||
|
||||
|
@ -144,7 +144,8 @@ void MultiplayerAPI::set_root_node(Node *p_node) {
|
||||
|
||||
void MultiplayerAPI::set_network_peer(const Ref<NetworkedMultiplayerPeer> &p_peer) {
|
||||
|
||||
if (p_peer == network_peer) return; // Nothing to do
|
||||
if (p_peer == network_peer)
|
||||
return; // Nothing to do
|
||||
|
||||
ERR_FAIL_COND_MSG(p_peer.is_valid() && p_peer->get_connection_status() == NetworkedMultiplayerPeer::CONNECTION_DISCONNECTED,
|
||||
"Supplied NetworkedMultiplayerPeer must be connecting or connected.");
|
||||
@ -787,8 +788,9 @@ void MultiplayerAPI::_send_rpc(Node *p_from, int p_to, bool p_unreliable, bool p
|
||||
|
||||
int ofs = 0;
|
||||
|
||||
#define MAKE_ROOM(m_amount) \
|
||||
if (packet_cache.size() < m_amount) packet_cache.resize(m_amount);
|
||||
#define MAKE_ROOM(m_amount) \
|
||||
if (packet_cache.size() < m_amount) \
|
||||
packet_cache.resize(m_amount);
|
||||
|
||||
// Encode meta.
|
||||
// The meta is composed by a single byte that contains (starting from the least segnificant bit):
|
||||
|
@ -160,7 +160,8 @@ public:
|
||||
static bool get_timestamp_on_load() { return timestamp_on_load; }
|
||||
|
||||
static void notify_load_error(const String &p_err) {
|
||||
if (err_notify) err_notify(err_notify_ud, p_err);
|
||||
if (err_notify)
|
||||
err_notify(err_notify_ud, p_err);
|
||||
}
|
||||
static void set_error_notify_func(void *p_ud, ResourceLoadErrorNotify p_err_notify) {
|
||||
err_notify = p_err_notify;
|
||||
@ -168,7 +169,8 @@ public:
|
||||
}
|
||||
|
||||
static void notify_dependency_error(const String &p_path, const String &p_dependency, const String &p_type) {
|
||||
if (dep_err_notify) dep_err_notify(dep_err_notify_ud, p_path, p_dependency, p_type);
|
||||
if (dep_err_notify)
|
||||
dep_err_notify(dep_err_notify_ud, p_path, p_dependency, p_type);
|
||||
}
|
||||
static void set_dependency_error_notify_func(void *p_ud, DependencyErrorNotify p_err_notify) {
|
||||
dep_err_notify = p_err_notify;
|
||||
|
@ -353,7 +353,8 @@ public:
|
||||
|
||||
Element *it = front();
|
||||
while (it) {
|
||||
if (it->value == p_val) return it;
|
||||
if (it->value == p_val)
|
||||
return it;
|
||||
it = it->next();
|
||||
};
|
||||
|
||||
|
@ -164,7 +164,8 @@ void AStar::connect_points(int p_id, int p_with_id, bool bidirectional) {
|
||||
}
|
||||
|
||||
Segment s(p_id, p_with_id);
|
||||
if (bidirectional) s.direction = Segment::BIDIRECTIONAL;
|
||||
if (bidirectional)
|
||||
s.direction = Segment::BIDIRECTIONAL;
|
||||
|
||||
Set<Segment>::Element *element = segments.find(s);
|
||||
if (element != nullptr) {
|
||||
@ -290,7 +291,8 @@ int AStar::get_closest_point(const Vector3 &p_point, bool p_include_disabled) co
|
||||
|
||||
for (OAHashMap<int, Point *>::Iterator it = points.iter(); it.valid; it = points.next_iter(it)) {
|
||||
|
||||
if (!p_include_disabled && !(*it.value)->enabled) continue; // Disabled points should not be considered.
|
||||
if (!p_include_disabled && !(*it.value)->enabled)
|
||||
continue; // Disabled points should not be considered.
|
||||
|
||||
real_t d = p_point.distance_squared_to((*it.value)->pos);
|
||||
if (closest_id < 0 || d < closest_dist) {
|
||||
@ -340,7 +342,8 @@ bool AStar::_solve(Point *begin_point, Point *end_point) {
|
||||
|
||||
pass++;
|
||||
|
||||
if (!end_point->enabled) return false;
|
||||
if (!end_point->enabled)
|
||||
return false;
|
||||
|
||||
bool found_route = false;
|
||||
|
||||
@ -451,7 +454,8 @@ Vector<Vector3> AStar::get_point_path(int p_from_id, int p_to_id) {
|
||||
Point *end_point = b;
|
||||
|
||||
bool found_route = _solve(begin_point, end_point);
|
||||
if (!found_route) return Vector<Vector3>();
|
||||
if (!found_route)
|
||||
return Vector<Vector3>();
|
||||
|
||||
Point *p = end_point;
|
||||
int pc = 1; // Begin point
|
||||
@ -499,7 +503,8 @@ Vector<int> AStar::get_id_path(int p_from_id, int p_to_id) {
|
||||
Point *end_point = b;
|
||||
|
||||
bool found_route = _solve(begin_point, end_point);
|
||||
if (!found_route) return Vector<int>();
|
||||
if (!found_route)
|
||||
return Vector<int>();
|
||||
|
||||
Point *p = end_point;
|
||||
int pc = 1; // Begin point
|
||||
@ -729,7 +734,8 @@ Vector<Vector2> AStar2D::get_point_path(int p_from_id, int p_to_id) {
|
||||
AStar::Point *end_point = b;
|
||||
|
||||
bool found_route = _solve(begin_point, end_point);
|
||||
if (!found_route) return Vector<Vector2>();
|
||||
if (!found_route)
|
||||
return Vector<Vector2>();
|
||||
|
||||
AStar::Point *p = end_point;
|
||||
int pc = 1; // Begin point
|
||||
@ -777,7 +783,8 @@ Vector<int> AStar2D::get_id_path(int p_from_id, int p_to_id) {
|
||||
AStar::Point *end_point = b;
|
||||
|
||||
bool found_route = _solve(begin_point, end_point);
|
||||
if (!found_route) return Vector<int>();
|
||||
if (!found_route)
|
||||
return Vector<int>();
|
||||
|
||||
AStar::Point *p = end_point;
|
||||
int pc = 1; // Begin point
|
||||
@ -809,7 +816,8 @@ bool AStar2D::_solve(AStar::Point *begin_point, AStar::Point *end_point) {
|
||||
|
||||
astar.pass++;
|
||||
|
||||
if (!end_point->enabled) return false;
|
||||
if (!end_point->enabled)
|
||||
return false;
|
||||
|
||||
bool found_route = false;
|
||||
|
||||
|
@ -177,14 +177,22 @@ Vector3 AABB::get_support(const Vector3 &p_normal) const {
|
||||
Vector3 AABB::get_endpoint(int p_point) const {
|
||||
|
||||
switch (p_point) {
|
||||
case 0: return Vector3(position.x, position.y, position.z);
|
||||
case 1: return Vector3(position.x, position.y, position.z + size.z);
|
||||
case 2: return Vector3(position.x, position.y + size.y, position.z);
|
||||
case 3: return Vector3(position.x, position.y + size.y, position.z + size.z);
|
||||
case 4: return Vector3(position.x + size.x, position.y, position.z);
|
||||
case 5: return Vector3(position.x + size.x, position.y, position.z + size.z);
|
||||
case 6: return Vector3(position.x + size.x, position.y + size.y, position.z);
|
||||
case 7: return Vector3(position.x + size.x, position.y + size.y, position.z + size.z);
|
||||
case 0:
|
||||
return Vector3(position.x, position.y, position.z);
|
||||
case 1:
|
||||
return Vector3(position.x, position.y, position.z + size.z);
|
||||
case 2:
|
||||
return Vector3(position.x, position.y + size.y, position.z);
|
||||
case 3:
|
||||
return Vector3(position.x, position.y + size.y, position.z + size.z);
|
||||
case 4:
|
||||
return Vector3(position.x + size.x, position.y, position.z);
|
||||
case 5:
|
||||
return Vector3(position.x + size.x, position.y, position.z + size.z);
|
||||
case 6:
|
||||
return Vector3(position.x + size.x, position.y + size.y, position.z);
|
||||
case 7:
|
||||
return Vector3(position.x + size.x, position.y + size.y, position.z + size.z);
|
||||
};
|
||||
|
||||
ERR_FAIL_V(Vector3());
|
||||
|
@ -783,7 +783,8 @@ void Basis::get_axis_angle(Vector3 &r_axis, real_t &r_angle) const {
|
||||
real_t s = Math::sqrt((elements[1][2] - elements[2][1]) * (elements[1][2] - elements[2][1]) + (elements[2][0] - elements[0][2]) * (elements[2][0] - elements[0][2]) + (elements[0][1] - elements[1][0]) * (elements[0][1] - elements[1][0])); // s=|axis||sin(angle)|, used to normalise
|
||||
|
||||
angle = Math::acos((elements[0][0] + elements[1][1] + elements[2][2] - 1) / 2);
|
||||
if (angle < 0) s = -s;
|
||||
if (angle < 0)
|
||||
s = -s;
|
||||
x = (elements[2][1] - elements[1][2]) / s;
|
||||
y = (elements[0][2] - elements[2][0]) / s;
|
||||
z = (elements[1][0] - elements[0][1]) / s;
|
||||
|
@ -473,20 +473,23 @@ void CameraMatrix::invert() {
|
||||
|
||||
/** Divide column by minus pivot value **/
|
||||
for (i = 0; i < 4; i++) {
|
||||
if (i != k) matrix[i][k] /= (-pvt_val);
|
||||
if (i != k)
|
||||
matrix[i][k] /= (-pvt_val);
|
||||
}
|
||||
|
||||
/** Reduce the matrix **/
|
||||
for (i = 0; i < 4; i++) {
|
||||
hold = matrix[i][k];
|
||||
for (j = 0; j < 4; j++) {
|
||||
if (i != k && j != k) matrix[i][j] += hold * matrix[k][j];
|
||||
if (i != k && j != k)
|
||||
matrix[i][j] += hold * matrix[k][j];
|
||||
}
|
||||
}
|
||||
|
||||
/** Divide row by pivot **/
|
||||
for (j = 0; j < 4; j++) {
|
||||
if (j != k) matrix[k][j] /= pvt_val;
|
||||
if (j != k)
|
||||
matrix[k][j] /= pvt_val;
|
||||
}
|
||||
|
||||
/** Replace pivot by reciprocal (at last we can touch it). **/
|
||||
|
@ -1023,11 +1023,21 @@ Error Expression::_get_token(Token &r_token) {
|
||||
|
||||
switch (next) {
|
||||
|
||||
case 'b': res = 8; break;
|
||||
case 't': res = 9; break;
|
||||
case 'n': res = 10; break;
|
||||
case 'f': res = 12; break;
|
||||
case 'r': res = 13; break;
|
||||
case 'b':
|
||||
res = 8;
|
||||
break;
|
||||
case 't':
|
||||
res = 9;
|
||||
break;
|
||||
case 'n':
|
||||
res = 10;
|
||||
break;
|
||||
case 'f':
|
||||
res = 12;
|
||||
break;
|
||||
case 'r':
|
||||
res = 13;
|
||||
break;
|
||||
case 'u': {
|
||||
// hex number
|
||||
for (int j = 0; j < 4; j++) {
|
||||
@ -1703,27 +1713,69 @@ Expression::ENode *Expression::_parse_expression() {
|
||||
Variant::Operator op = Variant::OP_MAX;
|
||||
|
||||
switch (tk.type) {
|
||||
case TK_OP_IN: op = Variant::OP_IN; break;
|
||||
case TK_OP_EQUAL: op = Variant::OP_EQUAL; break;
|
||||
case TK_OP_NOT_EQUAL: op = Variant::OP_NOT_EQUAL; break;
|
||||
case TK_OP_LESS: op = Variant::OP_LESS; break;
|
||||
case TK_OP_LESS_EQUAL: op = Variant::OP_LESS_EQUAL; break;
|
||||
case TK_OP_GREATER: op = Variant::OP_GREATER; break;
|
||||
case TK_OP_GREATER_EQUAL: op = Variant::OP_GREATER_EQUAL; break;
|
||||
case TK_OP_AND: op = Variant::OP_AND; break;
|
||||
case TK_OP_OR: op = Variant::OP_OR; break;
|
||||
case TK_OP_NOT: op = Variant::OP_NOT; break;
|
||||
case TK_OP_ADD: op = Variant::OP_ADD; break;
|
||||
case TK_OP_SUB: op = Variant::OP_SUBTRACT; break;
|
||||
case TK_OP_MUL: op = Variant::OP_MULTIPLY; break;
|
||||
case TK_OP_DIV: op = Variant::OP_DIVIDE; break;
|
||||
case TK_OP_MOD: op = Variant::OP_MODULE; break;
|
||||
case TK_OP_SHIFT_LEFT: op = Variant::OP_SHIFT_LEFT; break;
|
||||
case TK_OP_SHIFT_RIGHT: op = Variant::OP_SHIFT_RIGHT; break;
|
||||
case TK_OP_BIT_AND: op = Variant::OP_BIT_AND; break;
|
||||
case TK_OP_BIT_OR: op = Variant::OP_BIT_OR; break;
|
||||
case TK_OP_BIT_XOR: op = Variant::OP_BIT_XOR; break;
|
||||
case TK_OP_BIT_INVERT: op = Variant::OP_BIT_NEGATE; break;
|
||||
case TK_OP_IN:
|
||||
op = Variant::OP_IN;
|
||||
break;
|
||||
case TK_OP_EQUAL:
|
||||
op = Variant::OP_EQUAL;
|
||||
break;
|
||||
case TK_OP_NOT_EQUAL:
|
||||
op = Variant::OP_NOT_EQUAL;
|
||||
break;
|
||||
case TK_OP_LESS:
|
||||
op = Variant::OP_LESS;
|
||||
break;
|
||||
case TK_OP_LESS_EQUAL:
|
||||
op = Variant::OP_LESS_EQUAL;
|
||||
break;
|
||||
case TK_OP_GREATER:
|
||||
op = Variant::OP_GREATER;
|
||||
break;
|
||||
case TK_OP_GREATER_EQUAL:
|
||||
op = Variant::OP_GREATER_EQUAL;
|
||||
break;
|
||||
case TK_OP_AND:
|
||||
op = Variant::OP_AND;
|
||||
break;
|
||||
case TK_OP_OR:
|
||||
op = Variant::OP_OR;
|
||||
break;
|
||||
case TK_OP_NOT:
|
||||
op = Variant::OP_NOT;
|
||||
break;
|
||||
case TK_OP_ADD:
|
||||
op = Variant::OP_ADD;
|
||||
break;
|
||||
case TK_OP_SUB:
|
||||
op = Variant::OP_SUBTRACT;
|
||||
break;
|
||||
case TK_OP_MUL:
|
||||
op = Variant::OP_MULTIPLY;
|
||||
break;
|
||||
case TK_OP_DIV:
|
||||
op = Variant::OP_DIVIDE;
|
||||
break;
|
||||
case TK_OP_MOD:
|
||||
op = Variant::OP_MODULE;
|
||||
break;
|
||||
case TK_OP_SHIFT_LEFT:
|
||||
op = Variant::OP_SHIFT_LEFT;
|
||||
break;
|
||||
case TK_OP_SHIFT_RIGHT:
|
||||
op = Variant::OP_SHIFT_RIGHT;
|
||||
break;
|
||||
case TK_OP_BIT_AND:
|
||||
op = Variant::OP_BIT_AND;
|
||||
break;
|
||||
case TK_OP_BIT_OR:
|
||||
op = Variant::OP_BIT_OR;
|
||||
break;
|
||||
case TK_OP_BIT_XOR:
|
||||
op = Variant::OP_BIT_XOR;
|
||||
break;
|
||||
case TK_OP_BIT_INVERT:
|
||||
op = Variant::OP_BIT_NEGATE;
|
||||
break;
|
||||
default: {
|
||||
};
|
||||
}
|
||||
@ -1772,36 +1824,74 @@ Expression::ENode *Expression::_parse_expression() {
|
||||
unary = true;
|
||||
break;
|
||||
|
||||
case Variant::OP_MULTIPLY: priority = 2; break;
|
||||
case Variant::OP_DIVIDE: priority = 2; break;
|
||||
case Variant::OP_MODULE: priority = 2; break;
|
||||
case Variant::OP_MULTIPLY:
|
||||
priority = 2;
|
||||
break;
|
||||
case Variant::OP_DIVIDE:
|
||||
priority = 2;
|
||||
break;
|
||||
case Variant::OP_MODULE:
|
||||
priority = 2;
|
||||
break;
|
||||
|
||||
case Variant::OP_ADD: priority = 3; break;
|
||||
case Variant::OP_SUBTRACT: priority = 3; break;
|
||||
case Variant::OP_ADD:
|
||||
priority = 3;
|
||||
break;
|
||||
case Variant::OP_SUBTRACT:
|
||||
priority = 3;
|
||||
break;
|
||||
|
||||
case Variant::OP_SHIFT_LEFT: priority = 4; break;
|
||||
case Variant::OP_SHIFT_RIGHT: priority = 4; break;
|
||||
case Variant::OP_SHIFT_LEFT:
|
||||
priority = 4;
|
||||
break;
|
||||
case Variant::OP_SHIFT_RIGHT:
|
||||
priority = 4;
|
||||
break;
|
||||
|
||||
case Variant::OP_BIT_AND: priority = 5; break;
|
||||
case Variant::OP_BIT_XOR: priority = 6; break;
|
||||
case Variant::OP_BIT_OR: priority = 7; break;
|
||||
case Variant::OP_BIT_AND:
|
||||
priority = 5;
|
||||
break;
|
||||
case Variant::OP_BIT_XOR:
|
||||
priority = 6;
|
||||
break;
|
||||
case Variant::OP_BIT_OR:
|
||||
priority = 7;
|
||||
break;
|
||||
|
||||
case Variant::OP_LESS: priority = 8; break;
|
||||
case Variant::OP_LESS_EQUAL: priority = 8; break;
|
||||
case Variant::OP_GREATER: priority = 8; break;
|
||||
case Variant::OP_GREATER_EQUAL: priority = 8; break;
|
||||
case Variant::OP_LESS:
|
||||
priority = 8;
|
||||
break;
|
||||
case Variant::OP_LESS_EQUAL:
|
||||
priority = 8;
|
||||
break;
|
||||
case Variant::OP_GREATER:
|
||||
priority = 8;
|
||||
break;
|
||||
case Variant::OP_GREATER_EQUAL:
|
||||
priority = 8;
|
||||
break;
|
||||
|
||||
case Variant::OP_EQUAL: priority = 8; break;
|
||||
case Variant::OP_NOT_EQUAL: priority = 8; break;
|
||||
case Variant::OP_EQUAL:
|
||||
priority = 8;
|
||||
break;
|
||||
case Variant::OP_NOT_EQUAL:
|
||||
priority = 8;
|
||||
break;
|
||||
|
||||
case Variant::OP_IN: priority = 10; break;
|
||||
case Variant::OP_IN:
|
||||
priority = 10;
|
||||
break;
|
||||
|
||||
case Variant::OP_NOT:
|
||||
priority = 11;
|
||||
unary = true;
|
||||
break;
|
||||
case Variant::OP_AND: priority = 12; break;
|
||||
case Variant::OP_OR: priority = 13; break;
|
||||
case Variant::OP_AND:
|
||||
priority = 12;
|
||||
break;
|
||||
case Variant::OP_OR:
|
||||
priority = 13;
|
||||
break;
|
||||
|
||||
default: {
|
||||
_set_error("Parser bug, invalid operator in expression: " + itos(expression[i].op));
|
||||
|
@ -445,7 +445,8 @@ static inline void _mark_outside(uint8_t ***p_cell_status, int x, int y, int z,
|
||||
next_z--;
|
||||
prev = _CELL_PREV_Z_POS;
|
||||
} break;
|
||||
default: ERR_FAIL();
|
||||
default:
|
||||
ERR_FAIL();
|
||||
}
|
||||
|
||||
if (next_x < 0 || next_x >= len_x)
|
||||
@ -1083,10 +1084,18 @@ Vector<Vector<Point2>> Geometry::_polypaths_do_operation(PolyBooleanOperation p_
|
||||
ClipType op = ctUnion;
|
||||
|
||||
switch (p_op) {
|
||||
case OPERATION_UNION: op = ctUnion; break;
|
||||
case OPERATION_DIFFERENCE: op = ctDifference; break;
|
||||
case OPERATION_INTERSECTION: op = ctIntersection; break;
|
||||
case OPERATION_XOR: op = ctXor; break;
|
||||
case OPERATION_UNION:
|
||||
op = ctUnion;
|
||||
break;
|
||||
case OPERATION_DIFFERENCE:
|
||||
op = ctDifference;
|
||||
break;
|
||||
case OPERATION_INTERSECTION:
|
||||
op = ctIntersection;
|
||||
break;
|
||||
case OPERATION_XOR:
|
||||
op = ctXor;
|
||||
break;
|
||||
}
|
||||
Path path_a, path_b;
|
||||
|
||||
@ -1135,19 +1144,35 @@ Vector<Vector<Point2>> Geometry::_polypath_offset(const Vector<Point2> &p_polypa
|
||||
JoinType jt = jtSquare;
|
||||
|
||||
switch (p_join_type) {
|
||||
case JOIN_SQUARE: jt = jtSquare; break;
|
||||
case JOIN_ROUND: jt = jtRound; break;
|
||||
case JOIN_MITER: jt = jtMiter; break;
|
||||
case JOIN_SQUARE:
|
||||
jt = jtSquare;
|
||||
break;
|
||||
case JOIN_ROUND:
|
||||
jt = jtRound;
|
||||
break;
|
||||
case JOIN_MITER:
|
||||
jt = jtMiter;
|
||||
break;
|
||||
}
|
||||
|
||||
EndType et = etClosedPolygon;
|
||||
|
||||
switch (p_end_type) {
|
||||
case END_POLYGON: et = etClosedPolygon; break;
|
||||
case END_JOINED: et = etClosedLine; break;
|
||||
case END_BUTT: et = etOpenButt; break;
|
||||
case END_SQUARE: et = etOpenSquare; break;
|
||||
case END_ROUND: et = etOpenRound; break;
|
||||
case END_POLYGON:
|
||||
et = etClosedPolygon;
|
||||
break;
|
||||
case END_JOINED:
|
||||
et = etClosedLine;
|
||||
break;
|
||||
case END_BUTT:
|
||||
et = etOpenButt;
|
||||
break;
|
||||
case END_SQUARE:
|
||||
et = etOpenSquare;
|
||||
break;
|
||||
case END_ROUND:
|
||||
et = etOpenRound;
|
||||
break;
|
||||
}
|
||||
ClipperOffset co(2.0, 0.25 * SCALE_FACTOR); // Defaults from ClipperOffset.
|
||||
Path path;
|
||||
|
@ -113,10 +113,14 @@ public:
|
||||
real_t mub = (d_of(p1, q1, q2, q1) + mua * d_of(q2, q1, p2, p1)) / d_of(q2, q1, q2, q1);
|
||||
|
||||
// Clip the value between [0..1] constraining the solution to lie on the original curves.
|
||||
if (mua < 0) mua = 0;
|
||||
if (mub < 0) mub = 0;
|
||||
if (mua > 1) mua = 1;
|
||||
if (mub > 1) mub = 1;
|
||||
if (mua < 0)
|
||||
mua = 0;
|
||||
if (mub < 0)
|
||||
mub = 0;
|
||||
if (mua > 1)
|
||||
mua = 1;
|
||||
if (mub > 1)
|
||||
mub = 1;
|
||||
c1 = p1.lerp(p2, mua);
|
||||
c2 = q1.lerp(q2, mub);
|
||||
}
|
||||
@ -497,7 +501,8 @@ public:
|
||||
|
||||
bool orientation = an.cross(bn) > 0;
|
||||
|
||||
if ((bn.cross(cn) > 0) != orientation) return false;
|
||||
if ((bn.cross(cn) > 0) != orientation)
|
||||
return false;
|
||||
|
||||
return (cn.cross(an) > 0) == orientation;
|
||||
}
|
||||
@ -683,7 +688,8 @@ public:
|
||||
|
||||
// If the term we intend to square root is less than 0 then the answer won't be real,
|
||||
// so it definitely won't be t in the range 0 to 1.
|
||||
if (sqrtterm < 0) return -1;
|
||||
if (sqrtterm < 0)
|
||||
return -1;
|
||||
|
||||
// If we can assume that the line segment starts outside the circle (e.g. for continuous time collision detection)
|
||||
// then the following can be skipped and we can just return the equivalent of res1.
|
||||
@ -691,8 +697,10 @@ public:
|
||||
real_t res1 = (-b - sqrtterm) / (2 * a);
|
||||
real_t res2 = (-b + sqrtterm) / (2 * a);
|
||||
|
||||
if (res1 >= 0 && res1 <= 1) return res1;
|
||||
if (res2 >= 0 && res2 <= 1) return res2;
|
||||
if (res1 >= 0 && res1 <= 1)
|
||||
return res1;
|
||||
if (res2 >= 0 && res2 <= 1)
|
||||
return res2;
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -233,12 +233,14 @@ public:
|
||||
static _ALWAYS_INLINE_ float range_lerp(float p_value, float p_istart, float p_istop, float p_ostart, float p_ostop) { return Math::lerp(p_ostart, p_ostop, Math::inverse_lerp(p_istart, p_istop, p_value)); }
|
||||
|
||||
static _ALWAYS_INLINE_ double smoothstep(double p_from, double p_to, double p_weight) {
|
||||
if (is_equal_approx(p_from, p_to)) return p_from;
|
||||
if (is_equal_approx(p_from, p_to))
|
||||
return p_from;
|
||||
double x = CLAMP((p_weight - p_from) / (p_to - p_from), 0.0, 1.0);
|
||||
return x * x * (3.0 - 2.0 * x);
|
||||
}
|
||||
static _ALWAYS_INLINE_ float smoothstep(float p_from, float p_to, float p_weight) {
|
||||
if (is_equal_approx(p_from, p_to)) return p_from;
|
||||
if (is_equal_approx(p_from, p_to))
|
||||
return p_from;
|
||||
float x = CLAMP((p_weight - p_from) / (p_to - p_from), 0.0f, 1.0f);
|
||||
return x * x * (3.0f - 2.0f * x);
|
||||
}
|
||||
|
@ -206,7 +206,8 @@ Quat Quat::slerpni(const Quat &q, const real_t &t) const {
|
||||
|
||||
real_t dot = from.dot(q);
|
||||
|
||||
if (Math::absf(dot) > 0.9999) return from;
|
||||
if (Math::absf(dot) > 0.9999)
|
||||
return from;
|
||||
|
||||
real_t theta = Math::acos(dot),
|
||||
sinT = 1.0 / Math::sin(theta),
|
||||
|
@ -558,14 +558,16 @@ bool TriangleMesh::intersect_convex_shape(const Plane *p_planes, int p_plane_cou
|
||||
if (p.intersects_segment(point, next_point, &res)) {
|
||||
bool inisde = true;
|
||||
for (int k = 0; k < p_plane_count; k++) {
|
||||
if (k == i) continue;
|
||||
if (k == i)
|
||||
continue;
|
||||
const Plane &pp = p_planes[k];
|
||||
if (pp.is_point_over(res)) {
|
||||
inisde = false;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (inisde) return true;
|
||||
if (inisde)
|
||||
return true;
|
||||
}
|
||||
|
||||
if (p.is_point_over(point)) {
|
||||
@ -573,7 +575,8 @@ bool TriangleMesh::intersect_convex_shape(const Plane *p_planes, int p_plane_cou
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (over) return true;
|
||||
if (over)
|
||||
return true;
|
||||
}
|
||||
|
||||
stack[level] = (VISIT_DONE_BIT << VISITED_BIT_SHIFT) | node;
|
||||
@ -652,7 +655,8 @@ bool TriangleMesh::inside_convex_shape(const Plane *p_planes, int p_plane_count,
|
||||
case TEST_AABB_BIT: {
|
||||
|
||||
bool intersects = scale.xform(b.aabb).intersects_convex_shape(p_planes, p_plane_count, p_points, p_point_count);
|
||||
if (!intersects) return false;
|
||||
if (!intersects)
|
||||
return false;
|
||||
|
||||
bool inside = scale.xform(b.aabb).inside_convex_shape(p_planes, p_plane_count);
|
||||
if (inside) {
|
||||
@ -667,7 +671,8 @@ bool TriangleMesh::inside_convex_shape(const Plane *p_planes, int p_plane_count,
|
||||
Vector3 point = scale.xform(vertexptr[s.indices[j]]);
|
||||
for (int i = 0; i < p_plane_count; i++) {
|
||||
const Plane &p = p_planes[i];
|
||||
if (p.is_point_over(point)) return false;
|
||||
if (p.is_point_over(point))
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -103,13 +103,16 @@ bool Triangulate::snip(const Vector<Vector2> &p_contour, int u, int v, int w, in
|
||||
// To avoid that we allow zero-area triangles if all else failed.
|
||||
float threshold = relaxed ? -CMP_EPSILON : CMP_EPSILON;
|
||||
|
||||
if (threshold > (((Bx - Ax) * (Cy - Ay)) - ((By - Ay) * (Cx - Ax)))) return false;
|
||||
if (threshold > (((Bx - Ax) * (Cy - Ay)) - ((By - Ay) * (Cx - Ax))))
|
||||
return false;
|
||||
|
||||
for (p = 0; p < n; p++) {
|
||||
if ((p == u) || (p == v) || (p == w)) continue;
|
||||
if ((p == u) || (p == v) || (p == w))
|
||||
continue;
|
||||
Px = contour[V[p]].x;
|
||||
Py = contour[V[p]].y;
|
||||
if (is_inside_triangle(Ax, Ay, Bx, By, Cx, Cy, Px, Py, relaxed)) return false;
|
||||
if (is_inside_triangle(Ax, Ay, Bx, By, Cx, Cy, Px, Py, relaxed))
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
@ -119,7 +122,8 @@ bool Triangulate::triangulate(const Vector<Vector2> &contour, Vector<int> &resul
|
||||
/* allocate and initialize list of Vertices in polygon */
|
||||
|
||||
int n = contour.size();
|
||||
if (n < 3) return false;
|
||||
if (n < 3)
|
||||
return false;
|
||||
|
||||
Vector<int> V;
|
||||
V.resize(n);
|
||||
@ -161,11 +165,14 @@ bool Triangulate::triangulate(const Vector<Vector2> &contour, Vector<int> &resul
|
||||
|
||||
/* three consecutive vertices in current polygon, <u,v,w> */
|
||||
int u = v;
|
||||
if (nv <= u) u = 0; /* previous */
|
||||
if (nv <= u)
|
||||
u = 0; /* previous */
|
||||
v = u + 1;
|
||||
if (nv <= v) v = 0; /* new v */
|
||||
if (nv <= v)
|
||||
v = 0; /* new v */
|
||||
int w = v + 1;
|
||||
if (nv <= w) w = 0; /* next */
|
||||
if (nv <= w)
|
||||
w = 0; /* next */
|
||||
|
||||
if (snip(contour, u, v, w, nv, V, relaxed)) {
|
||||
int a, b, c, s, t;
|
||||
|
@ -165,7 +165,8 @@ struct VariantObjectClassChecker<Control *> {
|
||||
#define CHECK_NOARG(m_arg) \
|
||||
{ \
|
||||
if (p_arg##m_arg.get_type() != Variant::NIL) { \
|
||||
if (r_argerror) *r_argerror = (m_arg - 1); \
|
||||
if (r_argerror) \
|
||||
*r_argerror = (m_arg - 1); \
|
||||
return CALL_ERROR_EXTRA_ARGUMENT; \
|
||||
} \
|
||||
}
|
||||
|
@ -373,7 +373,8 @@ NodePath::NodePath(const String &p_path) {
|
||||
|
||||
String str = path.substr(from, i - from);
|
||||
if (str == "") {
|
||||
if (path[i] == 0) continue; // Allow end-of-path :
|
||||
if (path[i] == 0)
|
||||
continue; // Allow end-of-path :
|
||||
|
||||
ERR_FAIL_MSG("Invalid NodePath '" + p_path + "'.");
|
||||
}
|
||||
|
@ -543,7 +543,8 @@ void Object::set_indexed(const Vector<StringName> &p_names, const Variant &p_val
|
||||
}
|
||||
|
||||
bool valid = false;
|
||||
if (!r_valid) r_valid = &valid;
|
||||
if (!r_valid)
|
||||
r_valid = &valid;
|
||||
|
||||
List<Variant> value_stack;
|
||||
|
||||
|
@ -346,7 +346,8 @@ protected:
|
||||
return (bool (Object::*)(const StringName &, const Variant &)) & m_class::_set; \
|
||||
} \
|
||||
virtual bool _setv(const StringName &p_name, const Variant &p_property) { \
|
||||
if (m_inherits::_setv(p_name, p_property)) return true; \
|
||||
if (m_inherits::_setv(p_name, p_property)) \
|
||||
return true; \
|
||||
if (m_class::_get_set() != m_inherits::_get_set()) { \
|
||||
return _set(p_name, p_property); \
|
||||
} \
|
||||
|
@ -39,18 +39,24 @@ String DirAccess::_get_root_path() const {
|
||||
|
||||
switch (_access_type) {
|
||||
|
||||
case ACCESS_RESOURCES: return ProjectSettings::get_singleton()->get_resource_path();
|
||||
case ACCESS_USERDATA: return OS::get_singleton()->get_user_data_dir();
|
||||
default: return "";
|
||||
case ACCESS_RESOURCES:
|
||||
return ProjectSettings::get_singleton()->get_resource_path();
|
||||
case ACCESS_USERDATA:
|
||||
return OS::get_singleton()->get_user_data_dir();
|
||||
default:
|
||||
return "";
|
||||
}
|
||||
}
|
||||
String DirAccess::_get_root_string() const {
|
||||
|
||||
switch (_access_type) {
|
||||
|
||||
case ACCESS_RESOURCES: return "res://";
|
||||
case ACCESS_USERDATA: return "user://";
|
||||
default: return "";
|
||||
case ACCESS_RESOURCES:
|
||||
return "res://";
|
||||
case ACCESS_USERDATA:
|
||||
return "user://";
|
||||
default:
|
||||
return "";
|
||||
}
|
||||
}
|
||||
|
||||
@ -220,7 +226,8 @@ String DirAccess::fix_path(String p_path) const {
|
||||
|
||||
return p_path;
|
||||
} break;
|
||||
case ACCESS_MAX: break; // Can't happen, but silences warning
|
||||
case ACCESS_MAX:
|
||||
break; // Can't happen, but silences warning
|
||||
}
|
||||
|
||||
return p_path;
|
||||
|
@ -145,7 +145,8 @@ struct DirAccessRef {
|
||||
DirAccess *f;
|
||||
DirAccessRef(DirAccess *fa) { f = fa; }
|
||||
~DirAccessRef() {
|
||||
if (f) memdelete(f);
|
||||
if (f)
|
||||
memdelete(f);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -163,7 +163,8 @@ String FileAccess::fix_path(const String &p_path) const {
|
||||
|
||||
return r_path;
|
||||
} break;
|
||||
case ACCESS_MAX: break; // Can't happen, but silences warning
|
||||
case ACCESS_MAX:
|
||||
break; // Can't happen, but silences warning
|
||||
}
|
||||
|
||||
return r_path;
|
||||
|
@ -192,7 +192,8 @@ struct FileAccessRef {
|
||||
operator FileAccess *() { return f; }
|
||||
FileAccessRef(FileAccess *fa) { f = fa; }
|
||||
~FileAccessRef() {
|
||||
if (f) memdelete(f);
|
||||
if (f)
|
||||
memdelete(f);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -130,9 +130,10 @@ void memdelete_allocator(T *p_class) {
|
||||
A::free(p_class);
|
||||
}
|
||||
|
||||
#define memdelete_notnull(m_v) \
|
||||
{ \
|
||||
if (m_v) memdelete(m_v); \
|
||||
#define memdelete_notnull(m_v) \
|
||||
{ \
|
||||
if (m_v) \
|
||||
memdelete(m_v); \
|
||||
}
|
||||
|
||||
#define memnew_arr(m_class, m_count) memnew_arr_template<m_class>(m_count)
|
||||
|
@ -58,10 +58,12 @@ class RWLockRead {
|
||||
public:
|
||||
RWLockRead(const RWLock *p_lock) {
|
||||
lock = const_cast<RWLock *>(p_lock);
|
||||
if (lock) lock->read_lock();
|
||||
if (lock)
|
||||
lock->read_lock();
|
||||
}
|
||||
~RWLockRead() {
|
||||
if (lock) lock->read_unlock();
|
||||
if (lock)
|
||||
lock->read_unlock();
|
||||
}
|
||||
};
|
||||
|
||||
@ -72,10 +74,12 @@ class RWLockWrite {
|
||||
public:
|
||||
RWLockWrite(RWLock *p_lock) {
|
||||
lock = p_lock;
|
||||
if (lock) lock->write_lock();
|
||||
if (lock)
|
||||
lock->write_lock();
|
||||
}
|
||||
~RWLockWrite() {
|
||||
if (lock) lock->write_unlock();
|
||||
if (lock)
|
||||
lock->write_unlock();
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -182,7 +182,8 @@ PoolAllocator::ID PoolAllocator::alloc(int p_size) {
|
||||
|
||||
ERR_FAIL_COND_V(p_size < 1, POOL_ALLOCATOR_INVALID_ID);
|
||||
#ifdef DEBUG_ENABLED
|
||||
if (p_size > free_mem) OS::get_singleton()->debug_break();
|
||||
if (p_size > free_mem)
|
||||
OS::get_singleton()->debug_break();
|
||||
#endif
|
||||
ERR_FAIL_COND_V(p_size > free_mem, POOL_ALLOCATOR_INVALID_ID);
|
||||
|
||||
|
@ -121,7 +121,8 @@ private:
|
||||
public:
|
||||
_FORCE_INLINE_ bool in_list() const { return _root; }
|
||||
_FORCE_INLINE_ void remove_from_list() {
|
||||
if (_root) _root->remove(this);
|
||||
if (_root)
|
||||
_root->remove(this);
|
||||
}
|
||||
_FORCE_INLINE_ SelfList<T> *next() { return _next; }
|
||||
_FORCE_INLINE_ SelfList<T> *prev() { return _prev; }
|
||||
|
@ -989,7 +989,8 @@ String TranslationServer::get_locale() const {
|
||||
|
||||
String TranslationServer::get_locale_name(const String &p_locale) const {
|
||||
|
||||
if (!locale_name_map.has(p_locale)) return String();
|
||||
if (!locale_name_map.has(p_locale))
|
||||
return String();
|
||||
return locale_name_map[p_locale];
|
||||
}
|
||||
|
||||
|
@ -1 +1,31 @@
|
||||
/*************************************************************************/
|
||||
/* typed_array.cpp */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#include "typed_array.h"
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* typed_array.h */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#ifndef TYPED_ARRAY_H
|
||||
#define TYPED_ARRAY_H
|
||||
|
||||
|
@ -1882,7 +1882,8 @@ bool String::is_numeric() const {
|
||||
};
|
||||
|
||||
int s = 0;
|
||||
if (operator[](0) == '-') ++s;
|
||||
if (operator[](0) == '-')
|
||||
++s;
|
||||
bool dot = false;
|
||||
for (int i = s; i < length(); i++) {
|
||||
|
||||
@ -4182,9 +4183,14 @@ String String::sprintf(const Array &values, bool *error) const {
|
||||
int base = 16;
|
||||
bool capitalize = false;
|
||||
switch (c) {
|
||||
case 'd': base = 10; break;
|
||||
case 'o': base = 8; break;
|
||||
case 'x': break;
|
||||
case 'd':
|
||||
base = 10;
|
||||
break;
|
||||
case 'o':
|
||||
base = 8;
|
||||
break;
|
||||
case 'x':
|
||||
break;
|
||||
case 'X':
|
||||
base = 16;
|
||||
capitalize = true;
|
||||
|
295
core/variant.cpp
295
core/variant.cpp
@ -1406,20 +1406,47 @@ void Variant::reference(const Variant &p_variant) {
|
||||
|
||||
void Variant::zero() {
|
||||
switch (type) {
|
||||
case NIL: break;
|
||||
case BOOL: this->_data._bool = false; break;
|
||||
case INT: this->_data._int = 0; break;
|
||||
case FLOAT: this->_data._float = 0; break;
|
||||
case VECTOR2: *reinterpret_cast<Vector2 *>(this->_data._mem) = Vector2(); break;
|
||||
case VECTOR2I: *reinterpret_cast<Vector2i *>(this->_data._mem) = Vector2i(); break;
|
||||
case RECT2: *reinterpret_cast<Rect2 *>(this->_data._mem) = Rect2(); break;
|
||||
case RECT2I: *reinterpret_cast<Rect2i *>(this->_data._mem) = Rect2i(); break;
|
||||
case VECTOR3: *reinterpret_cast<Vector3 *>(this->_data._mem) = Vector3(); break;
|
||||
case VECTOR3I: *reinterpret_cast<Vector3i *>(this->_data._mem) = Vector3i(); break;
|
||||
case PLANE: *reinterpret_cast<Plane *>(this->_data._mem) = Plane(); break;
|
||||
case QUAT: *reinterpret_cast<Quat *>(this->_data._mem) = Quat(); break;
|
||||
case COLOR: *reinterpret_cast<Color *>(this->_data._mem) = Color(); break;
|
||||
default: this->clear(); break;
|
||||
case NIL:
|
||||
break;
|
||||
case BOOL:
|
||||
this->_data._bool = false;
|
||||
break;
|
||||
case INT:
|
||||
this->_data._int = 0;
|
||||
break;
|
||||
case FLOAT:
|
||||
this->_data._float = 0;
|
||||
break;
|
||||
case VECTOR2:
|
||||
*reinterpret_cast<Vector2 *>(this->_data._mem) = Vector2();
|
||||
break;
|
||||
case VECTOR2I:
|
||||
*reinterpret_cast<Vector2i *>(this->_data._mem) = Vector2i();
|
||||
break;
|
||||
case RECT2:
|
||||
*reinterpret_cast<Rect2 *>(this->_data._mem) = Rect2();
|
||||
break;
|
||||
case RECT2I:
|
||||
*reinterpret_cast<Rect2i *>(this->_data._mem) = Rect2i();
|
||||
break;
|
||||
case VECTOR3:
|
||||
*reinterpret_cast<Vector3 *>(this->_data._mem) = Vector3();
|
||||
break;
|
||||
case VECTOR3I:
|
||||
*reinterpret_cast<Vector3i *>(this->_data._mem) = Vector3i();
|
||||
break;
|
||||
case PLANE:
|
||||
*reinterpret_cast<Plane *>(this->_data._mem) = Plane();
|
||||
break;
|
||||
case QUAT:
|
||||
*reinterpret_cast<Quat *>(this->_data._mem) = Quat();
|
||||
break;
|
||||
case COLOR:
|
||||
*reinterpret_cast<Color *>(this->_data._mem) = Color();
|
||||
break;
|
||||
default:
|
||||
this->clear();
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1545,11 +1572,16 @@ Variant::operator signed int() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1560,11 +1592,16 @@ Variant::operator unsigned int() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1576,11 +1613,16 @@ Variant::operator int64_t() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int64();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int64();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1612,11 +1654,16 @@ Variant::operator uint64_t() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1639,11 +1686,16 @@ Variant::operator signed long() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._real;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._real;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1657,11 +1709,16 @@ Variant::operator unsigned long() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._real;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._real;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1676,11 +1733,16 @@ Variant::operator signed short() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1691,11 +1753,16 @@ Variant::operator unsigned short() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1706,11 +1773,16 @@ Variant::operator signed char() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1721,11 +1793,16 @@ Variant::operator unsigned char() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1 : 0;
|
||||
case INT: return _data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_int();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1 : 0;
|
||||
case INT:
|
||||
return _data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_int();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1742,11 +1819,16 @@ Variant::operator float() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1.0 : 0.0;
|
||||
case INT: return (float)_data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_double();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1.0 : 0.0;
|
||||
case INT:
|
||||
return (float)_data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_double();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1757,11 +1839,16 @@ Variant::operator double() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case NIL: return 0;
|
||||
case BOOL: return _data._bool ? 1.0 : 0.0;
|
||||
case INT: return (double)_data._int;
|
||||
case FLOAT: return _data._float;
|
||||
case STRING: return operator String().to_double();
|
||||
case NIL:
|
||||
return 0;
|
||||
case BOOL:
|
||||
return _data._bool ? 1.0 : 0.0;
|
||||
case INT:
|
||||
return (double)_data._int;
|
||||
case FLOAT:
|
||||
return _data._float;
|
||||
case STRING:
|
||||
return operator String().to_double();
|
||||
default: {
|
||||
|
||||
return 0;
|
||||
@ -1800,27 +1887,40 @@ Variant::operator String() const {
|
||||
String Variant::stringify(List<const void *> &stack) const {
|
||||
switch (type) {
|
||||
|
||||
case NIL: return "Null";
|
||||
case BOOL: return _data._bool ? "True" : "False";
|
||||
case INT: return itos(_data._int);
|
||||
case FLOAT: return rtos(_data._float);
|
||||
case STRING: return *reinterpret_cast<const String *>(_data._mem);
|
||||
case VECTOR2: return "(" + operator Vector2() + ")";
|
||||
case VECTOR2I: return "(" + operator Vector2i() + ")";
|
||||
case RECT2: return "(" + operator Rect2() + ")";
|
||||
case RECT2I: return "(" + operator Rect2i() + ")";
|
||||
case NIL:
|
||||
return "Null";
|
||||
case BOOL:
|
||||
return _data._bool ? "True" : "False";
|
||||
case INT:
|
||||
return itos(_data._int);
|
||||
case FLOAT:
|
||||
return rtos(_data._float);
|
||||
case STRING:
|
||||
return *reinterpret_cast<const String *>(_data._mem);
|
||||
case VECTOR2:
|
||||
return "(" + operator Vector2() + ")";
|
||||
case VECTOR2I:
|
||||
return "(" + operator Vector2i() + ")";
|
||||
case RECT2:
|
||||
return "(" + operator Rect2() + ")";
|
||||
case RECT2I:
|
||||
return "(" + operator Rect2i() + ")";
|
||||
case TRANSFORM2D: {
|
||||
|
||||
Transform2D mat32 = operator Transform2D();
|
||||
return "(" + Variant(mat32.elements[0]).operator String() + ", " + Variant(mat32.elements[1]).operator String() + ", " + Variant(mat32.elements[2]).operator String() + ")";
|
||||
} break;
|
||||
case VECTOR3: return "(" + operator Vector3() + ")";
|
||||
case VECTOR3I: return "(" + operator Vector3i() + ")";
|
||||
case VECTOR3:
|
||||
return "(" + operator Vector3() + ")";
|
||||
case VECTOR3I:
|
||||
return "(" + operator Vector3i() + ")";
|
||||
case PLANE:
|
||||
return operator Plane();
|
||||
//case QUAT:
|
||||
case AABB: return operator ::AABB();
|
||||
case QUAT: return "(" + operator Quat() + ")";
|
||||
case AABB:
|
||||
return operator ::AABB();
|
||||
case QUAT:
|
||||
return "(" + operator Quat() + ")";
|
||||
case BASIS: {
|
||||
|
||||
Basis mat3 = operator Basis();
|
||||
@ -1846,10 +1946,14 @@ String Variant::stringify(List<const void *> &stack) const {
|
||||
|
||||
return mtx + ")";
|
||||
} break;
|
||||
case TRANSFORM: return operator Transform();
|
||||
case STRING_NAME: return operator StringName();
|
||||
case NODE_PATH: return operator NodePath();
|
||||
case COLOR: return String::num(operator Color().r) + "," + String::num(operator Color().g) + "," + String::num(operator Color().b) + "," + String::num(operator Color().a);
|
||||
case TRANSFORM:
|
||||
return operator Transform();
|
||||
case STRING_NAME:
|
||||
return operator StringName();
|
||||
case NODE_PATH:
|
||||
return operator NodePath();
|
||||
case COLOR:
|
||||
return String::num(operator Color().r) + "," + String::num(operator Color().g) + "," + String::num(operator Color().b) + "," + String::num(operator Color().a);
|
||||
case DICTIONARY: {
|
||||
|
||||
const Dictionary &d = *reinterpret_cast<const Dictionary *>(_data._mem);
|
||||
@ -3676,9 +3780,12 @@ bool Variant::is_shared() const {
|
||||
|
||||
switch (type) {
|
||||
|
||||
case OBJECT: return true;
|
||||
case ARRAY: return true;
|
||||
case DICTIONARY: return true;
|
||||
case OBJECT:
|
||||
return true;
|
||||
case ARRAY:
|
||||
return true;
|
||||
case DICTIONARY:
|
||||
return true;
|
||||
default: {
|
||||
}
|
||||
}
|
||||
|
@ -474,7 +474,8 @@ public:
|
||||
type = NIL;
|
||||
}
|
||||
_FORCE_INLINE_ ~Variant() {
|
||||
if (type != Variant::NIL) clear();
|
||||
if (type != Variant::NIL)
|
||||
clear();
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -861,9 +861,15 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform2D_xform(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator Vector2()); return;
|
||||
case Variant::RECT2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator Rect2()); return;
|
||||
case Variant::PACKED_VECTOR2_ARRAY: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator PackedVector2Array()); return;
|
||||
case Variant::VECTOR2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator Vector2());
|
||||
return;
|
||||
case Variant::RECT2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator Rect2());
|
||||
return;
|
||||
case Variant::PACKED_VECTOR2_ARRAY:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform(p_args[0]->operator PackedVector2Array());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'xform' in base 'Transform2D'. Valid types are Vector2, Rect2, and PackedVector2Array.");
|
||||
@ -872,9 +878,15 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform2D_xform_inv(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Vector2()); return;
|
||||
case Variant::RECT2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Rect2()); return;
|
||||
case Variant::PACKED_VECTOR2_ARRAY: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator PackedVector2Array()); return;
|
||||
case Variant::VECTOR2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Vector2());
|
||||
return;
|
||||
case Variant::RECT2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Rect2());
|
||||
return;
|
||||
case Variant::PACKED_VECTOR2_ARRAY:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->xform_inv(p_args[0]->operator PackedVector2Array());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'xform_inv' in base 'Transform2D'. Valid types are Vector2, Rect2, and PackedVector2Array.");
|
||||
@ -883,7 +895,9 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform2D_basis_xform(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->basis_xform(p_args[0]->operator Vector2()); return;
|
||||
case Variant::VECTOR2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->basis_xform(p_args[0]->operator Vector2());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'basis_xform' in base 'Transform2D'. Only Vector2 is valid.");
|
||||
@ -892,7 +906,9 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform2D_basis_xform_inv(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR2: r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->basis_xform_inv(p_args[0]->operator Vector2()); return;
|
||||
case Variant::VECTOR2:
|
||||
r_ret = reinterpret_cast<Transform2D *>(p_self._data._ptr)->basis_xform_inv(p_args[0]->operator Vector2());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'basis_xform_inv' in base 'Transform2D'. Only Vector2 is valid.");
|
||||
@ -929,10 +945,18 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform_xform(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR3: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator Vector3()); return;
|
||||
case Variant::PLANE: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator Plane()); return;
|
||||
case Variant::AABB: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator ::AABB()); return;
|
||||
case Variant::PACKED_VECTOR3_ARRAY: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator ::PackedVector3Array()); return;
|
||||
case Variant::VECTOR3:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator Vector3());
|
||||
return;
|
||||
case Variant::PLANE:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator Plane());
|
||||
return;
|
||||
case Variant::AABB:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator ::AABB());
|
||||
return;
|
||||
case Variant::PACKED_VECTOR3_ARRAY:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform(p_args[0]->operator ::PackedVector3Array());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'xform' in base 'Transform'. Valid types are Vector3, Plane, AABB, and PackedVector3Array.");
|
||||
@ -941,10 +965,18 @@ struct _VariantCall {
|
||||
|
||||
static void _call_Transform_xform_inv(Variant &r_ret, Variant &p_self, const Variant **p_args) {
|
||||
switch (p_args[0]->type) {
|
||||
case Variant::VECTOR3: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Vector3()); return;
|
||||
case Variant::PLANE: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Plane()); return;
|
||||
case Variant::AABB: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator ::AABB()); return;
|
||||
case Variant::PACKED_VECTOR3_ARRAY: r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator ::PackedVector3Array()); return;
|
||||
case Variant::VECTOR3:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Vector3());
|
||||
return;
|
||||
case Variant::PLANE:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator Plane());
|
||||
return;
|
||||
case Variant::AABB:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator ::AABB());
|
||||
return;
|
||||
case Variant::PACKED_VECTOR3_ARRAY:
|
||||
r_ret = reinterpret_cast<Transform *>(p_self._data._ptr)->xform_inv(p_args[0]->operator ::PackedVector3Array());
|
||||
return;
|
||||
default:
|
||||
r_ret = Variant();
|
||||
ERR_PRINT("Invalid type in function 'xform_inv' in base 'Transform'. Valid types are Vector3, Plane, AABB, and PackedVector3Array.");
|
||||
@ -1280,50 +1312,74 @@ Variant Variant::construct(const Variant::Type p_type, const Variant **p_args, i
|
||||
return Variant();
|
||||
|
||||
// atomic types
|
||||
case BOOL: return Variant(false);
|
||||
case INT: return 0;
|
||||
case FLOAT: return 0.0f;
|
||||
case BOOL:
|
||||
return Variant(false);
|
||||
case INT:
|
||||
return 0;
|
||||
case FLOAT:
|
||||
return 0.0f;
|
||||
case STRING:
|
||||
return String();
|
||||
|
||||
// math types
|
||||
case VECTOR2:
|
||||
return Vector2();
|
||||
case RECT2: return Rect2();
|
||||
case VECTOR3: return Vector3();
|
||||
case TRANSFORM2D: return Transform2D();
|
||||
case PLANE: return Plane();
|
||||
case QUAT: return Quat();
|
||||
case RECT2:
|
||||
return Rect2();
|
||||
case VECTOR3:
|
||||
return Vector3();
|
||||
case TRANSFORM2D:
|
||||
return Transform2D();
|
||||
case PLANE:
|
||||
return Plane();
|
||||
case QUAT:
|
||||
return Quat();
|
||||
case AABB:
|
||||
return ::AABB();
|
||||
case BASIS: return Basis();
|
||||
case BASIS:
|
||||
return Basis();
|
||||
case TRANSFORM:
|
||||
return Transform();
|
||||
|
||||
// misc types
|
||||
case COLOR: return Color();
|
||||
case COLOR:
|
||||
return Color();
|
||||
case STRING_NAME:
|
||||
return StringName();
|
||||
case NODE_PATH:
|
||||
return NodePath();
|
||||
case _RID: return RID();
|
||||
case OBJECT: return (Object *)nullptr;
|
||||
case CALLABLE: return Callable();
|
||||
case SIGNAL: return Signal();
|
||||
case DICTIONARY: return Dictionary();
|
||||
case _RID:
|
||||
return RID();
|
||||
case OBJECT:
|
||||
return (Object *)nullptr;
|
||||
case CALLABLE:
|
||||
return Callable();
|
||||
case SIGNAL:
|
||||
return Signal();
|
||||
case DICTIONARY:
|
||||
return Dictionary();
|
||||
case ARRAY:
|
||||
return Array();
|
||||
case PACKED_BYTE_ARRAY: return PackedByteArray();
|
||||
case PACKED_INT32_ARRAY: return PackedInt32Array();
|
||||
case PACKED_INT64_ARRAY: return PackedInt64Array();
|
||||
case PACKED_FLOAT32_ARRAY: return PackedFloat32Array();
|
||||
case PACKED_FLOAT64_ARRAY: return PackedFloat64Array();
|
||||
case PACKED_STRING_ARRAY: return PackedStringArray();
|
||||
case PACKED_BYTE_ARRAY:
|
||||
return PackedByteArray();
|
||||
case PACKED_INT32_ARRAY:
|
||||
return PackedInt32Array();
|
||||
case PACKED_INT64_ARRAY:
|
||||
return PackedInt64Array();
|
||||
case PACKED_FLOAT32_ARRAY:
|
||||
return PackedFloat32Array();
|
||||
case PACKED_FLOAT64_ARRAY:
|
||||
return PackedFloat64Array();
|
||||
case PACKED_STRING_ARRAY:
|
||||
return PackedStringArray();
|
||||
case PACKED_VECTOR2_ARRAY:
|
||||
return PackedVector2Array();
|
||||
case PACKED_VECTOR3_ARRAY: return PackedVector3Array();
|
||||
case PACKED_COLOR_ARRAY: return PackedColorArray();
|
||||
default: return Variant();
|
||||
case PACKED_VECTOR3_ARRAY:
|
||||
return PackedVector3Array();
|
||||
case PACKED_COLOR_ARRAY:
|
||||
return PackedColorArray();
|
||||
default:
|
||||
return Variant();
|
||||
}
|
||||
|
||||
} else if (p_argcount == 1 && p_args[0]->type == p_type) {
|
||||
@ -1354,46 +1410,68 @@ Variant Variant::construct(const Variant::Type p_type, const Variant **p_args, i
|
||||
case VECTOR2I: {
|
||||
return Vector2i(*p_args[0]);
|
||||
}
|
||||
case RECT2: return (Rect2(*p_args[0]));
|
||||
case RECT2I: return (Rect2i(*p_args[0]));
|
||||
case VECTOR3: return (Vector3(*p_args[0]));
|
||||
case VECTOR3I: return (Vector3i(*p_args[0]));
|
||||
case RECT2:
|
||||
return (Rect2(*p_args[0]));
|
||||
case RECT2I:
|
||||
return (Rect2i(*p_args[0]));
|
||||
case VECTOR3:
|
||||
return (Vector3(*p_args[0]));
|
||||
case VECTOR3I:
|
||||
return (Vector3i(*p_args[0]));
|
||||
case TRANSFORM2D:
|
||||
return (Transform2D(p_args[0]->operator Transform2D()));
|
||||
case PLANE: return (Plane(*p_args[0]));
|
||||
case QUAT: return (p_args[0]->operator Quat());
|
||||
case PLANE:
|
||||
return (Plane(*p_args[0]));
|
||||
case QUAT:
|
||||
return (p_args[0]->operator Quat());
|
||||
case AABB:
|
||||
return (::AABB(*p_args[0]));
|
||||
case BASIS: return (Basis(p_args[0]->operator Basis()));
|
||||
case BASIS:
|
||||
return (Basis(p_args[0]->operator Basis()));
|
||||
case TRANSFORM:
|
||||
return (Transform(p_args[0]->operator Transform()));
|
||||
|
||||
// misc types
|
||||
case COLOR: return p_args[0]->type == Variant::STRING ? Color::html(*p_args[0]) : Color::hex(*p_args[0]);
|
||||
case COLOR:
|
||||
return p_args[0]->type == Variant::STRING ? Color::html(*p_args[0]) : Color::hex(*p_args[0]);
|
||||
case STRING_NAME:
|
||||
return (StringName(p_args[0]->operator StringName()));
|
||||
case NODE_PATH:
|
||||
return (NodePath(p_args[0]->operator NodePath()));
|
||||
case _RID: return (RID(*p_args[0]));
|
||||
case OBJECT: return ((Object *)(p_args[0]->operator Object *()));
|
||||
case CALLABLE: return ((Callable)(p_args[0]->operator Callable()));
|
||||
case SIGNAL: return ((Signal)(p_args[0]->operator Signal()));
|
||||
case DICTIONARY: return p_args[0]->operator Dictionary();
|
||||
case _RID:
|
||||
return (RID(*p_args[0]));
|
||||
case OBJECT:
|
||||
return ((Object *)(p_args[0]->operator Object *()));
|
||||
case CALLABLE:
|
||||
return ((Callable)(p_args[0]->operator Callable()));
|
||||
case SIGNAL:
|
||||
return ((Signal)(p_args[0]->operator Signal()));
|
||||
case DICTIONARY:
|
||||
return p_args[0]->operator Dictionary();
|
||||
case ARRAY:
|
||||
return p_args[0]->operator Array();
|
||||
|
||||
// arrays
|
||||
case PACKED_BYTE_ARRAY: return (PackedByteArray(*p_args[0]));
|
||||
case PACKED_INT32_ARRAY: return (PackedInt32Array(*p_args[0]));
|
||||
case PACKED_INT64_ARRAY: return (PackedInt64Array(*p_args[0]));
|
||||
case PACKED_FLOAT32_ARRAY: return (PackedFloat32Array(*p_args[0]));
|
||||
case PACKED_FLOAT64_ARRAY: return (PackedFloat64Array(*p_args[0]));
|
||||
case PACKED_STRING_ARRAY: return (PackedStringArray(*p_args[0]));
|
||||
case PACKED_BYTE_ARRAY:
|
||||
return (PackedByteArray(*p_args[0]));
|
||||
case PACKED_INT32_ARRAY:
|
||||
return (PackedInt32Array(*p_args[0]));
|
||||
case PACKED_INT64_ARRAY:
|
||||
return (PackedInt64Array(*p_args[0]));
|
||||
case PACKED_FLOAT32_ARRAY:
|
||||
return (PackedFloat32Array(*p_args[0]));
|
||||
case PACKED_FLOAT64_ARRAY:
|
||||
return (PackedFloat64Array(*p_args[0]));
|
||||
case PACKED_STRING_ARRAY:
|
||||
return (PackedStringArray(*p_args[0]));
|
||||
case PACKED_VECTOR2_ARRAY:
|
||||
return (PackedVector2Array(*p_args[0]));
|
||||
case PACKED_VECTOR3_ARRAY: return (PackedVector3Array(*p_args[0]));
|
||||
case PACKED_COLOR_ARRAY: return (PackedColorArray(*p_args[0]));
|
||||
default: return Variant();
|
||||
case PACKED_VECTOR3_ARRAY:
|
||||
return (PackedVector3Array(*p_args[0]));
|
||||
case PACKED_COLOR_ARRAY:
|
||||
return (PackedColorArray(*p_args[0]));
|
||||
default:
|
||||
return Variant();
|
||||
}
|
||||
} else if (p_argcount >= 1) {
|
||||
|
||||
|
@ -181,21 +181,26 @@ bool Variant::booleanize() const {
|
||||
return; \
|
||||
}
|
||||
|
||||
#define DEFAULT_OP_NUM(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) _RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) _RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_NUM(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_NUM_NULL(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) _RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) _RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
if (p_b.type == NIL) _RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_NUM_NULL(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
if (p_b.type == NIL) \
|
||||
_RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#ifdef DEBUG_ENABLED
|
||||
@ -219,12 +224,14 @@ bool Variant::booleanize() const {
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
#else
|
||||
#define DEFAULT_OP_NUM_DIV(m_prefix, m_op_name, m_name, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) _RETURN(p_a._data.m_type / p_b._data._int); \
|
||||
if (p_b.type == FLOAT) _RETURN(p_a._data.m_type / p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_NUM_DIV(m_prefix, m_op_name, m_name, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) \
|
||||
_RETURN(p_a._data.m_type / p_b._data._int); \
|
||||
if (p_b.type == FLOAT) \
|
||||
_RETURN(p_a._data.m_type / p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
#endif
|
||||
|
||||
@ -238,62 +245,84 @@ bool Variant::booleanize() const {
|
||||
_RETURN(p_a._data.m_type); \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_NUM_VEC(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) _RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) _RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
if (p_b.type == VECTOR2) _RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector2 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR3) _RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector3 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR2I) _RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector2 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR3I) _RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector3 *>(p_b._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_NUM_VEC(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == INT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) \
|
||||
_RETURN(p_a._data.m_type m_op p_b._data._float); \
|
||||
if (p_b.type == VECTOR2) \
|
||||
_RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector2 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR3) \
|
||||
_RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector3 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR2I) \
|
||||
_RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector2 *>(p_b._data._mem)); \
|
||||
if (p_b.type == VECTOR3I) \
|
||||
_RETURN(p_a._data.m_type m_op *reinterpret_cast<const Vector3 *>(p_b._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_STR_REV(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) _RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const String *>(p_a._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) _RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const StringName *>(p_a._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) _RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const NodePath *>(p_a._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_STR_REV(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const String *>(p_a._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const StringName *>(p_a._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_b._data._mem) m_op *reinterpret_cast<const NodePath *>(p_a._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_STR(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_STR(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_STR_NULL(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) _RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_STR_NULL(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) \
|
||||
_RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_STR_NULL_NP(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) _RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_STR_NULL_NP(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == NODE_PATH) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const NodePath *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) \
|
||||
_RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_STR_NULL_SN(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) _RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_STR_NULL_SN(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == STRING) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const String *>(p_b._data._mem)); \
|
||||
if (p_b.type == STRING_NAME) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const StringName *>(p_b._data._mem)); \
|
||||
if (p_b.type == NIL) \
|
||||
_RETURN(!(p_b.type m_op NIL)); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
};
|
||||
|
||||
#define DEFAULT_OP_LOCALMEM_REV(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
@ -332,13 +361,16 @@ bool Variant::booleanize() const {
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem)); \
|
||||
}
|
||||
|
||||
#define DEFAULT_OP_LOCALMEM_NUM(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == m_name) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const m_type *>(p_b._data._mem)); \
|
||||
if (p_b.type == INT) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) _RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
#define DEFAULT_OP_LOCALMEM_NUM(m_prefix, m_op_name, m_name, m_op, m_type) \
|
||||
CASE_TYPE(m_prefix, m_op_name, m_name) { \
|
||||
if (p_b.type == m_name) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op *reinterpret_cast<const m_type *>(p_b._data._mem)); \
|
||||
if (p_b.type == INT) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op p_b._data._int); \
|
||||
if (p_b.type == FLOAT) \
|
||||
_RETURN(*reinterpret_cast<const m_type *>(p_a._data._mem) m_op p_b._data._float); \
|
||||
\
|
||||
_RETURN_FAIL \
|
||||
}
|
||||
|
||||
#define DEFAULT_OP_PTR(m_op, m_name, m_sub) \
|
||||
@ -436,7 +468,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
SWITCH(math, p_op, p_a.type) {
|
||||
SWITCH_OP(math, OP_EQUAL, p_a.type) {
|
||||
CASE_TYPE(math, OP_EQUAL, NIL) {
|
||||
if (p_b.type == NIL) _RETURN(true);
|
||||
if (p_b.type == NIL)
|
||||
_RETURN(true);
|
||||
if (p_b.type == OBJECT)
|
||||
_RETURN(p_b._get_obj().obj == nullptr);
|
||||
|
||||
@ -532,7 +565,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
|
||||
SWITCH_OP(math, OP_NOT_EQUAL, p_a.type) {
|
||||
CASE_TYPE(math, OP_NOT_EQUAL, NIL) {
|
||||
if (p_b.type == NIL) _RETURN(false);
|
||||
if (p_b.type == NIL)
|
||||
_RETURN(false);
|
||||
if (p_b.type == OBJECT)
|
||||
_RETURN(p_b._get_obj().obj != nullptr);
|
||||
|
||||
@ -981,7 +1015,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
case VECTOR2: {
|
||||
_RETURN(p_a._data._transform2d->xform(*(const Vector2 *)p_b._data._mem));
|
||||
}
|
||||
default: _RETURN_FAIL;
|
||||
default:
|
||||
_RETURN_FAIL;
|
||||
}
|
||||
}
|
||||
|
||||
@ -996,7 +1031,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
case FLOAT: {
|
||||
_RETURN(*reinterpret_cast<const Quat *>(p_a._data._mem) * p_b._data._float);
|
||||
}
|
||||
default: _RETURN_FAIL;
|
||||
default:
|
||||
_RETURN_FAIL;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1008,7 +1044,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
case BASIS: {
|
||||
_RETURN(*p_a._data._basis * *p_b._data._basis);
|
||||
}
|
||||
default: _RETURN_FAIL;
|
||||
default:
|
||||
_RETURN_FAIL;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1020,7 +1057,8 @@ void Variant::evaluate(const Operator &p_op, const Variant &p_a,
|
||||
case TRANSFORM: {
|
||||
_RETURN(*p_a._data._transform * *p_b._data._transform);
|
||||
}
|
||||
default: _RETURN_FAIL;
|
||||
default:
|
||||
_RETURN_FAIL;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1983,7 +2021,8 @@ Variant Variant::get_named(const StringName &p_index, bool *r_valid) const {
|
||||
|
||||
#define DEFAULT_OP_DVECTOR_SET(m_name, m_type, skip_cond) \
|
||||
case m_name: { \
|
||||
if (skip_cond) return; \
|
||||
if (skip_cond) \
|
||||
return; \
|
||||
\
|
||||
if (p_index.get_type() == Variant::INT || p_index.get_type() == Variant::FLOAT) { \
|
||||
int index = p_index; \
|
||||
|
@ -243,11 +243,21 @@ Error VariantParser::get_token(Stream *p_stream, Token &r_token, int &line, Stri
|
||||
|
||||
switch (next) {
|
||||
|
||||
case 'b': res = 8; break;
|
||||
case 't': res = 9; break;
|
||||
case 'n': res = 10; break;
|
||||
case 'f': res = 12; break;
|
||||
case 'r': res = 13; break;
|
||||
case 'b':
|
||||
res = 8;
|
||||
break;
|
||||
case 't':
|
||||
res = 9;
|
||||
break;
|
||||
case 'n':
|
||||
res = 10;
|
||||
break;
|
||||
case 'f':
|
||||
res = 12;
|
||||
break;
|
||||
case 'r':
|
||||
res = 13;
|
||||
break;
|
||||
case 'u': {
|
||||
//hex number
|
||||
for (int j = 0; j < 4; j++) {
|
||||
|
@ -69,7 +69,8 @@ public:
|
||||
void remove(int p_index) { _cowdata.remove(p_index); }
|
||||
void erase(const T &p_val) {
|
||||
int idx = find(p_val);
|
||||
if (idx >= 0) remove(idx);
|
||||
if (idx >= 0)
|
||||
remove(idx);
|
||||
}
|
||||
void invert();
|
||||
|
||||
|
@ -55,10 +55,14 @@ static String _typestr(SL::DataType p_type) {
|
||||
static String _prestr(SL::DataPrecision p_pres) {
|
||||
|
||||
switch (p_pres) {
|
||||
case SL::PRECISION_LOWP: return "lowp ";
|
||||
case SL::PRECISION_MEDIUMP: return "mediump ";
|
||||
case SL::PRECISION_HIGHP: return "highp ";
|
||||
case SL::PRECISION_DEFAULT: return "";
|
||||
case SL::PRECISION_LOWP:
|
||||
return "lowp ";
|
||||
case SL::PRECISION_MEDIUMP:
|
||||
return "mediump ";
|
||||
case SL::PRECISION_HIGHP:
|
||||
return "highp ";
|
||||
case SL::PRECISION_DEFAULT:
|
||||
return "";
|
||||
}
|
||||
return "";
|
||||
}
|
||||
@ -66,9 +70,12 @@ static String _prestr(SL::DataPrecision p_pres) {
|
||||
static String _qualstr(SL::ArgumentQualifier p_qual) {
|
||||
|
||||
switch (p_qual) {
|
||||
case SL::ARGUMENT_QUALIFIER_IN: return "in ";
|
||||
case SL::ARGUMENT_QUALIFIER_OUT: return "out ";
|
||||
case SL::ARGUMENT_QUALIFIER_INOUT: return "inout ";
|
||||
case SL::ARGUMENT_QUALIFIER_IN:
|
||||
return "in ";
|
||||
case SL::ARGUMENT_QUALIFIER_OUT:
|
||||
return "out ";
|
||||
case SL::ARGUMENT_QUALIFIER_INOUT:
|
||||
return "inout ";
|
||||
}
|
||||
return "";
|
||||
}
|
||||
@ -96,7 +103,8 @@ static String f2sp0(float p_float) {
|
||||
static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNode::Value> &p_values) {
|
||||
|
||||
switch (p_type) {
|
||||
case SL::TYPE_BOOL: return p_values[0].boolean ? "true" : "false";
|
||||
case SL::TYPE_BOOL:
|
||||
return p_values[0].boolean ? "true" : "false";
|
||||
case SL::TYPE_BVEC2:
|
||||
case SL::TYPE_BVEC3:
|
||||
case SL::TYPE_BVEC4: {
|
||||
@ -118,7 +126,8 @@ static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNo
|
||||
}
|
||||
|
||||
// GLSL ES 2 doesn't support uints, so we just use signed ints instead...
|
||||
case SL::TYPE_UINT: return itos(p_values[0].uint);
|
||||
case SL::TYPE_UINT:
|
||||
return itos(p_values[0].uint);
|
||||
case SL::TYPE_UVEC2:
|
||||
case SL::TYPE_UVEC3:
|
||||
case SL::TYPE_UVEC4: {
|
||||
@ -140,7 +149,8 @@ static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNo
|
||||
|
||||
} break;
|
||||
|
||||
case SL::TYPE_INT: return itos(p_values[0].sint);
|
||||
case SL::TYPE_INT:
|
||||
return itos(p_values[0].sint);
|
||||
case SL::TYPE_IVEC2:
|
||||
case SL::TYPE_IVEC3:
|
||||
case SL::TYPE_IVEC4: {
|
||||
@ -161,7 +171,8 @@ static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNo
|
||||
return text.as_string();
|
||||
|
||||
} break;
|
||||
case SL::TYPE_FLOAT: return f2sp0(p_values[0].real);
|
||||
case SL::TYPE_FLOAT:
|
||||
return f2sp0(p_values[0].real);
|
||||
case SL::TYPE_VEC2:
|
||||
case SL::TYPE_VEC3:
|
||||
case SL::TYPE_VEC4: {
|
||||
@ -202,7 +213,8 @@ static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNo
|
||||
return text.as_string();
|
||||
|
||||
} break;
|
||||
default: ERR_FAIL_V(String());
|
||||
default:
|
||||
ERR_FAIL_V(String());
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1128,7 +1128,8 @@ float SchlickFresnel(float u) {
|
||||
}
|
||||
|
||||
float GTR1(float NdotH, float a) {
|
||||
if (a >= 1.0) return 1.0 / M_PI;
|
||||
if (a >= 1.0)
|
||||
return 1.0 / M_PI;
|
||||
float a2 = a * a;
|
||||
float t = 1.0 + (a2 - 1.0) * NdotH * NdotH;
|
||||
return (a2 - 1.0) / (M_PI * log(a2) * t);
|
||||
|
@ -248,7 +248,8 @@ void IP_Unix::get_local_interfaces(Map<String, Interface_Info> *r_interfaces) co
|
||||
info.ip_addresses.push_front(_sockaddr2ip(ifa->ifa_addr));
|
||||
}
|
||||
|
||||
if (ifAddrStruct != nullptr) freeifaddrs(ifAddrStruct);
|
||||
if (ifAddrStruct != nullptr)
|
||||
freeifaddrs(ifAddrStruct);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -49,11 +49,21 @@ void SyslogLogger::print_error(const char *p_function, const char *p_file, int p
|
||||
|
||||
const char *err_type = "**ERROR**";
|
||||
switch (p_type) {
|
||||
case ERR_ERROR: err_type = "**ERROR**"; break;
|
||||
case ERR_WARNING: err_type = "**WARNING**"; break;
|
||||
case ERR_SCRIPT: err_type = "**SCRIPT ERROR**"; break;
|
||||
case ERR_SHADER: err_type = "**SHADER ERROR**"; break;
|
||||
default: ERR_PRINT("Unknown error type"); break;
|
||||
case ERR_ERROR:
|
||||
err_type = "**ERROR**";
|
||||
break;
|
||||
case ERR_WARNING:
|
||||
err_type = "**WARNING**";
|
||||
break;
|
||||
case ERR_SCRIPT:
|
||||
err_type = "**SCRIPT ERROR**";
|
||||
break;
|
||||
case ERR_SHADER:
|
||||
err_type = "**SHADER ERROR**";
|
||||
break;
|
||||
default:
|
||||
ERR_PRINT("Unknown error type");
|
||||
break;
|
||||
}
|
||||
|
||||
const char *err_details;
|
||||
|
@ -566,52 +566,66 @@ int RenderingDeviceVulkan::get_format_vertex_size(DataFormat p_format) {
|
||||
case DATA_FORMAT_B8G8R8A8_UNORM:
|
||||
case DATA_FORMAT_B8G8R8A8_SNORM:
|
||||
case DATA_FORMAT_B8G8R8A8_UINT:
|
||||
case DATA_FORMAT_B8G8R8A8_SINT: return 4;
|
||||
case DATA_FORMAT_B8G8R8A8_SINT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R16_UNORM:
|
||||
case DATA_FORMAT_R16_SNORM:
|
||||
case DATA_FORMAT_R16_UINT:
|
||||
case DATA_FORMAT_R16_SINT:
|
||||
case DATA_FORMAT_R16_SFLOAT: return 4;
|
||||
case DATA_FORMAT_R16_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R16G16_UNORM:
|
||||
case DATA_FORMAT_R16G16_SNORM:
|
||||
case DATA_FORMAT_R16G16_UINT:
|
||||
case DATA_FORMAT_R16G16_SINT:
|
||||
case DATA_FORMAT_R16G16_SFLOAT: return 4;
|
||||
case DATA_FORMAT_R16G16_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R16G16B16_UNORM:
|
||||
case DATA_FORMAT_R16G16B16_SNORM:
|
||||
case DATA_FORMAT_R16G16B16_UINT:
|
||||
case DATA_FORMAT_R16G16B16_SINT:
|
||||
case DATA_FORMAT_R16G16B16_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R16G16B16_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R16G16B16A16_UNORM:
|
||||
case DATA_FORMAT_R16G16B16A16_SNORM:
|
||||
case DATA_FORMAT_R16G16B16A16_UINT:
|
||||
case DATA_FORMAT_R16G16B16A16_SINT:
|
||||
case DATA_FORMAT_R16G16B16A16_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R16G16B16A16_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R32_UINT:
|
||||
case DATA_FORMAT_R32_SINT:
|
||||
case DATA_FORMAT_R32_SFLOAT: return 4;
|
||||
case DATA_FORMAT_R32_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R32G32_UINT:
|
||||
case DATA_FORMAT_R32G32_SINT:
|
||||
case DATA_FORMAT_R32G32_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R32G32_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R32G32B32_UINT:
|
||||
case DATA_FORMAT_R32G32B32_SINT:
|
||||
case DATA_FORMAT_R32G32B32_SFLOAT: return 12;
|
||||
case DATA_FORMAT_R32G32B32_SFLOAT:
|
||||
return 12;
|
||||
case DATA_FORMAT_R32G32B32A32_UINT:
|
||||
case DATA_FORMAT_R32G32B32A32_SINT:
|
||||
case DATA_FORMAT_R32G32B32A32_SFLOAT: return 16;
|
||||
case DATA_FORMAT_R32G32B32A32_SFLOAT:
|
||||
return 16;
|
||||
case DATA_FORMAT_R64_UINT:
|
||||
case DATA_FORMAT_R64_SINT:
|
||||
case DATA_FORMAT_R64_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R64_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R64G64_UINT:
|
||||
case DATA_FORMAT_R64G64_SINT:
|
||||
case DATA_FORMAT_R64G64_SFLOAT: return 16;
|
||||
case DATA_FORMAT_R64G64_SFLOAT:
|
||||
return 16;
|
||||
case DATA_FORMAT_R64G64B64_UINT:
|
||||
case DATA_FORMAT_R64G64B64_SINT:
|
||||
case DATA_FORMAT_R64G64B64_SFLOAT: return 24;
|
||||
case DATA_FORMAT_R64G64B64_SFLOAT:
|
||||
return 24;
|
||||
case DATA_FORMAT_R64G64B64A64_UINT:
|
||||
case DATA_FORMAT_R64G64B64A64_SINT:
|
||||
case DATA_FORMAT_R64G64B64A64_SFLOAT: return 32;
|
||||
default: return 0;
|
||||
case DATA_FORMAT_R64G64B64A64_SFLOAT:
|
||||
return 32;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
@ -619,28 +633,32 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
|
||||
switch (p_format) {
|
||||
|
||||
case DATA_FORMAT_R4G4_UNORM_PACK8: return 1;
|
||||
case DATA_FORMAT_R4G4_UNORM_PACK8:
|
||||
return 1;
|
||||
case DATA_FORMAT_R4G4B4A4_UNORM_PACK16:
|
||||
case DATA_FORMAT_B4G4R4A4_UNORM_PACK16:
|
||||
case DATA_FORMAT_R5G6B5_UNORM_PACK16:
|
||||
case DATA_FORMAT_B5G6R5_UNORM_PACK16:
|
||||
case DATA_FORMAT_R5G5B5A1_UNORM_PACK16:
|
||||
case DATA_FORMAT_B5G5R5A1_UNORM_PACK16:
|
||||
case DATA_FORMAT_A1R5G5B5_UNORM_PACK16: return 2;
|
||||
case DATA_FORMAT_A1R5G5B5_UNORM_PACK16:
|
||||
return 2;
|
||||
case DATA_FORMAT_R8_UNORM:
|
||||
case DATA_FORMAT_R8_SNORM:
|
||||
case DATA_FORMAT_R8_USCALED:
|
||||
case DATA_FORMAT_R8_SSCALED:
|
||||
case DATA_FORMAT_R8_UINT:
|
||||
case DATA_FORMAT_R8_SINT:
|
||||
case DATA_FORMAT_R8_SRGB: return 1;
|
||||
case DATA_FORMAT_R8_SRGB:
|
||||
return 1;
|
||||
case DATA_FORMAT_R8G8_UNORM:
|
||||
case DATA_FORMAT_R8G8_SNORM:
|
||||
case DATA_FORMAT_R8G8_USCALED:
|
||||
case DATA_FORMAT_R8G8_SSCALED:
|
||||
case DATA_FORMAT_R8G8_UINT:
|
||||
case DATA_FORMAT_R8G8_SINT:
|
||||
case DATA_FORMAT_R8G8_SRGB: return 2;
|
||||
case DATA_FORMAT_R8G8_SRGB:
|
||||
return 2;
|
||||
case DATA_FORMAT_R8G8B8_UNORM:
|
||||
case DATA_FORMAT_R8G8B8_SNORM:
|
||||
case DATA_FORMAT_R8G8B8_USCALED:
|
||||
@ -654,7 +672,8 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_B8G8R8_SSCALED:
|
||||
case DATA_FORMAT_B8G8R8_UINT:
|
||||
case DATA_FORMAT_B8G8R8_SINT:
|
||||
case DATA_FORMAT_B8G8R8_SRGB: return 3;
|
||||
case DATA_FORMAT_B8G8R8_SRGB:
|
||||
return 3;
|
||||
case DATA_FORMAT_R8G8B8A8_UNORM:
|
||||
case DATA_FORMAT_R8G8B8A8_SNORM:
|
||||
case DATA_FORMAT_R8G8B8A8_USCALED:
|
||||
@ -668,7 +687,8 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_B8G8R8A8_SSCALED:
|
||||
case DATA_FORMAT_B8G8R8A8_UINT:
|
||||
case DATA_FORMAT_B8G8R8A8_SINT:
|
||||
case DATA_FORMAT_B8G8R8A8_SRGB: return 4;
|
||||
case DATA_FORMAT_B8G8R8A8_SRGB:
|
||||
return 4;
|
||||
case DATA_FORMAT_A8B8G8R8_UNORM_PACK32:
|
||||
case DATA_FORMAT_A8B8G8R8_SNORM_PACK32:
|
||||
case DATA_FORMAT_A8B8G8R8_USCALED_PACK32:
|
||||
@ -687,67 +707,87 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_A2B10G10R10_USCALED_PACK32:
|
||||
case DATA_FORMAT_A2B10G10R10_SSCALED_PACK32:
|
||||
case DATA_FORMAT_A2B10G10R10_UINT_PACK32:
|
||||
case DATA_FORMAT_A2B10G10R10_SINT_PACK32: return 4;
|
||||
case DATA_FORMAT_A2B10G10R10_SINT_PACK32:
|
||||
return 4;
|
||||
case DATA_FORMAT_R16_UNORM:
|
||||
case DATA_FORMAT_R16_SNORM:
|
||||
case DATA_FORMAT_R16_USCALED:
|
||||
case DATA_FORMAT_R16_SSCALED:
|
||||
case DATA_FORMAT_R16_UINT:
|
||||
case DATA_FORMAT_R16_SINT:
|
||||
case DATA_FORMAT_R16_SFLOAT: return 2;
|
||||
case DATA_FORMAT_R16_SFLOAT:
|
||||
return 2;
|
||||
case DATA_FORMAT_R16G16_UNORM:
|
||||
case DATA_FORMAT_R16G16_SNORM:
|
||||
case DATA_FORMAT_R16G16_USCALED:
|
||||
case DATA_FORMAT_R16G16_SSCALED:
|
||||
case DATA_FORMAT_R16G16_UINT:
|
||||
case DATA_FORMAT_R16G16_SINT:
|
||||
case DATA_FORMAT_R16G16_SFLOAT: return 4;
|
||||
case DATA_FORMAT_R16G16_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R16G16B16_UNORM:
|
||||
case DATA_FORMAT_R16G16B16_SNORM:
|
||||
case DATA_FORMAT_R16G16B16_USCALED:
|
||||
case DATA_FORMAT_R16G16B16_SSCALED:
|
||||
case DATA_FORMAT_R16G16B16_UINT:
|
||||
case DATA_FORMAT_R16G16B16_SINT:
|
||||
case DATA_FORMAT_R16G16B16_SFLOAT: return 6;
|
||||
case DATA_FORMAT_R16G16B16_SFLOAT:
|
||||
return 6;
|
||||
case DATA_FORMAT_R16G16B16A16_UNORM:
|
||||
case DATA_FORMAT_R16G16B16A16_SNORM:
|
||||
case DATA_FORMAT_R16G16B16A16_USCALED:
|
||||
case DATA_FORMAT_R16G16B16A16_SSCALED:
|
||||
case DATA_FORMAT_R16G16B16A16_UINT:
|
||||
case DATA_FORMAT_R16G16B16A16_SINT:
|
||||
case DATA_FORMAT_R16G16B16A16_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R16G16B16A16_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R32_UINT:
|
||||
case DATA_FORMAT_R32_SINT:
|
||||
case DATA_FORMAT_R32_SFLOAT: return 4;
|
||||
case DATA_FORMAT_R32_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_R32G32_UINT:
|
||||
case DATA_FORMAT_R32G32_SINT:
|
||||
case DATA_FORMAT_R32G32_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R32G32_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R32G32B32_UINT:
|
||||
case DATA_FORMAT_R32G32B32_SINT:
|
||||
case DATA_FORMAT_R32G32B32_SFLOAT: return 12;
|
||||
case DATA_FORMAT_R32G32B32_SFLOAT:
|
||||
return 12;
|
||||
case DATA_FORMAT_R32G32B32A32_UINT:
|
||||
case DATA_FORMAT_R32G32B32A32_SINT:
|
||||
case DATA_FORMAT_R32G32B32A32_SFLOAT: return 16;
|
||||
case DATA_FORMAT_R32G32B32A32_SFLOAT:
|
||||
return 16;
|
||||
case DATA_FORMAT_R64_UINT:
|
||||
case DATA_FORMAT_R64_SINT:
|
||||
case DATA_FORMAT_R64_SFLOAT: return 8;
|
||||
case DATA_FORMAT_R64_SFLOAT:
|
||||
return 8;
|
||||
case DATA_FORMAT_R64G64_UINT:
|
||||
case DATA_FORMAT_R64G64_SINT:
|
||||
case DATA_FORMAT_R64G64_SFLOAT: return 16;
|
||||
case DATA_FORMAT_R64G64_SFLOAT:
|
||||
return 16;
|
||||
case DATA_FORMAT_R64G64B64_UINT:
|
||||
case DATA_FORMAT_R64G64B64_SINT:
|
||||
case DATA_FORMAT_R64G64B64_SFLOAT: return 24;
|
||||
case DATA_FORMAT_R64G64B64_SFLOAT:
|
||||
return 24;
|
||||
case DATA_FORMAT_R64G64B64A64_UINT:
|
||||
case DATA_FORMAT_R64G64B64A64_SINT:
|
||||
case DATA_FORMAT_R64G64B64A64_SFLOAT: return 32;
|
||||
case DATA_FORMAT_R64G64B64A64_SFLOAT:
|
||||
return 32;
|
||||
case DATA_FORMAT_B10G11R11_UFLOAT_PACK32:
|
||||
case DATA_FORMAT_E5B9G9R9_UFLOAT_PACK32: return 4;
|
||||
case DATA_FORMAT_D16_UNORM: return 2;
|
||||
case DATA_FORMAT_X8_D24_UNORM_PACK32: return 4;
|
||||
case DATA_FORMAT_D32_SFLOAT: return 4;
|
||||
case DATA_FORMAT_S8_UINT: return 1;
|
||||
case DATA_FORMAT_D16_UNORM_S8_UINT: return 4;
|
||||
case DATA_FORMAT_D24_UNORM_S8_UINT: return 4;
|
||||
case DATA_FORMAT_E5B9G9R9_UFLOAT_PACK32:
|
||||
return 4;
|
||||
case DATA_FORMAT_D16_UNORM:
|
||||
return 2;
|
||||
case DATA_FORMAT_X8_D24_UNORM_PACK32:
|
||||
return 4;
|
||||
case DATA_FORMAT_D32_SFLOAT:
|
||||
return 4;
|
||||
case DATA_FORMAT_S8_UINT:
|
||||
return 1;
|
||||
case DATA_FORMAT_D16_UNORM_S8_UINT:
|
||||
return 4;
|
||||
case DATA_FORMAT_D24_UNORM_S8_UINT:
|
||||
return 4;
|
||||
case DATA_FORMAT_D32_SFLOAT_S8_UINT:
|
||||
return 5; //?
|
||||
case DATA_FORMAT_BC1_RGB_UNORM_BLOCK:
|
||||
@ -765,17 +805,20 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_BC6H_UFLOAT_BLOCK:
|
||||
case DATA_FORMAT_BC6H_SFLOAT_BLOCK:
|
||||
case DATA_FORMAT_BC7_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC7_SRGB_BLOCK: return 1;
|
||||
case DATA_FORMAT_BC7_SRGB_BLOCK:
|
||||
return 1;
|
||||
case DATA_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK: return 1;
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:
|
||||
return 1;
|
||||
case DATA_FORMAT_EAC_R11_UNORM_BLOCK:
|
||||
case DATA_FORMAT_EAC_R11_SNORM_BLOCK:
|
||||
case DATA_FORMAT_EAC_R11G11_UNORM_BLOCK:
|
||||
case DATA_FORMAT_EAC_R11G11_SNORM_BLOCK: return 1;
|
||||
case DATA_FORMAT_EAC_R11G11_SNORM_BLOCK:
|
||||
return 1;
|
||||
case DATA_FORMAT_ASTC_4x4_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ASTC_4x4_SRGB_BLOCK:
|
||||
case DATA_FORMAT_ASTC_5x4_UNORM_BLOCK:
|
||||
@ -803,14 +846,17 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_ASTC_12x10_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ASTC_12x10_SRGB_BLOCK:
|
||||
case DATA_FORMAT_ASTC_12x12_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ASTC_12x12_SRGB_BLOCK: return 1;
|
||||
case DATA_FORMAT_ASTC_12x12_SRGB_BLOCK:
|
||||
return 1;
|
||||
case DATA_FORMAT_G8B8G8R8_422_UNORM:
|
||||
case DATA_FORMAT_B8G8R8G8_422_UNORM: return 4;
|
||||
case DATA_FORMAT_B8G8R8G8_422_UNORM:
|
||||
return 4;
|
||||
case DATA_FORMAT_G8_B8_R8_3PLANE_420_UNORM:
|
||||
case DATA_FORMAT_G8_B8R8_2PLANE_420_UNORM:
|
||||
case DATA_FORMAT_G8_B8_R8_3PLANE_422_UNORM:
|
||||
case DATA_FORMAT_G8_B8R8_2PLANE_422_UNORM:
|
||||
case DATA_FORMAT_G8_B8_R8_3PLANE_444_UNORM: return 4;
|
||||
case DATA_FORMAT_G8_B8_R8_3PLANE_444_UNORM:
|
||||
return 4;
|
||||
case DATA_FORMAT_R10X6_UNORM_PACK16:
|
||||
case DATA_FORMAT_R10X6G10X6_UNORM_2PACK16:
|
||||
case DATA_FORMAT_R10X6G10X6B10X6A10X6_UNORM_4PACK16:
|
||||
@ -830,14 +876,16 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_G12X4_B12X4R12X4_2PLANE_420_UNORM_3PACK16:
|
||||
case DATA_FORMAT_G12X4_B12X4_R12X4_3PLANE_422_UNORM_3PACK16:
|
||||
case DATA_FORMAT_G12X4_B12X4R12X4_2PLANE_422_UNORM_3PACK16:
|
||||
case DATA_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16: return 2;
|
||||
case DATA_FORMAT_G12X4_B12X4_R12X4_3PLANE_444_UNORM_3PACK16:
|
||||
return 2;
|
||||
case DATA_FORMAT_G16B16G16R16_422_UNORM:
|
||||
case DATA_FORMAT_B16G16R16G16_422_UNORM:
|
||||
case DATA_FORMAT_G16_B16_R16_3PLANE_420_UNORM:
|
||||
case DATA_FORMAT_G16_B16R16_2PLANE_420_UNORM:
|
||||
case DATA_FORMAT_G16_B16_R16_3PLANE_422_UNORM:
|
||||
case DATA_FORMAT_G16_B16R16_2PLANE_422_UNORM:
|
||||
case DATA_FORMAT_G16_B16_R16_3PLANE_444_UNORM: return 8;
|
||||
case DATA_FORMAT_G16_B16_R16_3PLANE_444_UNORM:
|
||||
return 8;
|
||||
case DATA_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:
|
||||
@ -845,7 +893,8 @@ uint32_t RenderingDeviceVulkan::get_image_format_pixel_size(DataFormat p_format)
|
||||
case DATA_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG: return 1;
|
||||
case DATA_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:
|
||||
return 1;
|
||||
default: {
|
||||
ERR_PRINT("Format not handled, bug");
|
||||
}
|
||||
@ -943,29 +992,41 @@ uint32_t RenderingDeviceVulkan::get_compressed_image_format_block_byte_size(Data
|
||||
case DATA_FORMAT_BC1_RGB_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC1_RGB_SRGB_BLOCK:
|
||||
case DATA_FORMAT_BC1_RGBA_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC1_RGBA_SRGB_BLOCK: return 8;
|
||||
case DATA_FORMAT_BC1_RGBA_SRGB_BLOCK:
|
||||
return 8;
|
||||
case DATA_FORMAT_BC2_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC2_SRGB_BLOCK: return 16;
|
||||
case DATA_FORMAT_BC2_SRGB_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_BC3_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC3_SRGB_BLOCK: return 16;
|
||||
case DATA_FORMAT_BC3_SRGB_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_BC4_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC4_SNORM_BLOCK: return 8;
|
||||
case DATA_FORMAT_BC4_SNORM_BLOCK:
|
||||
return 8;
|
||||
case DATA_FORMAT_BC5_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC5_SNORM_BLOCK: return 16;
|
||||
case DATA_FORMAT_BC5_SNORM_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_BC6H_UFLOAT_BLOCK:
|
||||
case DATA_FORMAT_BC6H_SFLOAT_BLOCK: return 16;
|
||||
case DATA_FORMAT_BC6H_SFLOAT_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_BC7_UNORM_BLOCK:
|
||||
case DATA_FORMAT_BC7_SRGB_BLOCK: return 16;
|
||||
case DATA_FORMAT_BC7_SRGB_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_ETC2_R8G8B8_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8_SRGB_BLOCK: return 8;
|
||||
case DATA_FORMAT_ETC2_R8G8B8_SRGB_BLOCK:
|
||||
return 8;
|
||||
case DATA_FORMAT_ETC2_R8G8B8A1_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK: return 8;
|
||||
case DATA_FORMAT_ETC2_R8G8B8A1_SRGB_BLOCK:
|
||||
return 8;
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_UNORM_BLOCK:
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK: return 16;
|
||||
case DATA_FORMAT_ETC2_R8G8B8A8_SRGB_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_EAC_R11_UNORM_BLOCK:
|
||||
case DATA_FORMAT_EAC_R11_SNORM_BLOCK: return 8;
|
||||
case DATA_FORMAT_EAC_R11_SNORM_BLOCK:
|
||||
return 8;
|
||||
case DATA_FORMAT_EAC_R11G11_UNORM_BLOCK:
|
||||
case DATA_FORMAT_EAC_R11G11_SNORM_BLOCK: return 16;
|
||||
case DATA_FORMAT_EAC_R11G11_SNORM_BLOCK:
|
||||
return 16;
|
||||
case DATA_FORMAT_ASTC_4x4_UNORM_BLOCK: //again, not sure about astc
|
||||
case DATA_FORMAT_ASTC_4x4_SRGB_BLOCK:
|
||||
case DATA_FORMAT_ASTC_5x4_UNORM_BLOCK:
|
||||
@ -1028,11 +1089,13 @@ uint32_t RenderingDeviceVulkan::get_compressed_image_format_pixel_rshift(DataFor
|
||||
case DATA_FORMAT_PVRTC1_4BPP_UNORM_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_4BPP_UNORM_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC1_4BPP_SRGB_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG: return 1;
|
||||
case DATA_FORMAT_PVRTC2_4BPP_SRGB_BLOCK_IMG:
|
||||
return 1;
|
||||
case DATA_FORMAT_PVRTC1_2BPP_UNORM_BLOCK_IMG: //these formats are quarter byte size, so rshift is 1
|
||||
case DATA_FORMAT_PVRTC2_2BPP_UNORM_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC1_2BPP_SRGB_BLOCK_IMG:
|
||||
case DATA_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG: return 2;
|
||||
case DATA_FORMAT_PVRTC2_2BPP_SRGB_BLOCK_IMG:
|
||||
return 2;
|
||||
default: {
|
||||
}
|
||||
}
|
||||
@ -7222,42 +7285,77 @@ String RenderingDeviceVulkan::get_captured_timestamp_name(uint32_t p_index) cons
|
||||
|
||||
int RenderingDeviceVulkan::limit_get(Limit p_limit) {
|
||||
switch (p_limit) {
|
||||
case LIMIT_MAX_BOUND_UNIFORM_SETS: return limits.maxBoundDescriptorSets;
|
||||
case LIMIT_MAX_FRAMEBUFFER_COLOR_ATTACHMENTS: return limits.maxColorAttachments;
|
||||
case LIMIT_MAX_TEXTURES_PER_UNIFORM_SET: return limits.maxDescriptorSetSampledImages;
|
||||
case LIMIT_MAX_SAMPLERS_PER_UNIFORM_SET: return limits.maxDescriptorSetSamplers;
|
||||
case LIMIT_MAX_STORAGE_BUFFERS_PER_UNIFORM_SET: return limits.maxDescriptorSetStorageBuffers;
|
||||
case LIMIT_MAX_STORAGE_IMAGES_PER_UNIFORM_SET: return limits.maxDescriptorSetStorageImages;
|
||||
case LIMIT_MAX_UNIFORM_BUFFERS_PER_UNIFORM_SET: return limits.maxDescriptorSetUniformBuffers;
|
||||
case LIMIT_MAX_DRAW_INDEXED_INDEX: return limits.maxDrawIndexedIndexValue;
|
||||
case LIMIT_MAX_FRAMEBUFFER_HEIGHT: return limits.maxFramebufferHeight;
|
||||
case LIMIT_MAX_FRAMEBUFFER_WIDTH: return limits.maxFramebufferWidth;
|
||||
case LIMIT_MAX_TEXTURE_ARRAY_LAYERS: return limits.maxImageArrayLayers;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_1D: return limits.maxImageDimension1D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_2D: return limits.maxImageDimension2D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_3D: return limits.maxImageDimension3D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_CUBE: return limits.maxImageDimensionCube;
|
||||
case LIMIT_MAX_TEXTURES_PER_SHADER_STAGE: return limits.maxPerStageDescriptorSampledImages;
|
||||
case LIMIT_MAX_SAMPLERS_PER_SHADER_STAGE: return limits.maxPerStageDescriptorSamplers;
|
||||
case LIMIT_MAX_STORAGE_BUFFERS_PER_SHADER_STAGE: return limits.maxPerStageDescriptorStorageBuffers;
|
||||
case LIMIT_MAX_STORAGE_IMAGES_PER_SHADER_STAGE: return limits.maxPerStageDescriptorStorageImages;
|
||||
case LIMIT_MAX_UNIFORM_BUFFERS_PER_SHADER_STAGE: return limits.maxPerStageDescriptorUniformBuffers;
|
||||
case LIMIT_MAX_PUSH_CONSTANT_SIZE: return limits.maxPushConstantsSize;
|
||||
case LIMIT_MAX_UNIFORM_BUFFER_SIZE: return limits.maxUniformBufferRange;
|
||||
case LIMIT_MAX_VERTEX_INPUT_ATTRIBUTE_OFFSET: return limits.maxVertexInputAttributeOffset;
|
||||
case LIMIT_MAX_VERTEX_INPUT_ATTRIBUTES: return limits.maxVertexInputAttributes;
|
||||
case LIMIT_MAX_VERTEX_INPUT_BINDINGS: return limits.maxVertexInputBindings;
|
||||
case LIMIT_MAX_VERTEX_INPUT_BINDING_STRIDE: return limits.maxVertexInputBindingStride;
|
||||
case LIMIT_MIN_UNIFORM_BUFFER_OFFSET_ALIGNMENT: return limits.minUniformBufferOffsetAlignment;
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_X: return limits.maxComputeWorkGroupCount[0];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_Y: return limits.maxComputeWorkGroupCount[1];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_Z: return limits.maxComputeWorkGroupCount[2];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_INVOCATIONS: return limits.maxComputeWorkGroupInvocations;
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_X: return limits.maxComputeWorkGroupSize[0];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_Y: return limits.maxComputeWorkGroupSize[1];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_Z: return limits.maxComputeWorkGroupSize[2];
|
||||
case LIMIT_MAX_BOUND_UNIFORM_SETS:
|
||||
return limits.maxBoundDescriptorSets;
|
||||
case LIMIT_MAX_FRAMEBUFFER_COLOR_ATTACHMENTS:
|
||||
return limits.maxColorAttachments;
|
||||
case LIMIT_MAX_TEXTURES_PER_UNIFORM_SET:
|
||||
return limits.maxDescriptorSetSampledImages;
|
||||
case LIMIT_MAX_SAMPLERS_PER_UNIFORM_SET:
|
||||
return limits.maxDescriptorSetSamplers;
|
||||
case LIMIT_MAX_STORAGE_BUFFERS_PER_UNIFORM_SET:
|
||||
return limits.maxDescriptorSetStorageBuffers;
|
||||
case LIMIT_MAX_STORAGE_IMAGES_PER_UNIFORM_SET:
|
||||
return limits.maxDescriptorSetStorageImages;
|
||||
case LIMIT_MAX_UNIFORM_BUFFERS_PER_UNIFORM_SET:
|
||||
return limits.maxDescriptorSetUniformBuffers;
|
||||
case LIMIT_MAX_DRAW_INDEXED_INDEX:
|
||||
return limits.maxDrawIndexedIndexValue;
|
||||
case LIMIT_MAX_FRAMEBUFFER_HEIGHT:
|
||||
return limits.maxFramebufferHeight;
|
||||
case LIMIT_MAX_FRAMEBUFFER_WIDTH:
|
||||
return limits.maxFramebufferWidth;
|
||||
case LIMIT_MAX_TEXTURE_ARRAY_LAYERS:
|
||||
return limits.maxImageArrayLayers;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_1D:
|
||||
return limits.maxImageDimension1D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_2D:
|
||||
return limits.maxImageDimension2D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_3D:
|
||||
return limits.maxImageDimension3D;
|
||||
case LIMIT_MAX_TEXTURE_SIZE_CUBE:
|
||||
return limits.maxImageDimensionCube;
|
||||
case LIMIT_MAX_TEXTURES_PER_SHADER_STAGE:
|
||||
return limits.maxPerStageDescriptorSampledImages;
|
||||
case LIMIT_MAX_SAMPLERS_PER_SHADER_STAGE:
|
||||
return limits.maxPerStageDescriptorSamplers;
|
||||
case LIMIT_MAX_STORAGE_BUFFERS_PER_SHADER_STAGE:
|
||||
return limits.maxPerStageDescriptorStorageBuffers;
|
||||
case LIMIT_MAX_STORAGE_IMAGES_PER_SHADER_STAGE:
|
||||
return limits.maxPerStageDescriptorStorageImages;
|
||||
case LIMIT_MAX_UNIFORM_BUFFERS_PER_SHADER_STAGE:
|
||||
return limits.maxPerStageDescriptorUniformBuffers;
|
||||
case LIMIT_MAX_PUSH_CONSTANT_SIZE:
|
||||
return limits.maxPushConstantsSize;
|
||||
case LIMIT_MAX_UNIFORM_BUFFER_SIZE:
|
||||
return limits.maxUniformBufferRange;
|
||||
case LIMIT_MAX_VERTEX_INPUT_ATTRIBUTE_OFFSET:
|
||||
return limits.maxVertexInputAttributeOffset;
|
||||
case LIMIT_MAX_VERTEX_INPUT_ATTRIBUTES:
|
||||
return limits.maxVertexInputAttributes;
|
||||
case LIMIT_MAX_VERTEX_INPUT_BINDINGS:
|
||||
return limits.maxVertexInputBindings;
|
||||
case LIMIT_MAX_VERTEX_INPUT_BINDING_STRIDE:
|
||||
return limits.maxVertexInputBindingStride;
|
||||
case LIMIT_MIN_UNIFORM_BUFFER_OFFSET_ALIGNMENT:
|
||||
return limits.minUniformBufferOffsetAlignment;
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_X:
|
||||
return limits.maxComputeWorkGroupCount[0];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_Y:
|
||||
return limits.maxComputeWorkGroupCount[1];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_COUNT_Z:
|
||||
return limits.maxComputeWorkGroupCount[2];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_INVOCATIONS:
|
||||
return limits.maxComputeWorkGroupInvocations;
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_X:
|
||||
return limits.maxComputeWorkGroupSize[0];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_Y:
|
||||
return limits.maxComputeWorkGroupSize[1];
|
||||
case LIMIT_MAX_COMPUTE_WORKGROUP_SIZE_Z:
|
||||
return limits.maxComputeWorkGroupSize[2];
|
||||
|
||||
default: ERR_FAIL_V(0);
|
||||
default:
|
||||
ERR_FAIL_V(0);
|
||||
}
|
||||
|
||||
return 0;
|
||||
|
@ -601,12 +601,13 @@ Error VulkanContext::_initialize_queues(VkSurfaceKHR surface) {
|
||||
_create_device();
|
||||
|
||||
static PFN_vkGetDeviceProcAddr g_gdpa = nullptr;
|
||||
#define GET_DEVICE_PROC_ADDR(dev, entrypoint) \
|
||||
{ \
|
||||
if (!g_gdpa) g_gdpa = (PFN_vkGetDeviceProcAddr)vkGetInstanceProcAddr(inst, "vkGetDeviceProcAddr"); \
|
||||
fp##entrypoint = (PFN_vk##entrypoint)g_gdpa(dev, "vk" #entrypoint); \
|
||||
ERR_FAIL_COND_V_MSG(fp##entrypoint == nullptr, ERR_CANT_CREATE, \
|
||||
"vkGetDeviceProcAddr failed to find vk" #entrypoint); \
|
||||
#define GET_DEVICE_PROC_ADDR(dev, entrypoint) \
|
||||
{ \
|
||||
if (!g_gdpa) \
|
||||
g_gdpa = (PFN_vkGetDeviceProcAddr)vkGetInstanceProcAddr(inst, "vkGetDeviceProcAddr"); \
|
||||
fp##entrypoint = (PFN_vk##entrypoint)g_gdpa(dev, "vk" #entrypoint); \
|
||||
ERR_FAIL_COND_V_MSG(fp##entrypoint == nullptr, ERR_CANT_CREATE, \
|
||||
"vkGetDeviceProcAddr failed to find vk" #entrypoint); \
|
||||
}
|
||||
|
||||
GET_DEVICE_PROC_ADDR(device, CreateSwapchainKHR);
|
||||
|
@ -5297,10 +5297,18 @@ void AnimationTrackEditor::_edit_menu_pressed(int p_option) {
|
||||
}
|
||||
|
||||
switch (animation->track_get_type(i)) {
|
||||
case Animation::TYPE_TRANSFORM: text += " (Transform)"; break;
|
||||
case Animation::TYPE_METHOD: text += " (Methods)"; break;
|
||||
case Animation::TYPE_BEZIER: text += " (Bezier)"; break;
|
||||
case Animation::TYPE_AUDIO: text += " (Audio)"; break;
|
||||
case Animation::TYPE_TRANSFORM:
|
||||
text += " (Transform)";
|
||||
break;
|
||||
case Animation::TYPE_METHOD:
|
||||
text += " (Methods)";
|
||||
break;
|
||||
case Animation::TYPE_BEZIER:
|
||||
text += " (Bezier)";
|
||||
break;
|
||||
case Animation::TYPE_AUDIO:
|
||||
text += " (Audio)";
|
||||
break;
|
||||
default: {
|
||||
};
|
||||
}
|
||||
|
@ -309,7 +309,8 @@ void FindReplaceBar::_update_results_count() {
|
||||
results_count = 0;
|
||||
|
||||
String searched = get_search_text();
|
||||
if (searched.empty()) return;
|
||||
if (searched.empty())
|
||||
return;
|
||||
|
||||
String full_text = text_edit->get_text();
|
||||
|
||||
@ -317,7 +318,8 @@ void FindReplaceBar::_update_results_count() {
|
||||
|
||||
while (true) {
|
||||
int pos = is_case_sensitive() ? full_text.find(searched, from_pos) : full_text.findn(searched, from_pos);
|
||||
if (pos == -1) break;
|
||||
if (pos == -1)
|
||||
break;
|
||||
|
||||
if (is_whole_words()) {
|
||||
from_pos++; // Making sure we won't hit the same match next time, if we get out via a continue.
|
||||
|
@ -171,20 +171,48 @@ void ConnectDialog::_add_bind() {
|
||||
Variant value;
|
||||
|
||||
switch (vt) {
|
||||
case Variant::BOOL: value = false; break;
|
||||
case Variant::INT: value = 0; break;
|
||||
case Variant::FLOAT: value = 0.0; break;
|
||||
case Variant::STRING: value = ""; break;
|
||||
case Variant::STRING_NAME: value = ""; break;
|
||||
case Variant::VECTOR2: value = Vector2(); break;
|
||||
case Variant::RECT2: value = Rect2(); break;
|
||||
case Variant::VECTOR3: value = Vector3(); break;
|
||||
case Variant::PLANE: value = Plane(); break;
|
||||
case Variant::QUAT: value = Quat(); break;
|
||||
case Variant::AABB: value = AABB(); break;
|
||||
case Variant::BASIS: value = Basis(); break;
|
||||
case Variant::TRANSFORM: value = Transform(); break;
|
||||
case Variant::COLOR: value = Color(); break;
|
||||
case Variant::BOOL:
|
||||
value = false;
|
||||
break;
|
||||
case Variant::INT:
|
||||
value = 0;
|
||||
break;
|
||||
case Variant::FLOAT:
|
||||
value = 0.0;
|
||||
break;
|
||||
case Variant::STRING:
|
||||
value = "";
|
||||
break;
|
||||
case Variant::STRING_NAME:
|
||||
value = "";
|
||||
break;
|
||||
case Variant::VECTOR2:
|
||||
value = Vector2();
|
||||
break;
|
||||
case Variant::RECT2:
|
||||
value = Rect2();
|
||||
break;
|
||||
case Variant::VECTOR3:
|
||||
value = Vector3();
|
||||
break;
|
||||
case Variant::PLANE:
|
||||
value = Plane();
|
||||
break;
|
||||
case Variant::QUAT:
|
||||
value = Quat();
|
||||
break;
|
||||
case Variant::AABB:
|
||||
value = AABB();
|
||||
break;
|
||||
case Variant::BASIS:
|
||||
value = Basis();
|
||||
break;
|
||||
case Variant::TRANSFORM:
|
||||
value = Transform();
|
||||
break;
|
||||
case Variant::COLOR:
|
||||
value = Color();
|
||||
break;
|
||||
default: {
|
||||
ERR_FAIL();
|
||||
} break;
|
||||
|
@ -74,7 +74,8 @@ void ScriptEditorDebugger::_put_msg(String p_message, Array p_data) {
|
||||
|
||||
void ScriptEditorDebugger::debug_copy() {
|
||||
String msg = reason->get_text();
|
||||
if (msg == "") return;
|
||||
if (msg == "")
|
||||
return;
|
||||
DisplayServer::get_singleton()->clipboard_set(msg);
|
||||
}
|
||||
|
||||
|
@ -691,7 +691,8 @@ bool EditorFileDialog::_is_open_should_be_disabled() {
|
||||
void EditorFileDialog::update_file_name() {
|
||||
int idx = filter->get_selected() - 1;
|
||||
if ((idx == -1 && filter->get_item_count() == 2) || (filter->get_item_count() > 2 && idx >= 0 && idx < filter->get_item_count() - 2)) {
|
||||
if (idx == -1) idx += 1;
|
||||
if (idx == -1)
|
||||
idx += 1;
|
||||
String filter_str = filters[idx];
|
||||
String file_str = file->get_text();
|
||||
String base_name = file_str.get_basename();
|
||||
|
@ -1497,7 +1497,8 @@ void EditorHelp::_notification(int p_what) {
|
||||
_class_desc_resized();
|
||||
}
|
||||
} break;
|
||||
default: break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1642,7 +1643,8 @@ void EditorHelpBit::_notification(int p_what) {
|
||||
|
||||
rich_text->add_theme_color_override("selection_color", get_theme_color("accent_color", "Editor") * Color(1, 1, 1, 0.4));
|
||||
} break;
|
||||
default: break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1786,7 +1788,8 @@ void FindBar::_update_results_count() {
|
||||
results_count = 0;
|
||||
|
||||
String searched = search_text->get_text();
|
||||
if (searched.empty()) return;
|
||||
if (searched.empty())
|
||||
return;
|
||||
|
||||
String full_text = rich_text_label->get_text();
|
||||
|
||||
|
@ -3082,7 +3082,8 @@ void EditorNode::_remove_edited_scene(bool p_change_tab) {
|
||||
ScriptEditor::get_singleton()->close_builtin_scripts_from_scene(editor_data.get_scene_path(old_index));
|
||||
}
|
||||
|
||||
if (p_change_tab) _scene_tab_changed(new_index);
|
||||
if (p_change_tab)
|
||||
_scene_tab_changed(new_index);
|
||||
editor_data.remove_scene(old_index);
|
||||
editor_data.get_undo_redo().clear_history(false);
|
||||
_update_title();
|
||||
|
@ -3318,13 +3318,27 @@ bool EditorInspectorDefaultPlugin::parse_property(Object *p_object, Variant::Typ
|
||||
|
||||
EditorPropertyMember::Type type = EditorPropertyMember::MEMBER_METHOD_OF_BASE_TYPE;
|
||||
switch (p_hint) {
|
||||
case PROPERTY_HINT_METHOD_OF_BASE_TYPE: type = EditorPropertyMember::MEMBER_METHOD_OF_BASE_TYPE; break;
|
||||
case PROPERTY_HINT_METHOD_OF_INSTANCE: type = EditorPropertyMember::MEMBER_METHOD_OF_INSTANCE; break;
|
||||
case PROPERTY_HINT_METHOD_OF_SCRIPT: type = EditorPropertyMember::MEMBER_METHOD_OF_SCRIPT; break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_VARIANT_TYPE: type = EditorPropertyMember::MEMBER_PROPERTY_OF_VARIANT_TYPE; break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_BASE_TYPE: type = EditorPropertyMember::MEMBER_PROPERTY_OF_BASE_TYPE; break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_INSTANCE: type = EditorPropertyMember::MEMBER_PROPERTY_OF_INSTANCE; break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_SCRIPT: type = EditorPropertyMember::MEMBER_PROPERTY_OF_SCRIPT; break;
|
||||
case PROPERTY_HINT_METHOD_OF_BASE_TYPE:
|
||||
type = EditorPropertyMember::MEMBER_METHOD_OF_BASE_TYPE;
|
||||
break;
|
||||
case PROPERTY_HINT_METHOD_OF_INSTANCE:
|
||||
type = EditorPropertyMember::MEMBER_METHOD_OF_INSTANCE;
|
||||
break;
|
||||
case PROPERTY_HINT_METHOD_OF_SCRIPT:
|
||||
type = EditorPropertyMember::MEMBER_METHOD_OF_SCRIPT;
|
||||
break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_VARIANT_TYPE:
|
||||
type = EditorPropertyMember::MEMBER_PROPERTY_OF_VARIANT_TYPE;
|
||||
break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_BASE_TYPE:
|
||||
type = EditorPropertyMember::MEMBER_PROPERTY_OF_BASE_TYPE;
|
||||
break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_INSTANCE:
|
||||
type = EditorPropertyMember::MEMBER_PROPERTY_OF_INSTANCE;
|
||||
break;
|
||||
case PROPERTY_HINT_PROPERTY_OF_SCRIPT:
|
||||
type = EditorPropertyMember::MEMBER_PROPERTY_OF_SCRIPT;
|
||||
break;
|
||||
default: {
|
||||
}
|
||||
}
|
||||
|
@ -504,18 +504,26 @@ void ExportTemplateManager::_notification(int p_what) {
|
||||
status = TTR("Disconnected");
|
||||
errored = true;
|
||||
break;
|
||||
case HTTPClient::STATUS_RESOLVING: status = TTR("Resolving"); break;
|
||||
case HTTPClient::STATUS_RESOLVING:
|
||||
status = TTR("Resolving");
|
||||
break;
|
||||
case HTTPClient::STATUS_CANT_RESOLVE:
|
||||
status = TTR("Can't Resolve");
|
||||
errored = true;
|
||||
break;
|
||||
case HTTPClient::STATUS_CONNECTING: status = TTR("Connecting..."); break;
|
||||
case HTTPClient::STATUS_CONNECTING:
|
||||
status = TTR("Connecting...");
|
||||
break;
|
||||
case HTTPClient::STATUS_CANT_CONNECT:
|
||||
status = TTR("Can't Connect");
|
||||
errored = true;
|
||||
break;
|
||||
case HTTPClient::STATUS_CONNECTED: status = TTR("Connected"); break;
|
||||
case HTTPClient::STATUS_REQUESTING: status = TTR("Requesting..."); break;
|
||||
case HTTPClient::STATUS_CONNECTED:
|
||||
status = TTR("Connected");
|
||||
break;
|
||||
case HTTPClient::STATUS_REQUESTING:
|
||||
status = TTR("Requesting...");
|
||||
break;
|
||||
case HTTPClient::STATUS_BODY:
|
||||
status = TTR("Downloading");
|
||||
if (download_templates->get_body_size() > 0) {
|
||||
|
@ -538,12 +538,18 @@ Error EditorSceneImporterGLTF::_parse_accessors(GLTFState &state) {
|
||||
String EditorSceneImporterGLTF::_get_component_type_name(const uint32_t p_component) {
|
||||
|
||||
switch (p_component) {
|
||||
case COMPONENT_TYPE_BYTE: return "Byte";
|
||||
case COMPONENT_TYPE_UNSIGNED_BYTE: return "UByte";
|
||||
case COMPONENT_TYPE_SHORT: return "Short";
|
||||
case COMPONENT_TYPE_UNSIGNED_SHORT: return "UShort";
|
||||
case COMPONENT_TYPE_INT: return "Int";
|
||||
case COMPONENT_TYPE_FLOAT: return "Float";
|
||||
case COMPONENT_TYPE_BYTE:
|
||||
return "Byte";
|
||||
case COMPONENT_TYPE_UNSIGNED_BYTE:
|
||||
return "UByte";
|
||||
case COMPONENT_TYPE_SHORT:
|
||||
return "Short";
|
||||
case COMPONENT_TYPE_UNSIGNED_SHORT:
|
||||
return "UShort";
|
||||
case COMPONENT_TYPE_INT:
|
||||
return "Int";
|
||||
case COMPONENT_TYPE_FLOAT:
|
||||
return "Float";
|
||||
}
|
||||
|
||||
return "<Error>";
|
||||
@ -655,12 +661,24 @@ Error EditorSceneImporterGLTF::_decode_buffer_view(GLTFState &state, double *dst
|
||||
int EditorSceneImporterGLTF::_get_component_type_size(const int component_type) {
|
||||
|
||||
switch (component_type) {
|
||||
case COMPONENT_TYPE_BYTE: return 1; break;
|
||||
case COMPONENT_TYPE_UNSIGNED_BYTE: return 1; break;
|
||||
case COMPONENT_TYPE_SHORT: return 2; break;
|
||||
case COMPONENT_TYPE_UNSIGNED_SHORT: return 2; break;
|
||||
case COMPONENT_TYPE_INT: return 4; break;
|
||||
case COMPONENT_TYPE_FLOAT: return 4; break;
|
||||
case COMPONENT_TYPE_BYTE:
|
||||
return 1;
|
||||
break;
|
||||
case COMPONENT_TYPE_UNSIGNED_BYTE:
|
||||
return 1;
|
||||
break;
|
||||
case COMPONENT_TYPE_SHORT:
|
||||
return 2;
|
||||
break;
|
||||
case COMPONENT_TYPE_UNSIGNED_SHORT:
|
||||
return 2;
|
||||
break;
|
||||
case COMPONENT_TYPE_INT:
|
||||
return 4;
|
||||
break;
|
||||
case COMPONENT_TYPE_FLOAT:
|
||||
return 4;
|
||||
break;
|
||||
default: {
|
||||
ERR_FAIL_V(0);
|
||||
}
|
||||
|
@ -83,9 +83,15 @@ Error ResourceImporterCSVTranslation::import(const String &p_source_file, const
|
||||
|
||||
String delimiter;
|
||||
switch ((int)p_options["delimiter"]) {
|
||||
case 0: delimiter = ","; break;
|
||||
case 1: delimiter = ";"; break;
|
||||
case 2: delimiter = "\t"; break;
|
||||
case 0:
|
||||
delimiter = ",";
|
||||
break;
|
||||
case 1:
|
||||
delimiter = ";";
|
||||
break;
|
||||
case 2:
|
||||
delimiter = "\t";
|
||||
break;
|
||||
}
|
||||
|
||||
FileAccessRef f = FileAccess::open(p_source_file, FileAccess::READ);
|
||||
|
@ -221,16 +221,26 @@ int ResourceImporterScene::get_preset_count() const {
|
||||
String ResourceImporterScene::get_preset_name(int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case PRESET_SINGLE_SCENE: return TTR("Import as Single Scene");
|
||||
case PRESET_SEPARATE_ANIMATIONS: return TTR("Import with Separate Animations");
|
||||
case PRESET_SEPARATE_MATERIALS: return TTR("Import with Separate Materials");
|
||||
case PRESET_SEPARATE_MESHES: return TTR("Import with Separate Objects");
|
||||
case PRESET_SEPARATE_MESHES_AND_MATERIALS: return TTR("Import with Separate Objects+Materials");
|
||||
case PRESET_SEPARATE_MESHES_AND_ANIMATIONS: return TTR("Import with Separate Objects+Animations");
|
||||
case PRESET_SEPARATE_MATERIALS_AND_ANIMATIONS: return TTR("Import with Separate Materials+Animations");
|
||||
case PRESET_SEPARATE_MESHES_MATERIALS_AND_ANIMATIONS: return TTR("Import with Separate Objects+Materials+Animations");
|
||||
case PRESET_MULTIPLE_SCENES: return TTR("Import as Multiple Scenes");
|
||||
case PRESET_MULTIPLE_SCENES_AND_MATERIALS: return TTR("Import as Multiple Scenes+Materials");
|
||||
case PRESET_SINGLE_SCENE:
|
||||
return TTR("Import as Single Scene");
|
||||
case PRESET_SEPARATE_ANIMATIONS:
|
||||
return TTR("Import with Separate Animations");
|
||||
case PRESET_SEPARATE_MATERIALS:
|
||||
return TTR("Import with Separate Materials");
|
||||
case PRESET_SEPARATE_MESHES:
|
||||
return TTR("Import with Separate Objects");
|
||||
case PRESET_SEPARATE_MESHES_AND_MATERIALS:
|
||||
return TTR("Import with Separate Objects+Materials");
|
||||
case PRESET_SEPARATE_MESHES_AND_ANIMATIONS:
|
||||
return TTR("Import with Separate Objects+Animations");
|
||||
case PRESET_SEPARATE_MATERIALS_AND_ANIMATIONS:
|
||||
return TTR("Import with Separate Materials+Animations");
|
||||
case PRESET_SEPARATE_MESHES_MATERIALS_AND_ANIMATIONS:
|
||||
return TTR("Import with Separate Objects+Materials+Animations");
|
||||
case PRESET_MULTIPLE_SCENES:
|
||||
return TTR("Import as Multiple Scenes");
|
||||
case PRESET_MULTIPLE_SCENES_AND_MATERIALS:
|
||||
return TTR("Import as Multiple Scenes+Materials");
|
||||
}
|
||||
|
||||
return "";
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* resource_importer_shader_file.cpp */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#include "resource_importer_shader_file.h"
|
||||
|
||||
#include "core/io/marshalls.h"
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* resource_importer_shader_file.h */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#ifndef RESOURCE_IMPORTER_SHADER_FILE_H
|
||||
#define RESOURCE_IMPORTER_SHADER_FILE_H
|
||||
|
||||
|
@ -431,7 +431,8 @@ bool EditorNode3DGizmo::intersect_frustum(const Camera3D *p_camera, const Vector
|
||||
ERR_FAIL_COND_V(!spatial_node, false);
|
||||
ERR_FAIL_COND_V(!valid, false);
|
||||
|
||||
if (hidden && !gizmo_plugin->is_selectable_when_hidden()) return false;
|
||||
if (hidden && !gizmo_plugin->is_selectable_when_hidden())
|
||||
return false;
|
||||
|
||||
if (selectable_icon_size > 0.0f) {
|
||||
Vector3 origin = spatial_node->get_global_transform().get_origin();
|
||||
@ -470,10 +471,12 @@ bool EditorNode3DGizmo::intersect_frustum(const Camera3D *p_camera, const Vector
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (any_out) break;
|
||||
if (any_out)
|
||||
break;
|
||||
}
|
||||
|
||||
if (!any_out) return true;
|
||||
if (!any_out)
|
||||
return true;
|
||||
}
|
||||
|
||||
if (collision_mesh.is_valid()) {
|
||||
@ -504,7 +507,8 @@ bool EditorNode3DGizmo::intersect_ray(Camera3D *p_camera, const Point2 &p_point,
|
||||
ERR_FAIL_COND_V(!spatial_node, false);
|
||||
ERR_FAIL_COND_V(!valid, false);
|
||||
|
||||
if (hidden && !gizmo_plugin->is_selectable_when_hidden()) return false;
|
||||
if (hidden && !gizmo_plugin->is_selectable_when_hidden())
|
||||
return false;
|
||||
|
||||
if (r_gizmo_handle && !hidden) {
|
||||
|
||||
@ -785,7 +789,8 @@ EditorNode3DGizmo::EditorNode3DGizmo() {
|
||||
|
||||
EditorNode3DGizmo::~EditorNode3DGizmo() {
|
||||
|
||||
if (gizmo_plugin != nullptr) gizmo_plugin->unregister_gizmo(this);
|
||||
if (gizmo_plugin != nullptr)
|
||||
gizmo_plugin->unregister_gizmo(this);
|
||||
clear();
|
||||
}
|
||||
|
||||
@ -2207,12 +2212,18 @@ int VisibilityNotifier3DGizmoPlugin::get_priority() const {
|
||||
String VisibilityNotifier3DGizmoPlugin::get_handle_name(const EditorNode3DGizmo *p_gizmo, int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: return "Size X";
|
||||
case 1: return "Size Y";
|
||||
case 2: return "Size Z";
|
||||
case 3: return "Pos X";
|
||||
case 4: return "Pos Y";
|
||||
case 5: return "Pos Z";
|
||||
case 0:
|
||||
return "Size X";
|
||||
case 1:
|
||||
return "Size Y";
|
||||
case 2:
|
||||
return "Size Z";
|
||||
case 3:
|
||||
return "Pos X";
|
||||
case 4:
|
||||
return "Pos Y";
|
||||
case 5:
|
||||
return "Pos Z";
|
||||
}
|
||||
|
||||
return "";
|
||||
@ -2399,12 +2410,18 @@ bool GPUParticles3DGizmoPlugin::is_selectable_when_hidden() const {
|
||||
String GPUParticles3DGizmoPlugin::get_handle_name(const EditorNode3DGizmo *p_gizmo, int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: return "Size X";
|
||||
case 1: return "Size Y";
|
||||
case 2: return "Size Z";
|
||||
case 3: return "Pos X";
|
||||
case 4: return "Pos Y";
|
||||
case 5: return "Pos Z";
|
||||
case 0:
|
||||
return "Size X";
|
||||
case 1:
|
||||
return "Size Y";
|
||||
case 2:
|
||||
return "Size Z";
|
||||
case 3:
|
||||
return "Pos X";
|
||||
case 4:
|
||||
return "Pos Y";
|
||||
case 5:
|
||||
return "Pos Z";
|
||||
}
|
||||
|
||||
return "";
|
||||
@ -2564,12 +2581,18 @@ int ReflectionProbeGizmoPlugin::get_priority() const {
|
||||
String ReflectionProbeGizmoPlugin::get_handle_name(const EditorNode3DGizmo *p_gizmo, int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: return "Extents X";
|
||||
case 1: return "Extents Y";
|
||||
case 2: return "Extents Z";
|
||||
case 3: return "Origin X";
|
||||
case 4: return "Origin Y";
|
||||
case 5: return "Origin Z";
|
||||
case 0:
|
||||
return "Extents X";
|
||||
case 1:
|
||||
return "Extents Y";
|
||||
case 2:
|
||||
return "Extents Z";
|
||||
case 3:
|
||||
return "Origin X";
|
||||
case 4:
|
||||
return "Origin Y";
|
||||
case 5:
|
||||
return "Origin Z";
|
||||
}
|
||||
|
||||
return "";
|
||||
@ -2747,9 +2770,12 @@ int DecalGizmoPlugin::get_priority() const {
|
||||
String DecalGizmoPlugin::get_handle_name(const EditorNode3DGizmo *p_gizmo, int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: return "Extents X";
|
||||
case 1: return "Extents Y";
|
||||
case 2: return "Extents Z";
|
||||
case 0:
|
||||
return "Extents X";
|
||||
case 1:
|
||||
return "Extents Y";
|
||||
case 2:
|
||||
return "Extents Z";
|
||||
}
|
||||
|
||||
return "";
|
||||
@ -2888,9 +2914,12 @@ int GIProbeGizmoPlugin::get_priority() const {
|
||||
String GIProbeGizmoPlugin::get_handle_name(const EditorNode3DGizmo *p_gizmo, int p_idx) const {
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: return "Extents X";
|
||||
case 1: return "Extents Y";
|
||||
case 2: return "Extents Z";
|
||||
case 0:
|
||||
return "Extents X";
|
||||
case 1:
|
||||
return "Extents Y";
|
||||
case 2:
|
||||
return "Extents Z";
|
||||
}
|
||||
|
||||
return "";
|
||||
|
@ -1297,7 +1297,8 @@ void EditorAssetLibrary::_http_request_completed(int p_status, int p_code, const
|
||||
}
|
||||
}
|
||||
} break;
|
||||
default: break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1624,20 +1624,28 @@ bool CanvasItemEditor::_gui_input_anchors(const Ref<InputEvent> &p_event) {
|
||||
|
||||
switch (drag_type) {
|
||||
case DRAG_ANCHOR_TOP_LEFT:
|
||||
if (!use_single_axis || !use_y) control->set_anchor(MARGIN_LEFT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y) control->set_anchor(MARGIN_TOP, new_anchor.y, false, false);
|
||||
if (!use_single_axis || !use_y)
|
||||
control->set_anchor(MARGIN_LEFT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y)
|
||||
control->set_anchor(MARGIN_TOP, new_anchor.y, false, false);
|
||||
break;
|
||||
case DRAG_ANCHOR_TOP_RIGHT:
|
||||
if (!use_single_axis || !use_y) control->set_anchor(MARGIN_RIGHT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y) control->set_anchor(MARGIN_TOP, new_anchor.y, false, false);
|
||||
if (!use_single_axis || !use_y)
|
||||
control->set_anchor(MARGIN_RIGHT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y)
|
||||
control->set_anchor(MARGIN_TOP, new_anchor.y, false, false);
|
||||
break;
|
||||
case DRAG_ANCHOR_BOTTOM_RIGHT:
|
||||
if (!use_single_axis || !use_y) control->set_anchor(MARGIN_RIGHT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y) control->set_anchor(MARGIN_BOTTOM, new_anchor.y, false, false);
|
||||
if (!use_single_axis || !use_y)
|
||||
control->set_anchor(MARGIN_RIGHT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y)
|
||||
control->set_anchor(MARGIN_BOTTOM, new_anchor.y, false, false);
|
||||
break;
|
||||
case DRAG_ANCHOR_BOTTOM_LEFT:
|
||||
if (!use_single_axis || !use_y) control->set_anchor(MARGIN_LEFT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y) control->set_anchor(MARGIN_BOTTOM, new_anchor.y, false, false);
|
||||
if (!use_single_axis || !use_y)
|
||||
control->set_anchor(MARGIN_LEFT, new_anchor.x, false, false);
|
||||
if (!use_single_axis || use_y)
|
||||
control->set_anchor(MARGIN_BOTTOM, new_anchor.y, false, false);
|
||||
break;
|
||||
case DRAG_ANCHOR_ALL:
|
||||
if (!use_single_axis || !use_y) {
|
||||
@ -5037,7 +5045,8 @@ void CanvasItemEditor::_focus_selection(int p_op) {
|
||||
Map<Node *, Object *> &selection = editor_selection->get_selection();
|
||||
for (Map<Node *, Object *>::Element *E = selection.front(); E; E = E->next()) {
|
||||
CanvasItem *canvas_item = Object::cast_to<CanvasItem>(E->key());
|
||||
if (!canvas_item) continue;
|
||||
if (!canvas_item)
|
||||
continue;
|
||||
if (canvas_item->get_viewport() != EditorNode::get_singleton()->get_scene_root())
|
||||
continue;
|
||||
|
||||
@ -5065,7 +5074,8 @@ void CanvasItemEditor::_focus_selection(int p_op) {
|
||||
rect = rect.merge(canvas_item_rect);
|
||||
}
|
||||
};
|
||||
if (count == 0) return;
|
||||
if (count == 0)
|
||||
return;
|
||||
|
||||
if (p_op == VIEW_CENTER_TO_SELECTION) {
|
||||
|
||||
@ -6252,7 +6262,8 @@ void CanvasItemEditorViewport::_notification(int p_what) {
|
||||
disconnect("mouse_exited", callable_mp(this, &CanvasItemEditorViewport::_on_mouse_exit));
|
||||
} break;
|
||||
|
||||
default: break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -179,12 +179,18 @@ void DebuggerEditorPlugin::_update_debug_options() {
|
||||
bool check_reload_scripts = EditorSettings::get_singleton()->get_project_metadata("debug_options", "run_reload_scripts", false);
|
||||
int instances = EditorSettings::get_singleton()->get_project_metadata("debug_options", "run_debug_instances", 1);
|
||||
|
||||
if (check_deploy_remote) _menu_option(RUN_DEPLOY_REMOTE_DEBUG);
|
||||
if (check_file_server) _menu_option(RUN_FILE_SERVER);
|
||||
if (check_debug_collisions) _menu_option(RUN_DEBUG_COLLISONS);
|
||||
if (check_debug_navigation) _menu_option(RUN_DEBUG_NAVIGATION);
|
||||
if (check_live_debug) _menu_option(RUN_LIVE_DEBUG);
|
||||
if (check_reload_scripts) _menu_option(RUN_RELOAD_SCRIPTS);
|
||||
if (check_deploy_remote)
|
||||
_menu_option(RUN_DEPLOY_REMOTE_DEBUG);
|
||||
if (check_file_server)
|
||||
_menu_option(RUN_FILE_SERVER);
|
||||
if (check_debug_collisions)
|
||||
_menu_option(RUN_DEBUG_COLLISONS);
|
||||
if (check_debug_navigation)
|
||||
_menu_option(RUN_DEBUG_NAVIGATION);
|
||||
if (check_live_debug)
|
||||
_menu_option(RUN_LIVE_DEBUG);
|
||||
if (check_reload_scripts)
|
||||
_menu_option(RUN_RELOAD_SCRIPTS);
|
||||
|
||||
int len = instances_menu->get_item_count();
|
||||
for (int idx = 0; idx < len; idx++) {
|
||||
|
@ -718,9 +718,11 @@ void Node3DEditorViewport::_select_region() {
|
||||
item = sel;
|
||||
}
|
||||
|
||||
if (selected.find(item) != -1) continue;
|
||||
if (selected.find(item) != -1)
|
||||
continue;
|
||||
|
||||
if (_is_node_locked(item)) continue;
|
||||
if (_is_node_locked(item))
|
||||
continue;
|
||||
|
||||
Ref<EditorNode3DGizmo> seg = sp->get_gizmo();
|
||||
|
||||
@ -783,11 +785,16 @@ static int _get_key_modifier_setting(const String &p_property) {
|
||||
|
||||
switch (EditorSettings::get_singleton()->get(p_property).operator int()) {
|
||||
|
||||
case 0: return 0;
|
||||
case 1: return KEY_SHIFT;
|
||||
case 2: return KEY_ALT;
|
||||
case 3: return KEY_META;
|
||||
case 4: return KEY_CONTROL;
|
||||
case 0:
|
||||
return 0;
|
||||
case 1:
|
||||
return KEY_SHIFT;
|
||||
case 2:
|
||||
return KEY_ALT;
|
||||
case 3:
|
||||
return KEY_META;
|
||||
case 4:
|
||||
return KEY_CONTROL;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
@ -1381,7 +1388,8 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
|
||||
|
||||
if (cursor.region_select) {
|
||||
|
||||
if (!clicked_wants_append) _clear_selected();
|
||||
if (!clicked_wants_append)
|
||||
_clear_selected();
|
||||
|
||||
_select_region();
|
||||
cursor.region_select = false;
|
||||
@ -2076,7 +2084,8 @@ void Node3DEditorViewport::_sinput(const Ref<InputEvent> &p_event) {
|
||||
}
|
||||
|
||||
if (k->get_keycode() == KEY_SPACE) {
|
||||
if (!k->is_pressed()) emit_signal("toggle_maximize_view", this);
|
||||
if (!k->is_pressed())
|
||||
emit_signal("toggle_maximize_view", this);
|
||||
}
|
||||
}
|
||||
|
||||
@ -4633,7 +4642,8 @@ Dictionary Node3DEditor::get_state() const {
|
||||
|
||||
Dictionary gizmos_status;
|
||||
for (int i = 0; i < gizmo_plugins_by_name.size(); i++) {
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden()) continue;
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden())
|
||||
continue;
|
||||
int state = gizmos_menu->get_item_state(gizmos_menu->get_item_index(i));
|
||||
String name = gizmo_plugins_by_name[i]->get_name();
|
||||
gizmos_status[name] = state;
|
||||
@ -4727,7 +4737,8 @@ void Node3DEditor::set_state(const Dictionary &p_state) {
|
||||
gizmos_status.get_key_list(&keys);
|
||||
|
||||
for (int j = 0; j < gizmo_plugins_by_name.size(); ++j) {
|
||||
if (!gizmo_plugins_by_name[j]->can_be_hidden()) continue;
|
||||
if (!gizmo_plugins_by_name[j]->can_be_hidden())
|
||||
continue;
|
||||
int state = EditorNode3DGizmoPlugin::VISIBLE;
|
||||
for (int i = 0; i < keys.size(); i++) {
|
||||
if (gizmo_plugins_by_name.write[j]->get_name() == keys[i]) {
|
||||
@ -5492,7 +5503,8 @@ void Node3DEditor::_update_gizmos_menu() {
|
||||
gizmos_menu->clear();
|
||||
|
||||
for (int i = 0; i < gizmo_plugins_by_name.size(); ++i) {
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden()) continue;
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden())
|
||||
continue;
|
||||
String plugin_name = gizmo_plugins_by_name[i]->get_name();
|
||||
const int plugin_state = gizmo_plugins_by_name[i]->get_state();
|
||||
gizmos_menu->add_multistate_item(TTR(plugin_name), 3, plugin_state, i);
|
||||
@ -5513,7 +5525,8 @@ void Node3DEditor::_update_gizmos_menu() {
|
||||
|
||||
void Node3DEditor::_update_gizmos_menu_theme() {
|
||||
for (int i = 0; i < gizmo_plugins_by_name.size(); ++i) {
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden()) continue;
|
||||
if (!gizmo_plugins_by_name[i]->can_be_hidden())
|
||||
continue;
|
||||
const int plugin_state = gizmo_plugins_by_name[i]->get_state();
|
||||
const int idx = gizmos_menu->get_item_index(i);
|
||||
switch (plugin_state) {
|
||||
@ -5924,9 +5937,11 @@ void Node3DEditor::_request_gizmo(Object *p_obj) {
|
||||
}
|
||||
|
||||
void Node3DEditor::_toggle_maximize_view(Object *p_viewport) {
|
||||
if (!p_viewport) return;
|
||||
if (!p_viewport)
|
||||
return;
|
||||
Node3DEditorViewport *current_viewport = Object::cast_to<Node3DEditorViewport>(p_viewport);
|
||||
if (!current_viewport) return;
|
||||
if (!current_viewport)
|
||||
return;
|
||||
|
||||
int index = -1;
|
||||
bool maximized = false;
|
||||
@ -5938,7 +5953,8 @@ void Node3DEditor::_toggle_maximize_view(Object *p_viewport) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (index == -1) return;
|
||||
if (index == -1)
|
||||
return;
|
||||
|
||||
if (!maximized) {
|
||||
|
||||
@ -6655,7 +6671,8 @@ Ref<StandardMaterial3D> EditorNode3DGizmoPlugin::get_material(const String &p_na
|
||||
ERR_FAIL_COND_V(!materials.has(p_name), Ref<StandardMaterial3D>());
|
||||
ERR_FAIL_COND_V(materials[p_name].size() == 0, Ref<StandardMaterial3D>());
|
||||
|
||||
if (p_gizmo.is_null() || materials[p_name].size() == 1) return materials[p_name][0];
|
||||
if (p_gizmo.is_null() || materials[p_name].size() == 1)
|
||||
return materials[p_name][0];
|
||||
|
||||
int index = (p_gizmo->is_selected() ? 1 : 0) + (p_gizmo->is_editable() ? 2 : 0);
|
||||
|
||||
@ -6692,7 +6709,8 @@ Ref<EditorNode3DGizmo> EditorNode3DGizmoPlugin::get_gizmo(Node3D *p_spatial) {
|
||||
|
||||
Ref<EditorNode3DGizmo> ref = create_gizmo(p_spatial);
|
||||
|
||||
if (ref.is_null()) return ref;
|
||||
if (ref.is_null())
|
||||
return ref;
|
||||
|
||||
ref->set_plugin(this);
|
||||
ref->set_spatial_node(p_spatial);
|
||||
@ -6751,7 +6769,8 @@ Ref<EditorNode3DGizmo> EditorNode3DGizmoPlugin::create_gizmo(Node3D *p_spatial)
|
||||
}
|
||||
|
||||
Ref<EditorNode3DGizmo> ref;
|
||||
if (has_gizmo(p_spatial)) ref.instance();
|
||||
if (has_gizmo(p_spatial))
|
||||
ref.instance();
|
||||
return ref;
|
||||
}
|
||||
|
||||
|
@ -288,8 +288,10 @@ bool Path2DEditor::forward_gui_input(const Ref<InputEvent> &p_event) {
|
||||
Vector2 gpoint = mm->get_position();
|
||||
|
||||
Ref<Curve2D> curve = node->get_curve();
|
||||
if (curve == nullptr) return true;
|
||||
if (curve->get_point_count() < 2) return true;
|
||||
if (curve == nullptr)
|
||||
return true;
|
||||
if (curve->get_point_count() < 2)
|
||||
return true;
|
||||
|
||||
// Find edge
|
||||
edge_point = xform.xform(curve->get_closest_point(xform.affine_inverse().xform(mm->get_position())));
|
||||
|
@ -631,7 +631,8 @@ Ref<EditorNode3DGizmo> Path3DGizmoPlugin::create_gizmo(Node3D *p_spatial) {
|
||||
Ref<Path3DGizmo> ref;
|
||||
|
||||
Path3D *path = Object::cast_to<Path3D>(p_spatial);
|
||||
if (path) ref = Ref<Path3DGizmo>(memnew(Path3DGizmo(path)));
|
||||
if (path)
|
||||
ref = Ref<Path3DGizmo>(memnew(Path3DGizmo(path)));
|
||||
|
||||
return ref;
|
||||
}
|
||||
|
@ -822,7 +822,8 @@ void ScriptTextEditor::_code_complete_scripts(void *p_ud, const String &p_code,
|
||||
|
||||
void ScriptTextEditor::_code_complete_script(const String &p_code, List<ScriptCodeCompletionOption> *r_options, bool &r_force) {
|
||||
|
||||
if (color_panel->is_visible()) return;
|
||||
if (color_panel->is_visible())
|
||||
return;
|
||||
Node *base = get_tree()->get_edited_scene_root();
|
||||
if (base) {
|
||||
base = _find_node_for_script(base, base, script);
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* shader_file_editor_plugin.cpp */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#include "shader_file_editor_plugin.h"
|
||||
|
||||
#include "core/io/resource_loader.h"
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* shader_file_editor_plugin.h */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#ifndef SHADER_FILE_EDITOR_PLUGIN_H
|
||||
#define SHADER_FILE_EDITOR_PLUGIN_H
|
||||
|
||||
|
@ -74,11 +74,21 @@ void ThemeEditor::_name_menu_about_to_show() {
|
||||
|
||||
switch (type_select->get_selected()) {
|
||||
|
||||
case 0: Theme::get_default()->get_icon_list(fromtype, &names); break;
|
||||
case 1: Theme::get_default()->get_stylebox_list(fromtype, &names); break;
|
||||
case 2: Theme::get_default()->get_font_list(fromtype, &names); break;
|
||||
case 3: Theme::get_default()->get_color_list(fromtype, &names); break;
|
||||
case 4: Theme::get_default()->get_constant_list(fromtype, &names); break;
|
||||
case 0:
|
||||
Theme::get_default()->get_icon_list(fromtype, &names);
|
||||
break;
|
||||
case 1:
|
||||
Theme::get_default()->get_stylebox_list(fromtype, &names);
|
||||
break;
|
||||
case 2:
|
||||
Theme::get_default()->get_font_list(fromtype, &names);
|
||||
break;
|
||||
case 3:
|
||||
Theme::get_default()->get_color_list(fromtype, &names);
|
||||
break;
|
||||
case 4:
|
||||
Theme::get_default()->get_constant_list(fromtype, &names);
|
||||
break;
|
||||
}
|
||||
} else if (popup_mode == POPUP_REMOVE) {
|
||||
|
||||
@ -324,11 +334,21 @@ void ThemeEditor::_dialog_cbk() {
|
||||
|
||||
switch (type_select->get_selected()) {
|
||||
|
||||
case 0: theme->set_icon(name_edit->get_text(), type_edit->get_text(), Ref<Texture2D>()); break;
|
||||
case 1: theme->set_stylebox(name_edit->get_text(), type_edit->get_text(), Ref<StyleBox>()); break;
|
||||
case 2: theme->set_font(name_edit->get_text(), type_edit->get_text(), Ref<Font>()); break;
|
||||
case 3: theme->set_color(name_edit->get_text(), type_edit->get_text(), Color()); break;
|
||||
case 4: theme->set_constant(name_edit->get_text(), type_edit->get_text(), 0); break;
|
||||
case 0:
|
||||
theme->set_icon(name_edit->get_text(), type_edit->get_text(), Ref<Texture2D>());
|
||||
break;
|
||||
case 1:
|
||||
theme->set_stylebox(name_edit->get_text(), type_edit->get_text(), Ref<StyleBox>());
|
||||
break;
|
||||
case 2:
|
||||
theme->set_font(name_edit->get_text(), type_edit->get_text(), Ref<Font>());
|
||||
break;
|
||||
case 3:
|
||||
theme->set_color(name_edit->get_text(), type_edit->get_text(), Color());
|
||||
break;
|
||||
case 4:
|
||||
theme->set_constant(name_edit->get_text(), type_edit->get_text(), 0);
|
||||
break;
|
||||
}
|
||||
|
||||
} break;
|
||||
@ -376,11 +396,21 @@ void ThemeEditor::_dialog_cbk() {
|
||||
case POPUP_REMOVE: {
|
||||
switch (type_select->get_selected()) {
|
||||
|
||||
case 0: theme->clear_icon(name_edit->get_text(), type_edit->get_text()); break;
|
||||
case 1: theme->clear_stylebox(name_edit->get_text(), type_edit->get_text()); break;
|
||||
case 2: theme->clear_font(name_edit->get_text(), type_edit->get_text()); break;
|
||||
case 3: theme->clear_color(name_edit->get_text(), type_edit->get_text()); break;
|
||||
case 4: theme->clear_constant(name_edit->get_text(), type_edit->get_text()); break;
|
||||
case 0:
|
||||
theme->clear_icon(name_edit->get_text(), type_edit->get_text());
|
||||
break;
|
||||
case 1:
|
||||
theme->clear_stylebox(name_edit->get_text(), type_edit->get_text());
|
||||
break;
|
||||
case 2:
|
||||
theme->clear_font(name_edit->get_text(), type_edit->get_text());
|
||||
break;
|
||||
case 3:
|
||||
theme->clear_color(name_edit->get_text(), type_edit->get_text());
|
||||
break;
|
||||
case 4:
|
||||
theme->clear_constant(name_edit->get_text(), type_edit->get_text());
|
||||
break;
|
||||
}
|
||||
|
||||
} break;
|
||||
|
@ -126,7 +126,8 @@ void TileSetEditor::_import_node(Node *p_node, Ref<TileSet> p_library) {
|
||||
sb->get_shape_owners(&shapes);
|
||||
|
||||
for (List<uint32_t>::Element *E = shapes.front(); E; E = E->next()) {
|
||||
if (sb->is_shape_owner_disabled(E->get())) continue;
|
||||
if (sb->is_shape_owner_disabled(E->get()))
|
||||
continue;
|
||||
|
||||
Transform2D shape_transform = sb->get_transform() * sb->shape_owner_get_transform(E->get());
|
||||
bool one_way = sb->is_shape_owner_one_way_collision_enabled(E->get());
|
||||
|
@ -1239,11 +1239,13 @@ void VisualShaderEditor::_port_name_focus_out(Object *line_edit, int p_node_id,
|
||||
List<String> output_names;
|
||||
|
||||
for (int i = 0; i < node->get_input_port_count(); i++) {
|
||||
if (!p_output && i == p_port_id) continue;
|
||||
if (!p_output && i == p_port_id)
|
||||
continue;
|
||||
input_names.push_back(node->get_input_port_name(i));
|
||||
}
|
||||
for (int i = 0; i < node->get_output_port_count(); i++) {
|
||||
if (p_output && i == p_port_id) continue;
|
||||
if (p_output && i == p_port_id)
|
||||
continue;
|
||||
output_names.push_back(node->get_output_port_name(i));
|
||||
}
|
||||
|
||||
|
@ -2429,12 +2429,24 @@ ProjectManager::ProjectManager() {
|
||||
#endif
|
||||
} break;
|
||||
|
||||
case 1: editor_set_scale(0.75); break;
|
||||
case 2: editor_set_scale(1.0); break;
|
||||
case 3: editor_set_scale(1.25); break;
|
||||
case 4: editor_set_scale(1.5); break;
|
||||
case 5: editor_set_scale(1.75); break;
|
||||
case 6: editor_set_scale(2.0); break;
|
||||
case 1:
|
||||
editor_set_scale(0.75);
|
||||
break;
|
||||
case 2:
|
||||
editor_set_scale(1.0);
|
||||
break;
|
||||
case 3:
|
||||
editor_set_scale(1.25);
|
||||
break;
|
||||
case 4:
|
||||
editor_set_scale(1.5);
|
||||
break;
|
||||
case 5:
|
||||
editor_set_scale(1.75);
|
||||
break;
|
||||
case 6:
|
||||
editor_set_scale(2.0);
|
||||
break;
|
||||
|
||||
default: {
|
||||
editor_set_scale(custom_display_scale);
|
||||
|
@ -446,11 +446,13 @@ void ProjectSettingsEditor::_show_last_added(const Ref<InputEvent> &p_event, con
|
||||
}
|
||||
child = child->get_next();
|
||||
}
|
||||
if (found) break;
|
||||
if (found)
|
||||
break;
|
||||
r = r->get_next();
|
||||
}
|
||||
|
||||
if (found) input_editor->ensure_cursor_is_visible();
|
||||
if (found)
|
||||
input_editor->ensure_cursor_is_visible();
|
||||
}
|
||||
|
||||
void ProjectSettingsEditor::_wait_for_key(const Ref<InputEvent> &p_event) {
|
||||
@ -804,12 +806,23 @@ void ProjectSettingsEditor::_update_actions() {
|
||||
if (mb.is_valid()) {
|
||||
String str = _get_device_string(mb->get_device()) + ", ";
|
||||
switch (mb->get_button_index()) {
|
||||
case BUTTON_LEFT: str += TTR("Left Button"); break;
|
||||
case BUTTON_RIGHT: str += TTR("Right Button"); break;
|
||||
case BUTTON_MIDDLE: str += TTR("Middle Button"); break;
|
||||
case BUTTON_WHEEL_UP: str += TTR("Wheel Up"); break;
|
||||
case BUTTON_WHEEL_DOWN: str += TTR("Wheel Down"); break;
|
||||
default: str += vformat(TTR("%d Button"), mb->get_button_index());
|
||||
case BUTTON_LEFT:
|
||||
str += TTR("Left Button");
|
||||
break;
|
||||
case BUTTON_RIGHT:
|
||||
str += TTR("Right Button");
|
||||
break;
|
||||
case BUTTON_MIDDLE:
|
||||
str += TTR("Middle Button");
|
||||
break;
|
||||
case BUTTON_WHEEL_UP:
|
||||
str += TTR("Wheel Up");
|
||||
break;
|
||||
case BUTTON_WHEEL_DOWN:
|
||||
str += TTR("Wheel Down");
|
||||
break;
|
||||
default:
|
||||
str += vformat(TTR("%d Button"), mb->get_button_index());
|
||||
}
|
||||
|
||||
action2->set_text(0, str);
|
||||
@ -1596,7 +1609,8 @@ void ProjectSettingsEditor::_update_translations() {
|
||||
String n = names[i];
|
||||
String l = langs[i];
|
||||
bool is_checked = l_filter.has(l);
|
||||
if (filter_mode == SHOW_ONLY_SELECTED_LOCALES && !is_checked) continue;
|
||||
if (filter_mode == SHOW_ONLY_SELECTED_LOCALES && !is_checked)
|
||||
continue;
|
||||
|
||||
TreeItem *t = translation_filter->create_item(root);
|
||||
t->set_cell_mode(0, TreeItem::CELL_MODE_CHECK);
|
||||
|
@ -491,8 +491,10 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
|
||||
for (List<Node *>::Element *E = selection.front(); E; E = E->next()) {
|
||||
int index = E->get()->get_index();
|
||||
|
||||
if (index > highest_id) highest_id = index;
|
||||
if (index < lowest_id) lowest_id = index;
|
||||
if (index > highest_id)
|
||||
highest_id = index;
|
||||
if (index < lowest_id)
|
||||
lowest_id = index;
|
||||
|
||||
if (E->get()->get_parent() != common_parent)
|
||||
common_parent = nullptr;
|
||||
@ -501,8 +503,10 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
|
||||
if (!common_parent || (MOVING_DOWN && highest_id >= common_parent->get_child_count() - MOVING_DOWN) || (MOVING_UP && lowest_id == 0))
|
||||
break; // one or more nodes can not be moved
|
||||
|
||||
if (selection.size() == 1) editor_data->get_undo_redo().create_action(TTR("Move Node In Parent"));
|
||||
if (selection.size() > 1) editor_data->get_undo_redo().create_action(TTR("Move Nodes In Parent"));
|
||||
if (selection.size() == 1)
|
||||
editor_data->get_undo_redo().create_action(TTR("Move Node In Parent"));
|
||||
if (selection.size() > 1)
|
||||
editor_data->get_undo_redo().create_action(TTR("Move Nodes In Parent"));
|
||||
|
||||
for (int i = 0; i < selection.size(); i++) {
|
||||
Node *top_node = selection[i];
|
||||
@ -986,8 +990,12 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
|
||||
}
|
||||
} else {
|
||||
switch (p_tool) {
|
||||
case TOOL_CREATE_2D_SCENE: new_node = memnew(Node2D); break;
|
||||
case TOOL_CREATE_3D_SCENE: new_node = memnew(Node3D); break;
|
||||
case TOOL_CREATE_2D_SCENE:
|
||||
new_node = memnew(Node2D);
|
||||
break;
|
||||
case TOOL_CREATE_3D_SCENE:
|
||||
new_node = memnew(Node3D);
|
||||
break;
|
||||
case TOOL_CREATE_USER_INTERFACE: {
|
||||
Control *node = memnew(Control);
|
||||
node->set_anchors_and_margins_preset(PRESET_WIDE); //more useful for resizable UIs.
|
||||
|
@ -167,11 +167,14 @@ String ScriptCreateDialog::_validate_path(const String &p_path, bool p_file_must
|
||||
|
||||
String p = p_path.strip_edges();
|
||||
|
||||
if (p == "") return TTR("Path is empty.");
|
||||
if (p.get_file().get_basename() == "") return TTR("Filename is empty.");
|
||||
if (p == "")
|
||||
return TTR("Path is empty.");
|
||||
if (p.get_file().get_basename() == "")
|
||||
return TTR("Filename is empty.");
|
||||
|
||||
p = ProjectSettings::get_singleton()->localize_path(p);
|
||||
if (!p.begins_with("res://")) return TTR("Path is not local.");
|
||||
if (!p.begins_with("res://"))
|
||||
return TTR("Path is not local.");
|
||||
|
||||
DirAccess *d = DirAccess::create(DirAccess::ACCESS_RESOURCES);
|
||||
if (d->change_dir(p.get_base_dir()) != OK) {
|
||||
@ -216,12 +219,15 @@ String ScriptCreateDialog::_validate_path(const String &p_path, bool p_file_must
|
||||
index++;
|
||||
}
|
||||
|
||||
if (!found) return TTR("Invalid extension.");
|
||||
if (!match) return TTR("Wrong extension chosen.");
|
||||
if (!found)
|
||||
return TTR("Invalid extension.");
|
||||
if (!match)
|
||||
return TTR("Wrong extension chosen.");
|
||||
|
||||
/* Let ScriptLanguage do custom validation */
|
||||
String path_error = ScriptServer::get_language(language_menu->get_selected())->validate_path(p);
|
||||
if (path_error != "") return path_error;
|
||||
if (path_error != "")
|
||||
return path_error;
|
||||
|
||||
/* All checks passed */
|
||||
return "";
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* shader_globals_editor.cpp */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#include "shader_globals_editor.h"
|
||||
#include "editor_node.h"
|
||||
|
||||
|
@ -1,3 +1,33 @@
|
||||
/*************************************************************************/
|
||||
/* shader_globals_editor.h */
|
||||
/*************************************************************************/
|
||||
/* This file is part of: */
|
||||
/* GODOT ENGINE */
|
||||
/* https://godotengine.org */
|
||||
/*************************************************************************/
|
||||
/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur. */
|
||||
/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md). */
|
||||
/* */
|
||||
/* Permission is hereby granted, free of charge, to any person obtaining */
|
||||
/* a copy of this software and associated documentation files (the */
|
||||
/* "Software"), to deal in the Software without restriction, including */
|
||||
/* without limitation the rights to use, copy, modify, merge, publish, */
|
||||
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
||||
/* permit persons to whom the Software is furnished to do so, subject to */
|
||||
/* the following conditions: */
|
||||
/* */
|
||||
/* The above copyright notice and this permission notice shall be */
|
||||
/* included in all copies or substantial portions of the Software. */
|
||||
/* */
|
||||
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
||||
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
||||
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
||||
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
||||
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
||||
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
||||
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
||||
/*************************************************************************/
|
||||
|
||||
#ifndef SHADER_GLOBALS_EDITOR_H
|
||||
#define SHADER_GLOBALS_EDITOR_H
|
||||
|
||||
|
@ -2260,7 +2260,8 @@ bool Main::iteration() {
|
||||
uint64_t time_step = 1000000L / target_fps;
|
||||
target_ticks += time_step;
|
||||
uint64_t current_ticks = OS::get_singleton()->get_ticks_usec();
|
||||
if (current_ticks < target_ticks) OS::get_singleton()->delay_usec(target_ticks - current_ticks);
|
||||
if (current_ticks < target_ticks)
|
||||
OS::get_singleton()->delay_usec(target_ticks - current_ticks);
|
||||
current_ticks = OS::get_singleton()->get_ticks_usec();
|
||||
target_ticks = MIN(MAX(target_ticks, current_ticks - time_step), current_ticks + time_step);
|
||||
}
|
||||
|
@ -125,33 +125,60 @@ String Performance::get_monitor_name(Monitor p_monitor) const {
|
||||
float Performance::get_monitor(Monitor p_monitor) const {
|
||||
|
||||
switch (p_monitor) {
|
||||
case TIME_FPS: return Engine::get_singleton()->get_frames_per_second();
|
||||
case TIME_PROCESS: return _process_time;
|
||||
case TIME_PHYSICS_PROCESS: return _physics_process_time;
|
||||
case MEMORY_STATIC: return Memory::get_mem_usage();
|
||||
case MEMORY_STATIC_MAX: return Memory::get_mem_max_usage();
|
||||
case MEMORY_MESSAGE_BUFFER_MAX: return MessageQueue::get_singleton()->get_max_buffer_usage();
|
||||
case OBJECT_COUNT: return ObjectDB::get_object_count();
|
||||
case OBJECT_RESOURCE_COUNT: return ResourceCache::get_cached_resource_count();
|
||||
case OBJECT_NODE_COUNT: return _get_node_count();
|
||||
case OBJECT_ORPHAN_NODE_COUNT: return Node::orphan_node_count;
|
||||
case RENDER_OBJECTS_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_OBJECTS_IN_FRAME);
|
||||
case RENDER_VERTICES_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_VERTICES_IN_FRAME);
|
||||
case RENDER_MATERIAL_CHANGES_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_MATERIAL_CHANGES_IN_FRAME);
|
||||
case RENDER_SHADER_CHANGES_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_SHADER_CHANGES_IN_FRAME);
|
||||
case RENDER_SURFACE_CHANGES_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_SURFACE_CHANGES_IN_FRAME);
|
||||
case RENDER_DRAW_CALLS_IN_FRAME: return RS::get_singleton()->get_render_info(RS::INFO_DRAW_CALLS_IN_FRAME);
|
||||
case RENDER_VIDEO_MEM_USED: return RS::get_singleton()->get_render_info(RS::INFO_VIDEO_MEM_USED);
|
||||
case RENDER_TEXTURE_MEM_USED: return RS::get_singleton()->get_render_info(RS::INFO_TEXTURE_MEM_USED);
|
||||
case RENDER_VERTEX_MEM_USED: return RS::get_singleton()->get_render_info(RS::INFO_VERTEX_MEM_USED);
|
||||
case RENDER_USAGE_VIDEO_MEM_TOTAL: return RS::get_singleton()->get_render_info(RS::INFO_USAGE_VIDEO_MEM_TOTAL);
|
||||
case PHYSICS_2D_ACTIVE_OBJECTS: return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_ACTIVE_OBJECTS);
|
||||
case PHYSICS_2D_COLLISION_PAIRS: return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_COLLISION_PAIRS);
|
||||
case PHYSICS_2D_ISLAND_COUNT: return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_ISLAND_COUNT);
|
||||
case PHYSICS_3D_ACTIVE_OBJECTS: return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_ACTIVE_OBJECTS);
|
||||
case PHYSICS_3D_COLLISION_PAIRS: return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_COLLISION_PAIRS);
|
||||
case PHYSICS_3D_ISLAND_COUNT: return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_ISLAND_COUNT);
|
||||
case AUDIO_OUTPUT_LATENCY: return AudioServer::get_singleton()->get_output_latency();
|
||||
case TIME_FPS:
|
||||
return Engine::get_singleton()->get_frames_per_second();
|
||||
case TIME_PROCESS:
|
||||
return _process_time;
|
||||
case TIME_PHYSICS_PROCESS:
|
||||
return _physics_process_time;
|
||||
case MEMORY_STATIC:
|
||||
return Memory::get_mem_usage();
|
||||
case MEMORY_STATIC_MAX:
|
||||
return Memory::get_mem_max_usage();
|
||||
case MEMORY_MESSAGE_BUFFER_MAX:
|
||||
return MessageQueue::get_singleton()->get_max_buffer_usage();
|
||||
case OBJECT_COUNT:
|
||||
return ObjectDB::get_object_count();
|
||||
case OBJECT_RESOURCE_COUNT:
|
||||
return ResourceCache::get_cached_resource_count();
|
||||
case OBJECT_NODE_COUNT:
|
||||
return _get_node_count();
|
||||
case OBJECT_ORPHAN_NODE_COUNT:
|
||||
return Node::orphan_node_count;
|
||||
case RENDER_OBJECTS_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_OBJECTS_IN_FRAME);
|
||||
case RENDER_VERTICES_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_VERTICES_IN_FRAME);
|
||||
case RENDER_MATERIAL_CHANGES_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_MATERIAL_CHANGES_IN_FRAME);
|
||||
case RENDER_SHADER_CHANGES_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_SHADER_CHANGES_IN_FRAME);
|
||||
case RENDER_SURFACE_CHANGES_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_SURFACE_CHANGES_IN_FRAME);
|
||||
case RENDER_DRAW_CALLS_IN_FRAME:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_DRAW_CALLS_IN_FRAME);
|
||||
case RENDER_VIDEO_MEM_USED:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_VIDEO_MEM_USED);
|
||||
case RENDER_TEXTURE_MEM_USED:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_TEXTURE_MEM_USED);
|
||||
case RENDER_VERTEX_MEM_USED:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_VERTEX_MEM_USED);
|
||||
case RENDER_USAGE_VIDEO_MEM_TOTAL:
|
||||
return RS::get_singleton()->get_render_info(RS::INFO_USAGE_VIDEO_MEM_TOTAL);
|
||||
case PHYSICS_2D_ACTIVE_OBJECTS:
|
||||
return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_ACTIVE_OBJECTS);
|
||||
case PHYSICS_2D_COLLISION_PAIRS:
|
||||
return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_COLLISION_PAIRS);
|
||||
case PHYSICS_2D_ISLAND_COUNT:
|
||||
return PhysicsServer2D::get_singleton()->get_process_info(PhysicsServer2D::INFO_ISLAND_COUNT);
|
||||
case PHYSICS_3D_ACTIVE_OBJECTS:
|
||||
return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_ACTIVE_OBJECTS);
|
||||
case PHYSICS_3D_COLLISION_PAIRS:
|
||||
return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_COLLISION_PAIRS);
|
||||
case PHYSICS_3D_ISLAND_COUNT:
|
||||
return PhysicsServer3D::get_singleton()->get_process_info(PhysicsServer3D::INFO_ISLAND_COUNT);
|
||||
case AUDIO_OUTPUT_LATENCY:
|
||||
return AudioServer::get_singleton()->get_output_latency();
|
||||
|
||||
default: {
|
||||
}
|
||||
|
@ -173,7 +173,8 @@ bool test_add_remove() {
|
||||
for (int i = 0; i < 20000; i++) {
|
||||
int u = Math::rand() % 5;
|
||||
int v = Math::rand() % 4;
|
||||
if (u == v) v = 4;
|
||||
if (u == v)
|
||||
v = 4;
|
||||
if (Math::rand() % 2 == 1) {
|
||||
// Add a (possibly existing) directed edge and confirm connectivity
|
||||
a.connect_points(u, v, false);
|
||||
@ -195,7 +196,8 @@ bool test_add_remove() {
|
||||
for (int j = 0; j < 10; j++) {
|
||||
int u = Math::rand() % 5;
|
||||
int v = Math::rand() % 4;
|
||||
if (u == v) v = 4;
|
||||
if (u == v)
|
||||
v = 4;
|
||||
if (Math::rand() % 2 == 1)
|
||||
a.connect_points(u, v, false);
|
||||
else
|
||||
@ -239,7 +241,8 @@ bool test_solutions() {
|
||||
int u, v;
|
||||
u = Math::rand() % N;
|
||||
v = Math::rand() % (N - 1);
|
||||
if (u == v) v = N - 1;
|
||||
if (u == v)
|
||||
v = N - 1;
|
||||
|
||||
// Pick a random operation
|
||||
int op = Math::rand();
|
||||
@ -253,14 +256,16 @@ bool test_solutions() {
|
||||
// Add edge (u, v); possibly bidirectional
|
||||
a.connect_points(u, v, op % 2);
|
||||
adj[u][v] = true;
|
||||
if (op % 2) adj[v][u] = true;
|
||||
if (op % 2)
|
||||
adj[v][u] = true;
|
||||
break;
|
||||
case 6:
|
||||
case 7:
|
||||
// Remove edge (u, v); possibly bidirectional
|
||||
a.disconnect_points(u, v, op % 2);
|
||||
adj[u][v] = false;
|
||||
if (op % 2) adj[v][u] = false;
|
||||
if (op % 2)
|
||||
adj[v][u] = false;
|
||||
break;
|
||||
case 8:
|
||||
// Remove point u and add it back; clears adjacent edges and changes coordinates
|
||||
@ -291,12 +296,14 @@ bool test_solutions() {
|
||||
int count = 0;
|
||||
for (int u = 0; u < N; u++)
|
||||
for (int v = 0; v < N; v++)
|
||||
if (adj[u][v]) count++;
|
||||
if (adj[u][v])
|
||||
count++;
|
||||
printf("Test #%4d: %3d edges, ", test + 1, count);
|
||||
count = 0;
|
||||
for (int u = 0; u < N; u++)
|
||||
for (int v = 0; v < N; v++)
|
||||
if (!Math::is_inf(d[u][v])) count++;
|
||||
if (!Math::is_inf(d[u][v]))
|
||||
count++;
|
||||
printf("%3d/%d pairs of reachable points\n", count - N, N * (N - 1));
|
||||
|
||||
// Check A*'s output
|
||||
@ -339,7 +346,8 @@ bool test_solutions() {
|
||||
}
|
||||
|
||||
exit:
|
||||
if (!match) return false;
|
||||
if (!match)
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -199,14 +199,24 @@ class GetClassAndNamespace {
|
||||
|
||||
switch (next) {
|
||||
|
||||
case 'b': res = 8; break;
|
||||
case 't': res = 9; break;
|
||||
case 'n': res = 10; break;
|
||||
case 'f': res = 12; break;
|
||||
case 'b':
|
||||
res = 8;
|
||||
break;
|
||||
case 't':
|
||||
res = 9;
|
||||
break;
|
||||
case 'n':
|
||||
res = 10;
|
||||
break;
|
||||
case 'f':
|
||||
res = 12;
|
||||
break;
|
||||
case 'r':
|
||||
res = 13;
|
||||
break;
|
||||
case '\"': res = '\"'; break;
|
||||
case '\"':
|
||||
res = '\"';
|
||||
break;
|
||||
case '\\':
|
||||
res = '\\';
|
||||
break;
|
||||
|
@ -61,10 +61,14 @@ static String _typestr(SL::DataType p_type) {
|
||||
static String _prestr(SL::DataPrecision p_pres) {
|
||||
|
||||
switch (p_pres) {
|
||||
case SL::PRECISION_LOWP: return "lowp ";
|
||||
case SL::PRECISION_MEDIUMP: return "mediump ";
|
||||
case SL::PRECISION_HIGHP: return "highp ";
|
||||
case SL::PRECISION_DEFAULT: return "";
|
||||
case SL::PRECISION_LOWP:
|
||||
return "lowp ";
|
||||
case SL::PRECISION_MEDIUMP:
|
||||
return "mediump ";
|
||||
case SL::PRECISION_HIGHP:
|
||||
return "highp ";
|
||||
case SL::PRECISION_DEFAULT:
|
||||
return "";
|
||||
}
|
||||
return "";
|
||||
}
|
||||
@ -77,23 +81,40 @@ static String _opstr(SL::Operator p_op) {
|
||||
static String get_constant_text(SL::DataType p_type, const Vector<SL::ConstantNode::Value> &p_values) {
|
||||
|
||||
switch (p_type) {
|
||||
case SL::TYPE_BOOL: return p_values[0].boolean ? "true" : "false";
|
||||
case SL::TYPE_BVEC2: return String() + "bvec2(" + (p_values[0].boolean ? "true" : "false") + (p_values[1].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_BVEC3: return String() + "bvec3(" + (p_values[0].boolean ? "true" : "false") + "," + (p_values[1].boolean ? "true" : "false") + "," + (p_values[2].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_BVEC4: return String() + "bvec4(" + (p_values[0].boolean ? "true" : "false") + "," + (p_values[1].boolean ? "true" : "false") + "," + (p_values[2].boolean ? "true" : "false") + "," + (p_values[3].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_INT: return rtos(p_values[0].sint);
|
||||
case SL::TYPE_IVEC2: return String() + "ivec2(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + ")";
|
||||
case SL::TYPE_IVEC3: return String() + "ivec3(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + "," + rtos(p_values[2].sint) + ")";
|
||||
case SL::TYPE_IVEC4: return String() + "ivec4(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + "," + rtos(p_values[2].sint) + "," + rtos(p_values[3].sint) + ")";
|
||||
case SL::TYPE_UINT: return rtos(p_values[0].real);
|
||||
case SL::TYPE_UVEC2: return String() + "uvec2(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + ")";
|
||||
case SL::TYPE_UVEC3: return String() + "uvec3(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + ")";
|
||||
case SL::TYPE_UVEC4: return String() + "uvec4(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + "," + rtos(p_values[3].real) + ")";
|
||||
case SL::TYPE_FLOAT: return rtos(p_values[0].real);
|
||||
case SL::TYPE_VEC2: return String() + "vec2(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + ")";
|
||||
case SL::TYPE_VEC3: return String() + "vec3(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + ")";
|
||||
case SL::TYPE_VEC4: return String() + "vec4(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + "," + rtos(p_values[3].real) + ")";
|
||||
default: ERR_FAIL_V(String());
|
||||
case SL::TYPE_BOOL:
|
||||
return p_values[0].boolean ? "true" : "false";
|
||||
case SL::TYPE_BVEC2:
|
||||
return String() + "bvec2(" + (p_values[0].boolean ? "true" : "false") + (p_values[1].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_BVEC3:
|
||||
return String() + "bvec3(" + (p_values[0].boolean ? "true" : "false") + "," + (p_values[1].boolean ? "true" : "false") + "," + (p_values[2].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_BVEC4:
|
||||
return String() + "bvec4(" + (p_values[0].boolean ? "true" : "false") + "," + (p_values[1].boolean ? "true" : "false") + "," + (p_values[2].boolean ? "true" : "false") + "," + (p_values[3].boolean ? "true" : "false") + ")";
|
||||
case SL::TYPE_INT:
|
||||
return rtos(p_values[0].sint);
|
||||
case SL::TYPE_IVEC2:
|
||||
return String() + "ivec2(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + ")";
|
||||
case SL::TYPE_IVEC3:
|
||||
return String() + "ivec3(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + "," + rtos(p_values[2].sint) + ")";
|
||||
case SL::TYPE_IVEC4:
|
||||
return String() + "ivec4(" + rtos(p_values[0].sint) + "," + rtos(p_values[1].sint) + "," + rtos(p_values[2].sint) + "," + rtos(p_values[3].sint) + ")";
|
||||
case SL::TYPE_UINT:
|
||||
return rtos(p_values[0].real);
|
||||
case SL::TYPE_UVEC2:
|
||||
return String() + "uvec2(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + ")";
|
||||
case SL::TYPE_UVEC3:
|
||||
return String() + "uvec3(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + ")";
|
||||
case SL::TYPE_UVEC4:
|
||||
return String() + "uvec4(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + "," + rtos(p_values[3].real) + ")";
|
||||
case SL::TYPE_FLOAT:
|
||||
return rtos(p_values[0].real);
|
||||
case SL::TYPE_VEC2:
|
||||
return String() + "vec2(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + ")";
|
||||
case SL::TYPE_VEC3:
|
||||
return String() + "vec3(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + ")";
|
||||
case SL::TYPE_VEC4:
|
||||
return String() + "vec4(" + rtos(p_values[0].real) + "," + rtos(p_values[1].real) + "," + rtos(p_values[2].real) + "," + rtos(p_values[3].real) + ")";
|
||||
default:
|
||||
ERR_FAIL_V(String());
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -972,22 +972,26 @@ bool test_31() {
|
||||
String a = "";
|
||||
success = a[0] == 0;
|
||||
OS::get_singleton()->print("Is 0 String[0]:, %s\n", success ? "OK" : "FAIL");
|
||||
if (!success) state = false;
|
||||
if (!success)
|
||||
state = false;
|
||||
|
||||
String b = "Godot";
|
||||
success = b[b.size()] == 0;
|
||||
OS::get_singleton()->print("Is 0 String[size()]:, %s\n", success ? "OK" : "FAIL");
|
||||
if (!success) state = false;
|
||||
if (!success)
|
||||
state = false;
|
||||
|
||||
const String c = "";
|
||||
success = c[0] == 0;
|
||||
OS::get_singleton()->print("Is 0 const String[0]:, %s\n", success ? "OK" : "FAIL");
|
||||
if (!success) state = false;
|
||||
if (!success)
|
||||
state = false;
|
||||
|
||||
const String d = "Godot";
|
||||
success = d[d.size()] == 0;
|
||||
OS::get_singleton()->print("Is 0 const String[size()]:, %s\n", success ? "OK" : "FAIL");
|
||||
if (!success) state = false;
|
||||
if (!success)
|
||||
state = false;
|
||||
|
||||
return state;
|
||||
};
|
||||
|
@ -202,20 +202,34 @@ public:
|
||||
*/
|
||||
static float get_fbx_fps(int32_t time_mode, const aiScene *p_scene) {
|
||||
switch (time_mode) {
|
||||
case AssetImportFbx::TIME_MODE_DEFAULT: return 24; //hack
|
||||
case AssetImportFbx::TIME_MODE_120: return 120;
|
||||
case AssetImportFbx::TIME_MODE_100: return 100;
|
||||
case AssetImportFbx::TIME_MODE_60: return 60;
|
||||
case AssetImportFbx::TIME_MODE_50: return 50;
|
||||
case AssetImportFbx::TIME_MODE_48: return 48;
|
||||
case AssetImportFbx::TIME_MODE_30: return 30;
|
||||
case AssetImportFbx::TIME_MODE_30_DROP: return 30;
|
||||
case AssetImportFbx::TIME_MODE_NTSC_DROP_FRAME: return 29.9700262f;
|
||||
case AssetImportFbx::TIME_MODE_NTSC_FULL_FRAME: return 29.9700262f;
|
||||
case AssetImportFbx::TIME_MODE_PAL: return 25;
|
||||
case AssetImportFbx::TIME_MODE_CINEMA: return 24;
|
||||
case AssetImportFbx::TIME_MODE_1000: return 1000;
|
||||
case AssetImportFbx::TIME_MODE_CINEMA_ND: return 23.976f;
|
||||
case AssetImportFbx::TIME_MODE_DEFAULT:
|
||||
return 24; //hack
|
||||
case AssetImportFbx::TIME_MODE_120:
|
||||
return 120;
|
||||
case AssetImportFbx::TIME_MODE_100:
|
||||
return 100;
|
||||
case AssetImportFbx::TIME_MODE_60:
|
||||
return 60;
|
||||
case AssetImportFbx::TIME_MODE_50:
|
||||
return 50;
|
||||
case AssetImportFbx::TIME_MODE_48:
|
||||
return 48;
|
||||
case AssetImportFbx::TIME_MODE_30:
|
||||
return 30;
|
||||
case AssetImportFbx::TIME_MODE_30_DROP:
|
||||
return 30;
|
||||
case AssetImportFbx::TIME_MODE_NTSC_DROP_FRAME:
|
||||
return 29.9700262f;
|
||||
case AssetImportFbx::TIME_MODE_NTSC_FULL_FRAME:
|
||||
return 29.9700262f;
|
||||
case AssetImportFbx::TIME_MODE_PAL:
|
||||
return 25;
|
||||
case AssetImportFbx::TIME_MODE_CINEMA:
|
||||
return 24;
|
||||
case AssetImportFbx::TIME_MODE_1000:
|
||||
return 1000;
|
||||
case AssetImportFbx::TIME_MODE_CINEMA_ND:
|
||||
return 23.976f;
|
||||
case AssetImportFbx::TIME_MODE_CUSTOM:
|
||||
int32_t frame_rate = -1;
|
||||
p_scene->mMetaData->Get("FrameRate", frame_rate);
|
||||
|
@ -162,7 +162,8 @@ void HingeJointBullet::set_flag(PhysicsServer3D::HingeJointFlag p_flag, bool p_v
|
||||
case PhysicsServer3D::HINGE_JOINT_FLAG_ENABLE_MOTOR:
|
||||
hingeConstraint->enableMotor(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::HINGE_JOINT_FLAG_MAX: break; // Can't happen, but silences warning
|
||||
case PhysicsServer3D::HINGE_JOINT_FLAG_MAX:
|
||||
break; // Can't happen, but silences warning
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -81,7 +81,8 @@ void ShapeBullet::add_owner(ShapeOwnerBullet *p_owner) {
|
||||
|
||||
void ShapeBullet::remove_owner(ShapeOwnerBullet *p_owner, bool p_permanentlyFromThisBody) {
|
||||
Map<ShapeOwnerBullet *, int>::Element *E = owners.find(p_owner);
|
||||
if (!E) return;
|
||||
if (!E)
|
||||
return;
|
||||
E->get()--;
|
||||
if (p_permanentlyFromThisBody || 0 >= E->get()) {
|
||||
owners.erase(E);
|
||||
|
@ -344,56 +344,123 @@ real_t SliderJointBullet::getLinearPos() {
|
||||
|
||||
void SliderJointBullet::set_param(PhysicsServer3D::SliderJointParam p_param, real_t p_value) {
|
||||
switch (p_param) {
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_UPPER: setUpperLinLimit(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_LOWER: setLowerLinLimit(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_SOFTNESS: setSoftnessLimLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_RESTITUTION: setRestitutionLimLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_DAMPING: setDampingLimLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_SOFTNESS: setSoftnessDirLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_RESTITUTION: setRestitutionDirLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_DAMPING: setDampingDirLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_SOFTNESS: setSoftnessOrthoLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_RESTITUTION: setRestitutionOrthoLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_DAMPING: setDampingOrthoLin(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_UPPER: setUpperAngLimit(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_LOWER: setLowerAngLimit(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_SOFTNESS: setSoftnessLimAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_RESTITUTION: setRestitutionLimAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_DAMPING: setDampingLimAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_SOFTNESS: setSoftnessDirAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_RESTITUTION: setRestitutionDirAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_DAMPING: setDampingDirAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_SOFTNESS: setSoftnessOrthoAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_RESTITUTION: setRestitutionOrthoAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_DAMPING: setDampingOrthoAng(p_value); break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_MAX: break; // Can't happen, but silences warning
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_UPPER:
|
||||
setUpperLinLimit(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_LOWER:
|
||||
setLowerLinLimit(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_SOFTNESS:
|
||||
setSoftnessLimLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_RESTITUTION:
|
||||
setRestitutionLimLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_DAMPING:
|
||||
setDampingLimLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_SOFTNESS:
|
||||
setSoftnessDirLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_RESTITUTION:
|
||||
setRestitutionDirLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_DAMPING:
|
||||
setDampingDirLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_SOFTNESS:
|
||||
setSoftnessOrthoLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_RESTITUTION:
|
||||
setRestitutionOrthoLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_DAMPING:
|
||||
setDampingOrthoLin(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_UPPER:
|
||||
setUpperAngLimit(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_LOWER:
|
||||
setLowerAngLimit(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_SOFTNESS:
|
||||
setSoftnessLimAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_RESTITUTION:
|
||||
setRestitutionLimAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_DAMPING:
|
||||
setDampingLimAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_SOFTNESS:
|
||||
setSoftnessDirAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_RESTITUTION:
|
||||
setRestitutionDirAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_DAMPING:
|
||||
setDampingDirAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_SOFTNESS:
|
||||
setSoftnessOrthoAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_RESTITUTION:
|
||||
setRestitutionOrthoAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_DAMPING:
|
||||
setDampingOrthoAng(p_value);
|
||||
break;
|
||||
case PhysicsServer3D::SLIDER_JOINT_MAX:
|
||||
break; // Can't happen, but silences warning
|
||||
}
|
||||
}
|
||||
|
||||
real_t SliderJointBullet::get_param(PhysicsServer3D::SliderJointParam p_param) const {
|
||||
switch (p_param) {
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_UPPER: return getUpperLinLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_LOWER: return getLowerLinLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_SOFTNESS: return getSoftnessLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_RESTITUTION: return getRestitutionLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_DAMPING: return getDampingLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_SOFTNESS: return getSoftnessDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_RESTITUTION: return getRestitutionDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_DAMPING: return getDampingDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_SOFTNESS: return getSoftnessOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_RESTITUTION: return getRestitutionOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_DAMPING: return getDampingOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_UPPER: return getUpperAngLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_LOWER: return getLowerAngLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_SOFTNESS: return getSoftnessLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_RESTITUTION: return getRestitutionLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_DAMPING: return getDampingLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_SOFTNESS: return getSoftnessDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_RESTITUTION: return getRestitutionDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_DAMPING: return getDampingDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_SOFTNESS: return getSoftnessOrthoAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_RESTITUTION: return getRestitutionOrthoAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_DAMPING: return getDampingOrthoAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_UPPER:
|
||||
return getUpperLinLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_LOWER:
|
||||
return getLowerLinLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_SOFTNESS:
|
||||
return getSoftnessLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_RESTITUTION:
|
||||
return getRestitutionLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_LIMIT_DAMPING:
|
||||
return getDampingLimLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_SOFTNESS:
|
||||
return getSoftnessDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_RESTITUTION:
|
||||
return getRestitutionDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_MOTION_DAMPING:
|
||||
return getDampingDirLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_SOFTNESS:
|
||||
return getSoftnessOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_RESTITUTION:
|
||||
return getRestitutionOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_LINEAR_ORTHOGONAL_DAMPING:
|
||||
return getDampingOrthoLin();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_UPPER:
|
||||
return getUpperAngLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_LOWER:
|
||||
return getLowerAngLimit();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_SOFTNESS:
|
||||
return getSoftnessLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_RESTITUTION:
|
||||
return getRestitutionLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_LIMIT_DAMPING:
|
||||
return getDampingLimAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_SOFTNESS:
|
||||
return getSoftnessDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_RESTITUTION:
|
||||
return getRestitutionDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_MOTION_DAMPING:
|
||||
return getDampingDirAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_SOFTNESS:
|
||||
return getSoftnessOrthoAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_RESTITUTION:
|
||||
return getRestitutionOrthoAng();
|
||||
case PhysicsServer3D::SLIDER_JOINT_ANGULAR_ORTHOGONAL_DAMPING:
|
||||
return getDampingOrthoAng();
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
|
@ -170,7 +170,8 @@ public:
|
||||
contactDebugCount = 0;
|
||||
}
|
||||
_FORCE_INLINE_ void add_debug_contact(const Vector3 &p_contact) {
|
||||
if (contactDebugCount < contactDebug.size()) contactDebug.write[contactDebugCount++] = p_contact;
|
||||
if (contactDebugCount < contactDebug.size())
|
||||
contactDebug.write[contactDebugCount++] = p_contact;
|
||||
}
|
||||
_FORCE_INLINE_ Vector<Vector3> get_debug_contacts() { return contactDebug; }
|
||||
_FORCE_INLINE_ int get_debug_contact_count() { return contactDebugCount; }
|
||||
|
@ -138,10 +138,12 @@ inline bool is_point_in_triangle(const Vector3 &p_point, const Vector3 p_vertice
|
||||
lambda[2] = p_vertices[0].cross(p_vertices[1]).dot(p_point) / det;
|
||||
|
||||
// Point is in the plane if all lambdas sum to 1.
|
||||
if (!Math::is_equal_approx(lambda[0] + lambda[1] + lambda[2], 1)) return false;
|
||||
if (!Math::is_equal_approx(lambda[0] + lambda[1] + lambda[2], 1))
|
||||
return false;
|
||||
|
||||
// Point is inside the triangle if all lambdas are positive.
|
||||
if (lambda[0] < 0 || lambda[1] < 0 || lambda[2] < 0) return false;
|
||||
if (lambda[0] < 0 || lambda[1] < 0 || lambda[2] < 0)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
@ -524,7 +526,8 @@ void CSGBrushOperation::MeshMerge::_add_distance(List<real_t> &r_intersectionsA,
|
||||
|
||||
// Check if distance exists.
|
||||
for (const List<real_t>::Element *E = intersections.front(); E; E = E->next())
|
||||
if (Math::abs(**E - p_distance) < vertex_snap) return;
|
||||
if (Math::abs(**E - p_distance) < vertex_snap)
|
||||
return;
|
||||
|
||||
intersections.push_back(p_distance);
|
||||
}
|
||||
@ -790,7 +793,8 @@ int CSGBrushOperation::Build2DFaces::_add_vertex(const Vertex2D &p_vertex) {
|
||||
|
||||
// Check if vertex exists.
|
||||
int vertex_id = _get_point_idx(p_vertex.point);
|
||||
if (vertex_id != -1) return vertex_id;
|
||||
if (vertex_id != -1)
|
||||
return vertex_id;
|
||||
|
||||
vertices.push_back(p_vertex);
|
||||
return vertices.size() - 1;
|
||||
@ -816,7 +820,8 @@ void CSGBrushOperation::Build2DFaces::_add_vertex_idx_sorted(Vector<int> &r_vert
|
||||
|
||||
// Sort along the axis with the greatest difference.
|
||||
int axis = 0;
|
||||
if (Math::abs(new_point.x - first_point.x) < Math::abs(new_point.y - first_point.y)) axis = 1;
|
||||
if (Math::abs(new_point.x - first_point.x) < Math::abs(new_point.y - first_point.y))
|
||||
axis = 1;
|
||||
|
||||
// Add it to the beginning or the end appropriately.
|
||||
if (new_point[axis] < first_point[axis])
|
||||
@ -834,7 +839,8 @@ void CSGBrushOperation::Build2DFaces::_add_vertex_idx_sorted(Vector<int> &r_vert
|
||||
|
||||
// Determine axis being sorted against i.e. the axis with the greatest difference.
|
||||
int axis = 0;
|
||||
if (Math::abs(last_point.x - first_point.x) < Math::abs(last_point.y - first_point.y)) axis = 1;
|
||||
if (Math::abs(last_point.x - first_point.x) < Math::abs(last_point.y - first_point.y))
|
||||
axis = 1;
|
||||
|
||||
// Insert the point at the appropriate index.
|
||||
for (int insert_idx = 0; insert_idx < r_vertex_indices.size(); ++insert_idx) {
|
||||
@ -853,7 +859,8 @@ void CSGBrushOperation::Build2DFaces::_add_vertex_idx_sorted(Vector<int> &r_vert
|
||||
void CSGBrushOperation::Build2DFaces::_merge_faces(const Vector<int> &p_segment_indices) {
|
||||
|
||||
int segments = p_segment_indices.size() - 1;
|
||||
if (segments < 2) return;
|
||||
if (segments < 2)
|
||||
return;
|
||||
|
||||
// Faces around an inner vertex are merged by moving the inner vertex to the first vertex.
|
||||
for (int sorted_idx = 1; sorted_idx < segments; ++sorted_idx) {
|
||||
@ -893,7 +900,8 @@ void CSGBrushOperation::Build2DFaces::_merge_faces(const Vector<int> &p_segment_
|
||||
|
||||
// Skip flattened faces.
|
||||
if (outer_edge_idx[0] == p_segment_indices[closest_idx] ||
|
||||
outer_edge_idx[1] == p_segment_indices[closest_idx]) continue;
|
||||
outer_edge_idx[1] == p_segment_indices[closest_idx])
|
||||
continue;
|
||||
|
||||
//Don't create degenerate triangles.
|
||||
Vector2 edge1[2] = {
|
||||
@ -924,7 +932,8 @@ void CSGBrushOperation::Build2DFaces::_merge_faces(const Vector<int> &p_segment_
|
||||
for (int i = 0; i < merge_faces_idx.size(); ++i)
|
||||
faces.remove(merge_faces_idx[i]);
|
||||
|
||||
if (degenerate_points.size() == 0) continue;
|
||||
if (degenerate_points.size() == 0)
|
||||
continue;
|
||||
|
||||
// Split faces using degenerate points.
|
||||
for (int face_idx = 0; face_idx < faces.size(); ++face_idx) {
|
||||
@ -954,7 +963,8 @@ void CSGBrushOperation::Build2DFaces::_merge_faces(const Vector<int> &p_segment_
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (existing) continue;
|
||||
if (existing)
|
||||
continue;
|
||||
|
||||
// Check if point is on an each edge.
|
||||
for (int face_edge_idx = 0; face_edge_idx < 3; ++face_edge_idx) {
|
||||
@ -1043,10 +1053,12 @@ void CSGBrushOperation::Build2DFaces::_find_edge_intersections(const Vector2 p_s
|
||||
|
||||
// Check if intersection point is an edge point.
|
||||
if ((intersection_point - edge_points[0]).length_squared() < vertex_snap2 ||
|
||||
(intersection_point - edge_points[1]).length_squared() < vertex_snap2) continue;
|
||||
(intersection_point - edge_points[1]).length_squared() < vertex_snap2)
|
||||
continue;
|
||||
|
||||
// Check if edge exists, by checking if the intersecting segment is parallel to the edge.
|
||||
if (are_segements_parallel(p_segment_points, edge_points, vertex_snap2)) continue;
|
||||
if (are_segements_parallel(p_segment_points, edge_points, vertex_snap2))
|
||||
continue;
|
||||
|
||||
// Add the intersection point as a new vertex.
|
||||
Vertex2D new_vertex;
|
||||
@ -1384,7 +1396,8 @@ void CSGBrushOperation::update_faces(const CSGBrush &p_brush_a, const int p_face
|
||||
p_collection.build2DFacesB[p_face_idx_b] = Build2DFaces();
|
||||
has_degenerate = true;
|
||||
}
|
||||
if (has_degenerate) return;
|
||||
if (has_degenerate)
|
||||
return;
|
||||
|
||||
// Ensure B has points either side of or in the plane of A.
|
||||
int in_plane_count = 0, over_count = 0, under_count = 0;
|
||||
@ -1400,7 +1413,8 @@ void CSGBrushOperation::update_faces(const CSGBrush &p_brush_a, const int p_face
|
||||
under_count++;
|
||||
}
|
||||
// If all points under or over the plane, there is no intesection.
|
||||
if (over_count == 3 || under_count == 3) return;
|
||||
if (over_count == 3 || under_count == 3)
|
||||
return;
|
||||
|
||||
// Ensure A has points either side of or in the plane of B.
|
||||
in_plane_count = 0;
|
||||
@ -1418,7 +1432,8 @@ void CSGBrushOperation::update_faces(const CSGBrush &p_brush_a, const int p_face
|
||||
under_count++;
|
||||
}
|
||||
// If all points under or over the plane, there is no intesection.
|
||||
if (over_count == 3 || under_count == 3) return;
|
||||
if (over_count == 3 || under_count == 3)
|
||||
return;
|
||||
|
||||
// Check for intersection using the SAT theorem.
|
||||
{
|
||||
|
@ -90,9 +90,12 @@ Variant CSGShape3DGizmoPlugin::get_handle_value(EditorNode3DGizmo *p_gizmo, int
|
||||
|
||||
CSGBox3D *s = Object::cast_to<CSGBox3D>(cs);
|
||||
switch (p_idx) {
|
||||
case 0: return s->get_width();
|
||||
case 1: return s->get_height();
|
||||
case 2: return s->get_depth();
|
||||
case 0:
|
||||
return s->get_width();
|
||||
case 1:
|
||||
return s->get_height();
|
||||
case 2:
|
||||
return s->get_depth();
|
||||
}
|
||||
}
|
||||
|
||||
@ -157,9 +160,15 @@ void CSGShape3DGizmoPlugin::set_handle(EditorNode3DGizmo *p_gizmo, int p_idx, Ca
|
||||
d = 0.001;
|
||||
|
||||
switch (p_idx) {
|
||||
case 0: s->set_width(d * 2); break;
|
||||
case 1: s->set_height(d * 2); break;
|
||||
case 2: s->set_depth(d * 2); break;
|
||||
case 0:
|
||||
s->set_width(d * 2);
|
||||
break;
|
||||
case 1:
|
||||
s->set_height(d * 2);
|
||||
break;
|
||||
case 2:
|
||||
s->set_depth(d * 2);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -229,9 +238,15 @@ void CSGShape3DGizmoPlugin::commit_handle(EditorNode3DGizmo *p_gizmo, int p_idx,
|
||||
CSGBox3D *s = Object::cast_to<CSGBox3D>(cs);
|
||||
if (p_cancel) {
|
||||
switch (p_idx) {
|
||||
case 0: s->set_width(p_restore); break;
|
||||
case 1: s->set_height(p_restore); break;
|
||||
case 2: s->set_depth(p_restore); break;
|
||||
case 0:
|
||||
s->set_width(p_restore);
|
||||
break;
|
||||
case 1:
|
||||
s->set_height(p_restore);
|
||||
break;
|
||||
case 2:
|
||||
s->set_depth(p_restore);
|
||||
break;
|
||||
}
|
||||
return;
|
||||
}
|
||||
@ -241,9 +256,15 @@ void CSGShape3DGizmoPlugin::commit_handle(EditorNode3DGizmo *p_gizmo, int p_idx,
|
||||
static const char *method[3] = { "set_width", "set_height", "set_depth" };
|
||||
float current = 0;
|
||||
switch (p_idx) {
|
||||
case 0: current = s->get_width(); break;
|
||||
case 1: current = s->get_height(); break;
|
||||
case 2: current = s->get_depth(); break;
|
||||
case 0:
|
||||
current = s->get_width();
|
||||
break;
|
||||
case 1:
|
||||
current = s->get_height();
|
||||
break;
|
||||
case 2:
|
||||
current = s->get_depth();
|
||||
break;
|
||||
}
|
||||
|
||||
ur->add_do_method(s, method[p_idx], current);
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user