Skip to content

Latest commit

 

History

History
233 lines (208 loc) · 6.98 KB

testparse.c

File metadata and controls

233 lines (208 loc) · 6.98 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
64
printf("PROFILE: %s\n", prof);
if (pd->error != NULL)
Dec 10, 2008
Dec 10, 2008
65
printf("ERROR: (position %d) %s\n", pd->error_position, 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
const char *arrayof = "";
Jul 31, 2008
Jul 31, 2008
144
const char *constant = u->constant ? "const " : "";
May 5, 2008
May 5, 2008
145
146
147
148
149
150
151
152
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
153
154
printf(" * %d: %s%s%s%s", u->index, constant, arrayof,
arrayrange, typenames[(int) u->type]);
Apr 25, 2008
Apr 25, 2008
155
156
157
if (u->name != NULL)
printf(" (\"%s\")", u->name);
printf("\n");
Apr 4, 2008
Apr 4, 2008
158
159
160
} // for
} // else
Apr 19, 2008
Apr 19, 2008
161
162
163
164
165
166
167
168
169
170
171
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
172
173
174
175
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
176
177
178
} // for
} // else
Mar 28, 2008
Mar 28, 2008
179
if (pd->output != NULL)
Apr 6, 2008
Apr 6, 2008
180
181
182
183
184
185
186
{
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
187
} // else
Mar 28, 2008
Mar 28, 2008
188
189
printf("\n\n");
MOJOSHADER_freeParseData(pd);
Apr 19, 2008
Apr 19, 2008
190
191
return retval;
Mar 28, 2008
Mar 28, 2008
192
193
194
} // do_parse
Feb 10, 2008
Feb 10, 2008
195
196
int main(int argc, char **argv)
{
Apr 19, 2008
Apr 19, 2008
197
198
int retval = 0;
Mar 28, 2008
Mar 28, 2008
199
printf("MojoShader testparse\n");
Mar 22, 2008
Mar 22, 2008
200
201
printf("Compiled against version %d\n", MOJOSHADER_VERSION);
printf("Linked against version %d\n", MOJOSHADER_version());
Mar 28, 2008
Mar 28, 2008
202
printf("\n");
Mar 22, 2008
Mar 22, 2008
203
Mar 28, 2008
Mar 28, 2008
204
205
if (argc <= 2)
printf("\n\nUSAGE: %s <profile> [file1] ... [fileN]\n\n", argv[0]);
Mar 28, 2008
Mar 28, 2008
206
else
Feb 10, 2008
Feb 10, 2008
207
{
Mar 28, 2008
Mar 28, 2008
208
209
210
211
const char *profile = argv[1];
int i;
for (i = 2; i < argc; i++)
Feb 10, 2008
Feb 10, 2008
212
{
Mar 28, 2008
Mar 28, 2008
213
214
215
FILE *io = fopen(argv[i], "rb");
printf("FILE: %s\n", argv[i]);
if (io == NULL)
Mar 28, 2008
Mar 28, 2008
216
printf(" ... fopen('%s') failed.\n", argv[i]);
Mar 28, 2008
Mar 28, 2008
217
218
219
220
221
else
{
unsigned char *buf = (unsigned char *) malloc(1000000);
int rc = fread(buf, 1, 1000000, io);
fclose(io);
Apr 19, 2008
Apr 19, 2008
222
223
if (!do_parse(buf, rc, profile))
retval = 1;
Mar 28, 2008
Mar 28, 2008
224
225
226
227
free(buf);
} // else
} // for
} // else
Feb 10, 2008
Feb 10, 2008
228
Apr 19, 2008
Apr 19, 2008
229
return retval;
Feb 10, 2008
Feb 10, 2008
230
231
232
} // main
// end of testparse.c ...