wined3d: Make pixel shader input an array.

This commit is contained in:
Stefan Dösinger 2007-10-18 14:45:32 +02:00 committed by Alexandre Julliard
parent 672ed031ce
commit 9a9dfc76cb
1 changed files with 9 additions and 10 deletions

View File

@ -617,9 +617,8 @@ void shader_generate_glsl_declarations(
} }
/* Declare input register temporaries */ /* Declare input register temporaries */
for (i=0; i < This->baseShader.limits.packed_input; i++) { if(pshader) {
if (reg_maps->packed_input[i]) shader_addline(buffer, "vec4 IN[%lu];\n", This->baseShader.limits.packed_input);
shader_addline(buffer, "vec4 IN%lu;\n", i);
} }
/* Declare output register temporaries */ /* Declare output register temporaries */
@ -775,7 +774,7 @@ static void shader_glsl_get_register_name(
if (pshader) { if (pshader) {
/* Pixel shaders >= 3.0 */ /* Pixel shaders >= 3.0 */
if (WINED3DSHADER_VERSION_MAJOR(This->baseShader.hex_version) >= 3) if (WINED3DSHADER_VERSION_MAJOR(This->baseShader.hex_version) >= 3)
sprintf(tmpStr, "IN%u", reg); sprintf(tmpStr, "IN[%u]", reg);
else { else {
if (reg==0) if (reg==0)
strcpy(tmpStr, "gl_Color"); strcpy(tmpStr, "gl_Color");
@ -2514,28 +2513,28 @@ void pshader_glsl_input_pack(
case WINED3DDECLUSAGE_COLOR: case WINED3DDECLUSAGE_COLOR:
if (usage_idx == 0) if (usage_idx == 0)
shader_addline(buffer, "IN%u%s = vec4(gl_Color)%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(gl_Color)%s;\n",
i, reg_mask, reg_mask); i, reg_mask, reg_mask);
else if (usage_idx == 1) else if (usage_idx == 1)
shader_addline(buffer, "IN%u%s = vec4(gl_SecondaryColor)%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(gl_SecondaryColor)%s;\n",
i, reg_mask, reg_mask); i, reg_mask, reg_mask);
else else
shader_addline(buffer, "IN%u%s = vec4(unsupported_color_input)%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(unsupported_color_input)%s;\n",
i, reg_mask, reg_mask); i, reg_mask, reg_mask);
break; break;
case WINED3DDECLUSAGE_TEXCOORD: case WINED3DDECLUSAGE_TEXCOORD:
shader_addline(buffer, "IN%u%s = vec4(gl_TexCoord[%u])%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(gl_TexCoord[%u])%s;\n",
i, reg_mask, usage_idx, reg_mask ); i, reg_mask, usage_idx, reg_mask );
break; break;
case WINED3DDECLUSAGE_FOG: case WINED3DDECLUSAGE_FOG:
shader_addline(buffer, "IN%u%s = vec4(gl_FogFragCoord)%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(gl_FogFragCoord)%s;\n",
i, reg_mask, reg_mask); i, reg_mask, reg_mask);
break; break;
default: default:
shader_addline(buffer, "IN%u%s = vec4(unsupported_input)%s;\n", shader_addline(buffer, "IN[%u]%s = vec4(unsupported_input)%s;\n",
i, reg_mask, reg_mask); i, reg_mask, reg_mask);
} }
} }