Skip to content

Latest commit

 

History

History
232 lines (207 loc) · 6.86 KB

testparse.c

File metadata and controls

232 lines (207 loc) · 6.86 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
Apr 4, 2008
Apr 4, 2008
62
pd = MOJOSHADER_parse(prof, buf, len, Malloc, Free, NULL);
Mar 28, 2008
Mar 28, 2008
63
64
65
printf("PROFILE: %s\n", prof);
if (pd->error != NULL)
printf("ERROR: %s\n", pd->error);
Mar 28, 2008
Mar 28, 2008
66
67
else
{
Apr 19, 2008
Apr 19, 2008
68
retval = 1;
Mar 28, 2008
Mar 28, 2008
69
70
71
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
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
91
92
93
94
printf(" * %s%s", usagenames[(int) a->usage], numstr);
if (a->name != NULL)
printf(" (\"%s\")", a->name);
printf("\n");
Apr 5, 2008
Apr 5, 2008
95
96
97
} // for
} // else
May 3, 2008
May 3, 2008
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
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
132
133
134
135
136
137
138
139
140
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
141
static const char *typenames[] = { "float", "int", "bool" };
Apr 4, 2008
Apr 4, 2008
142
const MOJOSHADER_uniform *u = &pd->uniforms[i];
May 5, 2008
May 5, 2008
143
144
145
146
147
148
149
150
151
152
153
const char *arrayof = "";
char arrayrange[64] = { '\0' };
if (u->array_count > 0)
{
arrayof = "array[";
snprintf(arrayrange, sizeof (arrayrange), "%d] ",
u->array_count);
} // if
printf(" * %d: %s%s%s", u->index, arrayof, arrayrange,
typenames[(int) u->type]);
Apr 25, 2008
Apr 25, 2008
154
155
156
if (u->name != NULL)
printf(" (\"%s\")", u->name);
printf("\n");
Apr 4, 2008
Apr 4, 2008
157
158
159
} // for
} // else
Apr 19, 2008
Apr 19, 2008
160
161
162
163
164
165
166
167
168
169
170
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
171
172
173
174
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
175
176
177
} // for
} // else
Mar 28, 2008
Mar 28, 2008
178
if (pd->output != NULL)
Apr 6, 2008
Apr 6, 2008
179
180
181
182
183
184
185
{
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
186
} // else
Mar 28, 2008
Mar 28, 2008
187
188
printf("\n\n");
MOJOSHADER_freeParseData(pd);
Apr 19, 2008
Apr 19, 2008
189
190
return retval;
Mar 28, 2008
Mar 28, 2008
191
192
193
} // do_parse
Feb 10, 2008
Feb 10, 2008
194
195
int main(int argc, char **argv)
{
Apr 19, 2008
Apr 19, 2008
196
197
int retval = 0;
Mar 28, 2008
Mar 28, 2008
198
printf("MojoShader testparse\n");
Mar 22, 2008
Mar 22, 2008
199
200
printf("Compiled against version %d\n", MOJOSHADER_VERSION);
printf("Linked against version %d\n", MOJOSHADER_version());
Mar 28, 2008
Mar 28, 2008
201
printf("\n");
Mar 22, 2008
Mar 22, 2008
202
Mar 28, 2008
Mar 28, 2008
203
204
if (argc <= 2)
printf("\n\nUSAGE: %s <profile> [file1] ... [fileN]\n\n", argv[0]);
Mar 28, 2008
Mar 28, 2008
205
else
Feb 10, 2008
Feb 10, 2008
206
{
Mar 28, 2008
Mar 28, 2008
207
208
209
210
const char *profile = argv[1];
int i;
for (i = 2; i < argc; i++)
Feb 10, 2008
Feb 10, 2008
211
{
Mar 28, 2008
Mar 28, 2008
212
213
214
FILE *io = fopen(argv[i], "rb");
printf("FILE: %s\n", argv[i]);
if (io == NULL)
Mar 28, 2008
Mar 28, 2008
215
printf(" ... fopen('%s') failed.\n", argv[i]);
Mar 28, 2008
Mar 28, 2008
216
217
218
219
220
else
{
unsigned char *buf = (unsigned char *) malloc(1000000);
int rc = fread(buf, 1, 1000000, io);
fclose(io);
Apr 19, 2008
Apr 19, 2008
221
222
if (!do_parse(buf, rc, profile))
retval = 1;
Mar 28, 2008
Mar 28, 2008
223
224
225
226
free(buf);
} // else
} // for
} // else
Feb 10, 2008
Feb 10, 2008
227
Apr 19, 2008
Apr 19, 2008
228
return retval;
Feb 10, 2008
Feb 10, 2008
229
230
231
} // main
// end of testparse.c ...