• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #define FUNC_VARS                               \
2    struct pt_so_emit *so,                       \
3    const struct draw_prim_info *input_prims,    \
4    const struct draw_vertex_info *input_verts,  \
5    unsigned start,                              \
6    unsigned count
7 
8 #define FUNC_ENTER                                                \
9    /* declare more local vars */                                  \
10    const unsigned prim = input_prims->prim;                       \
11    const unsigned prim_flags = input_prims->flags;                \
12    const boolean quads_flatshade_last = FALSE;                    \
13    const boolean last_vertex_last = TRUE;                         \
14    do {                                                           \
15       debug_assert(input_prims->primitive_count == 1);            \
16       switch (prim) {                                             \
17       case PIPE_PRIM_LINES_ADJACENCY:                             \
18       case PIPE_PRIM_LINE_STRIP_ADJACENCY:                        \
19       case PIPE_PRIM_TRIANGLES_ADJACENCY:                         \
20       case PIPE_PRIM_TRIANGLE_STRIP_ADJACENCY:                    \
21          debug_assert(!"unexpected primitive type in stream output"); \
22          return;                                                  \
23       default:                                                    \
24          break;                                                   \
25       }                                                           \
26    } while (0)                                                    \
27 
28 #define POINT(i0)                so_point(so,i0)
29 #define LINE(flags,i0,i1)        so_line(so,i0,i1)
30 #define TRIANGLE(flags,i0,i1,i2) so_tri(so,i0,i1,i2)
31 
32 #include "draw_decompose_tmp.h"
33