Ported form godot4: Reformat structure string operators

The order of numbers is not changed except for Transform2D. All logic is done inside of their structures (and not in Variant).
-aaronfranke
554c776e08
This commit is contained in:
Relintai 2022-08-16 22:46:24 +02:00
parent 3b4b25b5f8
commit d9669b0ed0
8 changed files with 19 additions and 54 deletions

View File

@ -463,7 +463,7 @@ float Color::gray() const {
} }
Color::operator String() const { Color::operator String() const {
return rtos(r) + ", " + rtos(g) + ", " + rtos(b) + ", " + rtos(a); return "(" + String::num(r, 4) + ", " + String::num(g, 4) + ", " + String::num(b, 4) + ", " + String::num(a, 4) + ")";
} }
Color Color::operator+(const Color &p_color) const { Color Color::operator+(const Color &p_color) const {

View File

@ -426,5 +426,5 @@ Variant AABB::intersects_rayv(const Vector3 &p_from, const Vector3 &p_dir) const
} }
AABB::operator String() const { AABB::operator String() const {
return String() + position + " - " + size; return "[P: " + position.operator String() + ", S: " + size + "]";
} }

View File

@ -803,18 +803,9 @@ bool Basis::operator!=(const Basis &p_matrix) const {
} }
Basis::operator String() const { Basis::operator String() const {
String mtx; return "[X: " + get_axis(0).operator String() +
for (int i = 0; i < 3; i++) { ", Y: " + get_axis(1).operator String() +
for (int j = 0; j < 3; j++) { ", Z: " + get_axis(2).operator String() + "]";
if (i != 0 || j != 0) {
mtx += ", ";
}
mtx += rtos(rows[i][j]);
}
}
return mtx;
} }
Quaternion Basis::get_quaternion() const { Quaternion Basis::get_quaternion() const {

View File

@ -154,5 +154,5 @@ bool Plane::is_equal_approx_any_side(const Plane &p_plane) const {
} }
Plane::operator String() const { Plane::operator String() const {
return normal.operator String() + ", " + rtos(d); return "[N: " + normal.operator String() + ", D: " + String::num_real(d) + "]";
} }

View File

@ -866,14 +866,10 @@ Plane Projection::xform(const Plane &p_vec4) const {
} }
Projection::operator String() const { Projection::operator String() const {
String str; return "[ X: " + matrix[0].operator String() +
for (int i = 0; i < 4; i++) { ", Y: " + matrix[1].operator String() +
for (int j = 0; j < 4; j++) { ", Z: " + matrix[2].operator String() +
str += String((j > 0) ? ", " : "\n") + rtos(matrix[i][j]); ", W: " + matrix[3].operator String() + " ]";
}
}
return str;
} }
real_t Projection::get_aspect() const { real_t Projection::get_aspect() const {

View File

@ -258,9 +258,9 @@ Transform Transform::interpolate_with(const Transform &p_transform, real_t p_c)
} }
Transform::operator String() const { Transform::operator String() const {
return "[X: " + basis.get_column(0).operator String() + return "[X: " + basis.get_axis(0).operator String() +
", Y: " + basis.get_column(1).operator String() + ", Y: " + basis.get_axis(1).operator String() +
", Z: " + basis.get_column(2).operator String() + ", Z: " + basis.get_axis(2).operator String() +
", O: " + origin.operator String() + "]"; ", O: " + origin.operator String() + "]";
} }

View File

@ -330,5 +330,7 @@ Transform2D Transform2D::interpolate_with(const Transform2D &p_transform, real_t
} }
Transform2D::operator String() const { Transform2D::operator String() const {
return String(String() + columns[0] + ", " + columns[1] + ", " + columns[2]); return "[X: " + columns[0].operator String() +
", Y: " + columns[1].operator String() +
", O: " + columns[2].operator String() + "]";
} }

View File

@ -1729,7 +1729,6 @@ String Variant::stringify(List<const void *> &stack) const {
return operator Vector4(); return operator Vector4();
case VECTOR4I: case VECTOR4I:
return operator Vector4i(); return operator Vector4i();
case PLANE: case PLANE:
return operator Plane(); return operator Plane();
case QUATERNION: case QUATERNION:
@ -1737,40 +1736,17 @@ String Variant::stringify(List<const void *> &stack) const {
case AABB: case AABB:
return operator ::AABB(); return operator ::AABB();
case BASIS: { case BASIS: {
Basis mat3 = operator Basis(); return operator Basis();
String mtx("(");
for (int i = 0; i < 3; i++) {
if (i != 0) {
mtx += ", ";
}
mtx += "(";
for (int j = 0; j < 3; j++) {
if (j != 0) {
mtx += ", ";
}
mtx += Variant(mat3.rows[i][j]).operator String();
}
mtx += ")";
}
return mtx + ")";
} break; } break;
case TRANSFORM: case TRANSFORM:
return operator Transform(); return operator Transform();
case TRANSFORM2D: { case TRANSFORM2D: {
Transform2D mat32 = operator Transform2D(); return operator Transform2D();
return "(" + Variant(mat32.columns[0]).operator String() + ", " + Variant(mat32.columns[1]).operator String() + ", " + Variant(mat32.columns[2]).operator String() + ")";
} break; } break;
case PROJECTION: case PROJECTION:
return operator Projection(); return operator Projection();
case COLOR: case COLOR:
return String::num(operator Color().r) + "," + String::num(operator Color().g) + "," + String::num(operator Color().b) + "," + String::num(operator Color().a); return operator Color();
case NODE_PATH: case NODE_PATH:
return operator NodePath(); return operator NodePath();
//RID //RID