2 * Mesa 3-D graphics library
5 * Copyright (C) 1999-2007 Brian Paul All Rights Reserved.
7 * Permission is hereby granted, free of charge, to any person obtaining a
8 * copy of this software and associated documentation files (the "Software"),
9 * to deal in the Software without restriction, including without limitation
10 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
11 * and/or sell copies of the Software, and to permit persons to whom the
12 * Software is furnished to do so, subject to the following conditions:
14 * The above copyright notice and this permission notice shall be included
15 * in all copies or substantial portions of the Software.
17 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20 * BRIAN PAUL BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
21 * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25 #include "main/glheader.h"
26 #include "main/colormac.h"
27 #include "main/context.h"
28 #include "main/enums.h"
29 #include "main/feedback.h"
30 #include "main/macros.h"
32 #include "s_context.h"
33 #include "s_feedback.h"
34 #include "s_triangle.h"
39 feedback_vertex(GLcontext
* ctx
, const SWvertex
* v
, const SWvertex
* pv
)
42 const GLfloat
*vtc
= v
->attrib
[FRAG_ATTRIB_TEX0
];
43 const GLfloat
*color
= v
->attrib
[FRAG_ATTRIB_COL0
];
45 win
[0] = v
->attrib
[FRAG_ATTRIB_WPOS
][0];
46 win
[1] = v
->attrib
[FRAG_ATTRIB_WPOS
][1];
47 win
[2] = v
->attrib
[FRAG_ATTRIB_WPOS
][2] / ctx
->DrawBuffer
->_DepthMaxF
;
48 win
[3] = 1.0F
/ v
->attrib
[FRAG_ATTRIB_WPOS
][3];
50 _mesa_feedback_vertex(ctx
, win
, color
, v
->attrib
[FRAG_ATTRIB_CI
][0], vtc
);
55 * Put triangle in feedback buffer.
58 _swrast_feedback_triangle(GLcontext
*ctx
, const SWvertex
*v0
,
59 const SWvertex
*v1
, const SWvertex
*v2
)
61 if (_swrast_culltriangle(ctx
, v0
, v1
, v2
)) {
62 _mesa_feedback_token(ctx
, (GLfloat
) (GLint
) GL_POLYGON_TOKEN
);
63 _mesa_feedback_token(ctx
, (GLfloat
) 3); /* three vertices */
65 if (ctx
->Light
.ShadeModel
== GL_SMOOTH
) {
66 feedback_vertex(ctx
, v0
, v0
);
67 feedback_vertex(ctx
, v1
, v1
);
68 feedback_vertex(ctx
, v2
, v2
);
71 feedback_vertex(ctx
, v0
, v2
);
72 feedback_vertex(ctx
, v1
, v2
);
73 feedback_vertex(ctx
, v2
, v2
);
80 _swrast_feedback_line(GLcontext
*ctx
, const SWvertex
*v0
,
83 GLenum token
= GL_LINE_TOKEN
;
84 SWcontext
*swrast
= SWRAST_CONTEXT(ctx
);
86 if (swrast
->StippleCounter
== 0)
87 token
= GL_LINE_RESET_TOKEN
;
89 _mesa_feedback_token(ctx
, (GLfloat
) (GLint
) token
);
91 if (ctx
->Light
.ShadeModel
== GL_SMOOTH
) {
92 feedback_vertex(ctx
, v0
, v0
);
93 feedback_vertex(ctx
, v1
, v1
);
96 feedback_vertex(ctx
, v0
, v1
);
97 feedback_vertex(ctx
, v1
, v1
);
100 swrast
->StippleCounter
++;
105 _swrast_feedback_point(GLcontext
*ctx
, const SWvertex
*v
)
107 _mesa_feedback_token(ctx
, (GLfloat
) (GLint
) GL_POINT_TOKEN
);
108 feedback_vertex(ctx
, v
, v
);
113 _swrast_select_triangle(GLcontext
*ctx
, const SWvertex
*v0
,
114 const SWvertex
*v1
, const SWvertex
*v2
)
116 if (_swrast_culltriangle(ctx
, v0
, v1
, v2
)) {
117 const GLfloat zs
= 1.0F
/ ctx
->DrawBuffer
->_DepthMaxF
;
119 _mesa_update_hitflag( ctx
, v0
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);
120 _mesa_update_hitflag( ctx
, v1
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);
121 _mesa_update_hitflag( ctx
, v2
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);
127 _swrast_select_line(GLcontext
*ctx
, const SWvertex
*v0
, const SWvertex
*v1
)
129 const GLfloat zs
= 1.0F
/ ctx
->DrawBuffer
->_DepthMaxF
;
130 _mesa_update_hitflag( ctx
, v0
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);
131 _mesa_update_hitflag( ctx
, v1
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);
136 _swrast_select_point(GLcontext
*ctx
, const SWvertex
*v
)
138 const GLfloat zs
= 1.0F
/ ctx
->DrawBuffer
->_DepthMaxF
;
139 _mesa_update_hitflag( ctx
, v
->attrib
[FRAG_ATTRIB_WPOS
][2] * zs
);