Skip to content

Latest commit

 

History

History
241 lines (216 loc) · 7.15 KB

testparse.c

File metadata and controls

241 lines (216 loc) · 7.15 KB
 
Apr 29, 2008
Apr 29, 2008
1
2
3
4
5
6
7
8
9
/**
* MojoShader; generate shader programs from bytecode of compiled
* Direct3D shaders.
*
* Please see the file LICENSE.txt in the source's root directory.
*
* This file written by Ryan C. Gordon.
*/
Feb 10, 2008
Feb 10, 2008
10
#include <stdio.h>
Feb 12, 2008
Feb 12, 2008
11
#include <stdlib.h>
Mar 22, 2008
Mar 22, 2008
12
#include "mojoshader.h"
Feb 10, 2008
Feb 10, 2008
13
Apr 30, 2008
Apr 30, 2008
14
15
16
#ifdef _MSC_VER
#define snprintf _snprintf
#endif
Mar 28, 2008
Mar 28, 2008
17
Mar 28, 2008
Mar 28, 2008
18
#if MOJOSHADER_DEBUG_MALLOC
Mar 28, 2008
Mar 28, 2008
19
20
21
22
23
24
25
26
27
28
29
30
31
static void *Malloc(int len)
{
void *ptr = malloc(len + sizeof (int));
int *store = (int *) ptr;
printf("malloc() %d bytes (%p)\n", len, ptr);
if (ptr == NULL) return NULL;
*store = len;
return (void *) (store + 1);
} // Malloc
static void Free(void *_ptr)
{
Mar 28, 2008
Mar 28, 2008
32
33
int *ptr = (((int *) _ptr) - 1);
int len = *ptr;
Mar 28, 2008
Mar 28, 2008
34
35
36
37
38
39
40
41
printf("free() %d bytes (%p)\n", len, ptr);
free(ptr);
} // Free
#else
#define Malloc NULL
#define Free NULL
#endif
Mar 28, 2008
Mar 28, 2008
42
static const char *shader_type(const MOJOSHADER_shaderType s)
Mar 28, 2008
Mar 28, 2008
43
44
45
46
47
48
49
{
switch (s)
{
case MOJOSHADER_TYPE_UNKNOWN: return "unknown";
case MOJOSHADER_TYPE_PIXEL: return "pixel";
case MOJOSHADER_TYPE_VERTEX: return "vertex";
case MOJOSHADER_TYPE_GEOMETRY: return "geometry";
Mar 28, 2008
Mar 28, 2008
50
default: return "(bogus value?)";
Mar 28, 2008
Mar 28, 2008
51
52
} // switch
Mar 28, 2008
Mar 28, 2008
53
return NULL; // shouldn't hit this.
Mar 28, 2008
Mar 28, 2008
54
55
56
} // shader_type
Apr 19, 2008
Apr 19, 2008
57
static int do_parse(const unsigned char *buf, const int len, const char *prof)
Mar 28, 2008
Mar 28, 2008
58
59
{
const MOJOSHADER_parseData *pd;
Apr 19, 2008
Apr 19, 2008
60
int retval = 0;
Mar 28, 2008
Mar 28, 2008
61
Aug 26, 2008
Aug 26, 2008
62
pd = MOJOSHADER_parse(prof, buf, len, NULL, 0, Malloc, Free, NULL);
Mar 28, 2008
Mar 28, 2008
63
printf("PROFILE: %s\n", prof);
Feb 3, 2009
Feb 3, 2009
64
65
66
67
68
69
70
71
72
73
if (pd->error_count > 0)
{
int i;
for (i = 0; i < pd->error_count; i++)
{
printf("ERROR: (position %d) %s\n",
pd->errors[i].error_position,
pd->errors[i].error);
} // for
} // if
Mar 28, 2008
Mar 28, 2008
74
75
else
{
Apr 19, 2008
Apr 19, 2008
76
retval = 1;
Mar 28, 2008
Mar 28, 2008
77
78
79
printf("SHADER TYPE: %s\n", shader_type(pd->shader_type));
printf("VERSION: %d.%d\n", pd->major_ver, pd->minor_ver);
printf("INSTRUCTION COUNT: %d\n", (int) pd->instruction_count);
Apr 5, 2008
Apr 5, 2008
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
printf("ATTRIBUTES:");
if (pd->attribute_count == 0)
printf(" (none.)\n");
else
{
int i;
printf("\n");
for (i = 0; i < pd->attribute_count; i++)
{
static const char *usagenames[] = {
"position", "blendweight", "blendindices", "normal",
"psize", "texcoord", "tangent", "binormal", "tessfactor",
"positiont", "color", "fog", "depth", "sample"
};
const MOJOSHADER_attribute *a = &pd->attributes[i];
char numstr[16] = { 0 };
if (a->index != 0)
snprintf(numstr, sizeof (numstr), "%d", a->index);
Apr 25, 2008
Apr 25, 2008
99
100
101
102
printf(" * %s%s", usagenames[(int) a->usage], numstr);
if (a->name != NULL)
printf(" (\"%s\")", a->name);
printf("\n");
Apr 5, 2008
Apr 5, 2008
103
104
105
} // for
} // else
May 3, 2008
May 3, 2008
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
printf("CONSTANTS:");
if (pd->constant_count == 0)
printf(" (none.)\n");
else
{
int i;
printf("\n");
for (i = 0; i < pd->constant_count; i++)
{
static const char *typenames[] = { "float", "int", "bool" };
const MOJOSHADER_constant *c = &pd->constants[i];
printf(" * %d: %s (", c->index, typenames[(int) c->type]);
if (c->type == MOJOSHADER_UNIFORM_FLOAT)
{
printf("%f %f %f %f", c->value.f[0], c->value.f[1],
c->value.f[2], c->value.f[3]);
} // if
else if (c->type == MOJOSHADER_UNIFORM_INT)
{
printf("%d %d %d %d", c->value.i[0], c->value.i[1],
c->value.i[2], c->value.i[3]);
} // else if
else if (c->type == MOJOSHADER_UNIFORM_BOOL)
{
printf("%s", c->value.b ? "true" : "false");
} // else if
else
{
printf("???");
} // else
printf(")\n");
} // for
} // else
Apr 4, 2008
Apr 4, 2008
140
141
142
143
144
145
146
147
148
printf("UNIFORMS:");
if (pd->uniform_count == 0)
printf(" (none.)\n");
else
{
int i;
printf("\n");
for (i = 0; i < pd->uniform_count; i++)
{
Apr 4, 2008
Apr 4, 2008
149
static const char *typenames[] = { "float", "int", "bool" };
Apr 4, 2008
Apr 4, 2008
150
const MOJOSHADER_uniform *u = &pd->uniforms[i];
May 5, 2008
May 5, 2008
151
const char *arrayof = "";
Jul 31, 2008
Jul 31, 2008
152
const char *constant = u->constant ? "const " : "";
May 5, 2008
May 5, 2008
153
154
155
156
157
158
159
160
char arrayrange[64] = { '\0' };
if (u->array_count > 0)
{
arrayof = "array[";
snprintf(arrayrange, sizeof (arrayrange), "%d] ",
u->array_count);
} // if
Jul 31, 2008
Jul 31, 2008
161
162
printf(" * %d: %s%s%s%s", u->index, constant, arrayof,
arrayrange, typenames[(int) u->type]);
Apr 25, 2008
Apr 25, 2008
163
164
165
if (u->name != NULL)
printf(" (\"%s\")", u->name);
printf("\n");
Apr 4, 2008
Apr 4, 2008
166
167
168
} // for
} // else
Apr 19, 2008
Apr 19, 2008
169
170
171
172
173
174
175
176
177
178
179
printf("SAMPLERS:");
if (pd->sampler_count == 0)
printf(" (none.)\n");
else
{
int i;
printf("\n");
for (i = 0; i < pd->sampler_count; i++)
{
static const char *typenames[] = { "2d", "cube", "volume" };
const MOJOSHADER_sampler *s = &pd->samplers[i];
Apr 25, 2008
Apr 25, 2008
180
181
182
183
printf(" * %d: %s", s->index, typenames[(int) s->type]);
if (s->name != NULL)
printf(" (\"%s\")", s->name);
printf("\n");
Apr 19, 2008
Apr 19, 2008
184
185
186
} // for
} // else
Mar 28, 2008
Mar 28, 2008
187
if (pd->output != NULL)
Apr 6, 2008
Apr 6, 2008
188
189
190
191
192
193
194
{
int i;
printf("OUTPUT:\n");
for (i = 0; i < pd->output_len; i++)
putchar((int) pd->output[i]);
printf("\n");
} // if
Mar 28, 2008
Mar 28, 2008
195
} // else
Mar 28, 2008
Mar 28, 2008
196
197
printf("\n\n");
MOJOSHADER_freeParseData(pd);
Apr 19, 2008
Apr 19, 2008
198
199
return retval;
Mar 28, 2008
Mar 28, 2008
200
201
202
} // do_parse
Feb 10, 2008
Feb 10, 2008
203
204
int main(int argc, char **argv)
{
Apr 19, 2008
Apr 19, 2008
205
206
int retval = 0;
Mar 28, 2008
Mar 28, 2008
207
printf("MojoShader testparse\n");
Mar 22, 2008
Mar 22, 2008
208
209
printf("Compiled against version %d\n", MOJOSHADER_VERSION);
printf("Linked against version %d\n", MOJOSHADER_version());
Mar 28, 2008
Mar 28, 2008
210
printf("\n");
Mar 22, 2008
Mar 22, 2008
211
Mar 28, 2008
Mar 28, 2008
212
213
if (argc <= 2)
printf("\n\nUSAGE: %s <profile> [file1] ... [fileN]\n\n", argv[0]);
Mar 28, 2008
Mar 28, 2008
214
else
Feb 10, 2008
Feb 10, 2008
215
{
Mar 28, 2008
Mar 28, 2008
216
217
218
219
const char *profile = argv[1];
int i;
for (i = 2; i < argc; i++)
Feb 10, 2008
Feb 10, 2008
220
{
Mar 28, 2008
Mar 28, 2008
221
222
223
FILE *io = fopen(argv[i], "rb");
printf("FILE: %s\n", argv[i]);
if (io == NULL)
Mar 28, 2008
Mar 28, 2008
224
printf(" ... fopen('%s') failed.\n", argv[i]);
Mar 28, 2008
Mar 28, 2008
225
226
227
228
229
else
{
unsigned char *buf = (unsigned char *) malloc(1000000);
int rc = fread(buf, 1, 1000000, io);
fclose(io);
Apr 19, 2008
Apr 19, 2008
230
231
if (!do_parse(buf, rc, profile))
retval = 1;
Mar 28, 2008
Mar 28, 2008
232
233
234
235
free(buf);
} // else
} // for
} // else
Feb 10, 2008
Feb 10, 2008
236
Apr 19, 2008
Apr 19, 2008
237
return retval;
Feb 10, 2008
Feb 10, 2008
238
239
240
} // main
// end of testparse.c ...