Skip to content

Latest commit

 

History

History
243 lines (218 loc) · 7.27 KB

testparse.c

File metadata and controls

243 lines (218 loc) · 7.27 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
Mar 24, 2010
Mar 24, 2010
57
58
static int do_parse(const char *fname, const unsigned char *buf,
const int len, const char *prof)
Mar 28, 2008
Mar 28, 2008
59
60
{
const MOJOSHADER_parseData *pd;
Apr 19, 2008
Apr 19, 2008
61
int retval = 0;
Mar 28, 2008
Mar 28, 2008
62
Aug 26, 2008
Aug 26, 2008
63
pd = MOJOSHADER_parse(prof, buf, len, NULL, 0, Malloc, Free, NULL);
Mar 28, 2008
Mar 28, 2008
64
printf("PROFILE: %s\n", prof);
Feb 3, 2009
Feb 3, 2009
65
66
67
68
69
if (pd->error_count > 0)
{
int i;
for (i = 0; i < pd->error_count; i++)
{
Feb 12, 2009
Feb 12, 2009
70
printf("%s:%d: ERROR: %s\n",
Mar 24, 2010
Mar 24, 2010
71
pd->errors[i].filename ? pd->errors[i].filename : fname,
Feb 3, 2009
Feb 3, 2009
72
73
74
75
pd->errors[i].error_position,
pd->errors[i].error);
} // for
} // if
Mar 28, 2008
Mar 28, 2008
76
77
else
{
Apr 19, 2008
Apr 19, 2008
78
retval = 1;
Mar 28, 2008
Mar 28, 2008
79
80
81
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
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
101
102
103
104
printf(" * %s%s", usagenames[(int) a->usage], numstr);
if (a->name != NULL)
printf(" (\"%s\")", a->name);
printf("\n");
Apr 5, 2008
Apr 5, 2008
105
106
107
} // for
} // else
May 3, 2008
May 3, 2008
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
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
142
143
144
145
146
147
148
149
150
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
151
static const char *typenames[] = { "float", "int", "bool" };
Apr 4, 2008
Apr 4, 2008
152
const MOJOSHADER_uniform *u = &pd->uniforms[i];
May 5, 2008
May 5, 2008
153
const char *arrayof = "";
Jul 31, 2008
Jul 31, 2008
154
const char *constant = u->constant ? "const " : "";
May 5, 2008
May 5, 2008
155
156
157
158
159
160
161
162
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
163
164
printf(" * %d: %s%s%s%s", u->index, constant, arrayof,
arrayrange, typenames[(int) u->type]);
Apr 25, 2008
Apr 25, 2008
165
166
167
if (u->name != NULL)
printf(" (\"%s\")", u->name);
printf("\n");
Apr 4, 2008
Apr 4, 2008
168
169
170
} // for
} // else
Apr 19, 2008
Apr 19, 2008
171
172
173
174
175
176
177
178
179
180
181
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
182
183
184
185
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
186
187
188
} // for
} // else
Mar 28, 2008
Mar 28, 2008
189
if (pd->output != NULL)
Apr 6, 2008
Apr 6, 2008
190
191
192
193
194
195
196
{
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
197
} // else
Mar 28, 2008
Mar 28, 2008
198
199
printf("\n\n");
MOJOSHADER_freeParseData(pd);
Apr 19, 2008
Apr 19, 2008
200
201
return retval;
Mar 28, 2008
Mar 28, 2008
202
203
204
} // do_parse
Feb 10, 2008
Feb 10, 2008
205
206
int main(int argc, char **argv)
{
Apr 19, 2008
Apr 19, 2008
207
208
int retval = 0;
Mar 28, 2008
Mar 28, 2008
209
printf("MojoShader testparse\n");
Mar 24, 2010
Mar 24, 2010
210
211
printf("Compiled against changeset %s\n", MOJOSHADER_CHANGESET);
printf("Linked against changeset %s\n", MOJOSHADER_changeset());
Mar 28, 2008
Mar 28, 2008
212
printf("\n");
Mar 22, 2008
Mar 22, 2008
213
Mar 28, 2008
Mar 28, 2008
214
215
if (argc <= 2)
printf("\n\nUSAGE: %s <profile> [file1] ... [fileN]\n\n", argv[0]);
Mar 28, 2008
Mar 28, 2008
216
else
Feb 10, 2008
Feb 10, 2008
217
{
Mar 28, 2008
Mar 28, 2008
218
219
220
221
const char *profile = argv[1];
int i;
for (i = 2; i < argc; i++)
Feb 10, 2008
Feb 10, 2008
222
{
Mar 28, 2008
Mar 28, 2008
223
224
225
FILE *io = fopen(argv[i], "rb");
printf("FILE: %s\n", argv[i]);
if (io == NULL)
Mar 28, 2008
Mar 28, 2008
226
printf(" ... fopen('%s') failed.\n", argv[i]);
Mar 28, 2008
Mar 28, 2008
227
228
229
230
231
else
{
unsigned char *buf = (unsigned char *) malloc(1000000);
int rc = fread(buf, 1, 1000000, io);
fclose(io);
Mar 24, 2010
Mar 24, 2010
232
if (!do_parse(argv[i], buf, rc, profile))
Apr 19, 2008
Apr 19, 2008
233
retval = 1;
Mar 28, 2008
Mar 28, 2008
234
235
236
237
free(buf);
} // else
} // for
} // else
Feb 10, 2008
Feb 10, 2008
238
Apr 19, 2008
Apr 19, 2008
239
return retval;
Feb 10, 2008
Feb 10, 2008
240
241
242
} // main
// end of testparse.c ...