This repository has been archived by the owner on Jun 14, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathglEnable.c
142 lines (127 loc) · 3.38 KB
/
glEnable.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#include "pspgl_internal.h"
void __pspgl_enable_state (GLenum cap, GLboolean enable)
{
int i;
unsigned char opcode = 0;
// @@@ from here it's allways the same code exept for index of the command
if (pspgl_curctx->displaylists.is_in_glNewList & GL_COMPILE) { // we must record this command
struct stDisplayElement *new;
new = (struct stDisplayElement *) malloc (sizeof(struct stDisplayElement));
// @@@ put new element at the end of list
if (!__pspgl_actuallist->first)
__pspgl_actuallist->first = new;
if (__pspgl_actuallist->last)
__pspgl_actuallist->last->next = new;
new->next = NULL;
__pspgl_actuallist->last = new;
new->command_num = GLENABLE;
new->parami1 = cap;
new->parami2 = enable;
}
if ((pspgl_curctx->displaylists.is_in_glNewList == GL_COMPILE_AND_EXECUTE)||(pspgl_curctx->displaylists.is_in_glNewList == 0)) {
// @@@ from here it's different, because it's the old function
switch (cap) {
case GL_FOG:
opcode = CMD_ENA_FOG;
break;
case GL_LIGHTING: {
unsigned long c;
opcode = CMD_ENA_LIGHTING;
/* switch material ambient around depending on lighting state */
if (enable)
c = pspgl_curctx->material.ambient;
else
c = pspgl_curctx->current.color;
sendCommandi(CMD_MATERIAL_AMB_C, c);
sendCommandi(CMD_MATERIAL_AMB_A, c>>24);
break;
}
case GL_TEXTURE_2D:
opcode = CMD_ENA_TEXTURE;
break;
case GL_CULL_FACE:
opcode = CMD_ENA_CULL;
break;
case GL_ALPHA_TEST:
opcode = CMD_ENA_ALPHA_TEST;
break;
case GL_BLEND:
opcode = CMD_ENA_BLEND;
break;
case GL_COLOR_LOGIC_OP:
opcode = CMD_ENA_LOGIC;
break;
case GL_DITHER:
opcode = CMD_ENA_DITHER;
break;
case GL_STENCIL_TEST:
opcode = CMD_ENA_STENCIL_TEST;
enable = enable && pspgl_curctx->draw->stencil_mask;
if (enable)
sendCommandi(CMD_ALPHA_MASK, ~pspgl_curctx->write_mask.stencil);
else
sendCommandi(CMD_ALPHA_MASK, ~pspgl_curctx->write_mask.alpha);
break;
case GL_DEPTH_TEST:
opcode = CMD_ENA_DEPTH_TEST;
enable = enable && pspgl_curctx->draw->depth_buffer;
break;
case GL_LIGHT0:
case GL_LIGHT1:
case GL_LIGHT2:
case GL_LIGHT3:
opcode = cap - GL_LIGHT0 + CMD_ENA_LIGHT0;
break;
case GL_LINE_SMOOTH:
case GL_POINT_SMOOTH:
opcode = CMD_ENA_ANTIALIAS; /* XXX : antialiasing. both line and point? */
break;
case GL_SCISSOR_TEST:
pspgl_curctx->scissor_test.enabled = enable;
__pspgl_set_scissor();
return;
case GL_VERTEX_BLEND_PSP:
/* There's no specific enable flag for vertex
blending, but disabling the matricies (=identity)
should have the same effect. */
pspgl_curctx->vertexblend.enabled = enable;
for(i = 0; i < NBONES; i++) {
struct pspgl_matrix_stack *m = &pspgl_curctx->bone_stacks[i];
m->flags = (m->flags & ~MF_DISABLED) |
(enable ? 0 : MF_DISABLED) | MF_DIRTY;
}
break;
case GL_TEXTURE_GEN_S:
case GL_TEXTURE_GEN_T:
/* TODO */
break;
case GL_NORMALIZE:
/* ? */
break;
case GL_COLOR_MATERIAL:
case GL_RESCALE_NORMAL:
case GL_POLYGON_OFFSET_FILL:
case GL_VERTEX_ARRAY:
case GL_NORMAL_ARRAY:
case GL_COLOR_ARRAY:
case GL_TEXTURE_COORD_ARRAY:
case GL_MULTISAMPLE:
case GL_SAMPLE_ALPHA_TO_COVERAGE:
case GL_SAMPLE_ALPHA_TO_ONE:
case GL_SAMPLE_COVERAGE:
default:
GLERROR(GL_INVALID_ENUM);
return;
}
if (opcode)
sendCommandi(opcode, enable);
}
}
void glEnable (GLenum cap)
{
__pspgl_enable_state(cap, 1);
}
void glDisable (GLenum cap)
{
__pspgl_enable_state(cap, 0);
}