1 /* $Id: fog.c,v 1.36 2002/10/24 23:57:20 brianp Exp $ */
4 * Mesa 3-D graphics library
7 * Copyright (C) 1999-2001 Brian Paul All Rights Reserved.
9 * Permission is hereby granted, free of charge, to any person obtaining a
10 * copy of this software and associated documentation files (the "Software"),
11 * to deal in the Software without restriction, including without limitation
12 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
13 * and/or sell copies of the Software, and to permit persons to whom the
14 * Software is furnished to do so, subject to the following conditions:
16 * The above copyright notice and this permission notice shall be included
17 * in all copies or substantial portions of the Software.
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
22 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
23 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
24 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
37 _mesa_Fogf(GLenum pname
, GLfloat param
)
39 _mesa_Fogfv(pname
, ¶m
);
44 _mesa_Fogi(GLenum pname
, GLint param
)
46 GLfloat fparam
= (GLfloat
) param
;
47 _mesa_Fogfv(pname
, &fparam
);
52 _mesa_Fogiv(GLenum pname
, const GLint
*params
)
61 case GL_FOG_COORDINATE_SOURCE_EXT
:
62 p
[0] = (GLfloat
) *params
;
65 p
[0] = INT_TO_FLOAT( params
[0] );
66 p
[1] = INT_TO_FLOAT( params
[1] );
67 p
[2] = INT_TO_FLOAT( params
[2] );
68 p
[3] = INT_TO_FLOAT( params
[3] );
71 /* Error will be caught later in _mesa_Fogfv */
74 _mesa_Fogfv(pname
, p
);
79 _mesa_Fogfv( GLenum pname
, const GLfloat
*params
)
81 GET_CURRENT_CONTEXT(ctx
);
83 ASSERT_OUTSIDE_BEGIN_END(ctx
);
87 m
= (GLenum
) (GLint
) *params
;
94 _mesa_error( ctx
, GL_INVALID_ENUM
, "glFog" );
97 if (ctx
->Fog
.Mode
== m
)
99 FLUSH_VERTICES(ctx
, _NEW_FOG
);
104 _mesa_error( ctx
, GL_INVALID_VALUE
, "glFog" );
107 if (ctx
->Fog
.Density
== *params
)
109 FLUSH_VERTICES(ctx
, _NEW_FOG
);
110 ctx
->Fog
.Density
= *params
;
113 if (ctx
->Fog
.Start
== *params
)
115 FLUSH_VERTICES(ctx
, _NEW_FOG
);
116 ctx
->Fog
.Start
= *params
;
119 if (ctx
->Fog
.End
== *params
)
121 FLUSH_VERTICES(ctx
, _NEW_FOG
);
122 ctx
->Fog
.End
= *params
;
125 if (ctx
->Fog
.Index
== *params
)
127 FLUSH_VERTICES(ctx
, _NEW_FOG
);
128 ctx
->Fog
.Index
= *params
;
131 if (TEST_EQ_4V(ctx
->Fog
.Color
, params
))
133 FLUSH_VERTICES(ctx
, _NEW_FOG
);
134 ctx
->Fog
.Color
[0] = params
[0];
135 ctx
->Fog
.Color
[1] = params
[1];
136 ctx
->Fog
.Color
[2] = params
[2];
137 ctx
->Fog
.Color
[3] = params
[3];
139 case GL_FOG_COORDINATE_SOURCE_EXT
: {
140 GLenum p
= (GLenum
) (GLint
) *params
;
141 if (!ctx
->Extensions
.EXT_fog_coord
||
142 (p
!= GL_FOG_COORDINATE_EXT
&& p
!= GL_FRAGMENT_DEPTH_EXT
)) {
143 _mesa_error(ctx
, GL_INVALID_ENUM
, "glFog");
146 if (ctx
->Fog
.FogCoordinateSource
== p
)
148 FLUSH_VERTICES(ctx
, _NEW_FOG
);
149 ctx
->Fog
.FogCoordinateSource
= p
;
153 _mesa_error( ctx
, GL_INVALID_ENUM
, "glFog" );
157 if (ctx
->Driver
.Fogfv
) {
158 (*ctx
->Driver
.Fogfv
)( ctx
, pname
, params
);