mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2024-11-21 16:46:41 -08:00
vkd3d-shader/hlsl: Convert ternary operator true/false values to a common type.
This commit is contained in:
parent
a064009d3b
commit
dc41444941
Notes:
Alexandre Julliard
2023-05-09 22:26:06 +02:00
Approved-by: Zebediah Figura (@zfigura) Approved-by: Giovanni Mascellani (@giomasce) Approved-by: Henri Verbeet (@hverbeet) Approved-by: Alexandre Julliard (@julliard) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/201
@ -1360,20 +1360,27 @@ static struct hlsl_ir_node *add_unary_logical_expr(struct hlsl_ctx *ctx, struct
|
|||||||
return add_expr(ctx, instrs, op, args, bool_type, loc);
|
return add_expr(ctx, instrs, op, args, bool_type, loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct hlsl_ir_node *add_binary_arithmetic_expr(struct hlsl_ctx *ctx, struct list *instrs,
|
static struct hlsl_type *get_common_numeric_type(struct hlsl_ctx *ctx, const struct hlsl_ir_node *arg1,
|
||||||
enum hlsl_ir_expr_op op, struct hlsl_ir_node *arg1, struct hlsl_ir_node *arg2,
|
const struct hlsl_ir_node *arg2, const struct vkd3d_shader_location *loc)
|
||||||
const struct vkd3d_shader_location *loc)
|
|
||||||
{
|
{
|
||||||
struct hlsl_type *common_type;
|
|
||||||
enum hlsl_base_type base = expr_common_base_type(arg1->data_type->base_type, arg2->data_type->base_type);
|
enum hlsl_base_type base = expr_common_base_type(arg1->data_type->base_type, arg2->data_type->base_type);
|
||||||
enum hlsl_type_class type;
|
enum hlsl_type_class type;
|
||||||
unsigned int dimx, dimy;
|
unsigned int dimx, dimy;
|
||||||
struct hlsl_ir_node *args[HLSL_MAX_OPERANDS] = {0};
|
|
||||||
|
|
||||||
if (!expr_common_shape(ctx, arg1->data_type, arg2->data_type, loc, &type, &dimx, &dimy))
|
if (!expr_common_shape(ctx, arg1->data_type, arg2->data_type, loc, &type, &dimx, &dimy))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
common_type = hlsl_get_numeric_type(ctx, type, base, dimx, dimy);
|
return hlsl_get_numeric_type(ctx, type, base, dimx, dimy);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct hlsl_ir_node *add_binary_arithmetic_expr(struct hlsl_ctx *ctx, struct list *instrs,
|
||||||
|
enum hlsl_ir_expr_op op, struct hlsl_ir_node *arg1, struct hlsl_ir_node *arg2,
|
||||||
|
const struct vkd3d_shader_location *loc)
|
||||||
|
{
|
||||||
|
struct hlsl_ir_node *args[HLSL_MAX_OPERANDS] = {0};
|
||||||
|
struct hlsl_type *common_type;
|
||||||
|
|
||||||
|
common_type = get_common_numeric_type(ctx, arg1, arg2, loc);
|
||||||
|
|
||||||
if (!(args[0] = add_implicit_conversion(ctx, instrs, arg1, common_type, loc)))
|
if (!(args[0] = add_implicit_conversion(ctx, instrs, arg1, common_type, loc)))
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -6008,12 +6015,22 @@ conditional_expr:
|
|||||||
| logicor_expr '?' expr ':' assignment_expr
|
| logicor_expr '?' expr ':' assignment_expr
|
||||||
{
|
{
|
||||||
struct hlsl_ir_node *cond = node_from_list($1), *first = node_from_list($3), *second = node_from_list($5);
|
struct hlsl_ir_node *cond = node_from_list($1), *first = node_from_list($3), *second = node_from_list($5);
|
||||||
|
struct hlsl_type *common_type;
|
||||||
|
|
||||||
list_move_tail($1, $3);
|
list_move_tail($1, $3);
|
||||||
list_move_tail($1, $5);
|
list_move_tail($1, $5);
|
||||||
vkd3d_free($3);
|
vkd3d_free($3);
|
||||||
vkd3d_free($5);
|
vkd3d_free($5);
|
||||||
|
|
||||||
|
if (!(common_type = get_common_numeric_type(ctx, first, second, &@3)))
|
||||||
|
YYABORT;
|
||||||
|
|
||||||
|
if (!(first = add_implicit_conversion(ctx, $1, first, common_type, &@3)))
|
||||||
|
YYABORT;
|
||||||
|
|
||||||
|
if (!(second = add_implicit_conversion(ctx, $1, second, common_type, &@5)))
|
||||||
|
YYABORT;
|
||||||
|
|
||||||
if (!hlsl_add_conditional(ctx, $1, cond, first, second))
|
if (!hlsl_add_conditional(ctx, $1, cond, first, second))
|
||||||
YYABORT;
|
YYABORT;
|
||||||
$$ = $1;
|
$$ = $1;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
[pixel shader]
|
[pixel shader]
|
||||||
uniform float4 x;
|
uniform float4 x;
|
||||||
|
|
||||||
float4 main() : SV_TARGET
|
float4 main() : sv_target
|
||||||
{
|
{
|
||||||
return x.x ? x : x - 1;
|
return x.x ? x : x - 1;
|
||||||
}
|
}
|
||||||
@ -13,3 +13,21 @@ probe all rgba (2.0, 3.0, 4.0, 5.0)
|
|||||||
uniform 0 float4 0.0 10.0 11.0 12.0
|
uniform 0 float4 0.0 10.0 11.0 12.0
|
||||||
draw quad
|
draw quad
|
||||||
probe all rgba (-1.0, 9.0, 10.0, 11.0)
|
probe all rgba (-1.0, 9.0, 10.0, 11.0)
|
||||||
|
|
||||||
|
[pixel shader]
|
||||||
|
uniform float4 x;
|
||||||
|
|
||||||
|
float4 main() : sv_target
|
||||||
|
{
|
||||||
|
float4 ret;
|
||||||
|
|
||||||
|
ret.x = x.x ? x.x : 1;
|
||||||
|
ret.y = x.y ? 2 : x.y;
|
||||||
|
ret.z = ret.w = 0.0;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
[test]
|
||||||
|
uniform 0 float4 1.1 3.0 4.0 5.0
|
||||||
|
draw quad
|
||||||
|
probe all rgba (1.1, 2.0, 0.0, 0.0)
|
||||||
|
Loading…
Reference in New Issue
Block a user