Skip to content

Latest commit

 

History

History
185 lines (162 loc) · 5.17 KB

testparse.c

File metadata and controls

185 lines (162 loc) · 5.17 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
Mar 28, 2008
Mar 28, 2008
14
Mar 28, 2008
Mar 28, 2008
15
#if MOJOSHADER_DEBUG_MALLOC
Mar 28, 2008
Mar 28, 2008
16
17
18
19
20
21
22
23
24
25
26
27
28
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
29
30
int *ptr = (((int *) _ptr) - 1);
int len = *ptr;
Mar 28, 2008
Mar 28, 2008
31
32
33
34
35
36
37
38
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
39
static const char *shader_type(const MOJOSHADER_shaderType s)
Mar 28, 2008
Mar 28, 2008
40
41
42
43
44
45
46
{
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
47
default: return "(bogus value?)";
Mar 28, 2008
Mar 28, 2008
48
49
} // switch
Mar 28, 2008
Mar 28, 2008
50
return NULL; // shouldn't hit this.
Mar 28, 2008
Mar 28, 2008
51
52
53
} // shader_type
Apr 19, 2008
Apr 19, 2008
54
static int do_parse(const unsigned char *buf, const int len, const char *prof)
Mar 28, 2008
Mar 28, 2008
55
56
{
const MOJOSHADER_parseData *pd;
Apr 19, 2008
Apr 19, 2008
57
int retval = 0;
Mar 28, 2008
Mar 28, 2008
58
Apr 4, 2008
Apr 4, 2008
59
pd = MOJOSHADER_parse(prof, buf, len, Malloc, Free, NULL);
Mar 28, 2008
Mar 28, 2008
60
61
62
printf("PROFILE: %s\n", prof);
if (pd->error != NULL)
printf("ERROR: %s\n", pd->error);
Mar 28, 2008
Mar 28, 2008
63
64
else
{
Apr 19, 2008
Apr 19, 2008
65
retval = 1;
Mar 28, 2008
Mar 28, 2008
66
67
68
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
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
88
89
90
91
printf(" * %s%s", usagenames[(int) a->usage], numstr);
if (a->name != NULL)
printf(" (\"%s\")", a->name);
printf("\n");
Apr 5, 2008
Apr 5, 2008
92
93
94
} // for
} // else
Apr 4, 2008
Apr 4, 2008
95
96
97
98
99
100
101
102
103
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
104
static const char *typenames[] = { "float", "int", "bool" };
Apr 4, 2008
Apr 4, 2008
105
const MOJOSHADER_uniform *u = &pd->uniforms[i];
Apr 25, 2008
Apr 25, 2008
106
107
108
109
printf(" * %d: %s", u->index, typenames[(int) u->type]);
if (u->name != NULL)
printf(" (\"%s\")", u->name);
printf("\n");
Apr 4, 2008
Apr 4, 2008
110
111
112
} // for
} // else
Apr 19, 2008
Apr 19, 2008
113
114
115
116
117
118
119
120
121
122
123
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
124
125
126
127
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
128
129
130
} // for
} // else
Mar 28, 2008
Mar 28, 2008
131
if (pd->output != NULL)
Apr 6, 2008
Apr 6, 2008
132
133
134
135
136
137
138
{
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
139
} // else
Mar 28, 2008
Mar 28, 2008
140
141
printf("\n\n");
MOJOSHADER_freeParseData(pd);
Apr 19, 2008
Apr 19, 2008
142
143
return retval;
Mar 28, 2008
Mar 28, 2008
144
145
146
} // do_parse
Feb 10, 2008
Feb 10, 2008
147
148
int main(int argc, char **argv)
{
Apr 19, 2008
Apr 19, 2008
149
150
int retval = 0;
Mar 28, 2008
Mar 28, 2008
151
printf("MojoShader testparse\n");
Mar 22, 2008
Mar 22, 2008
152
153
printf("Compiled against version %d\n", MOJOSHADER_VERSION);
printf("Linked against version %d\n", MOJOSHADER_version());
Mar 28, 2008
Mar 28, 2008
154
printf("\n");
Mar 22, 2008
Mar 22, 2008
155
Mar 28, 2008
Mar 28, 2008
156
157
if (argc <= 2)
printf("\n\nUSAGE: %s <profile> [file1] ... [fileN]\n\n", argv[0]);
Mar 28, 2008
Mar 28, 2008
158
else
Feb 10, 2008
Feb 10, 2008
159
{
Mar 28, 2008
Mar 28, 2008
160
161
162
163
const char *profile = argv[1];
int i;
for (i = 2; i < argc; i++)
Feb 10, 2008
Feb 10, 2008
164
{
Mar 28, 2008
Mar 28, 2008
165
166
167
FILE *io = fopen(argv[i], "rb");
printf("FILE: %s\n", argv[i]);
if (io == NULL)
Mar 28, 2008
Mar 28, 2008
168
printf(" ... fopen('%s') failed.\n", argv[i]);
Mar 28, 2008
Mar 28, 2008
169
170
171
172
173
else
{
unsigned char *buf = (unsigned char *) malloc(1000000);
int rc = fread(buf, 1, 1000000, io);
fclose(io);
Apr 19, 2008
Apr 19, 2008
174
175
if (!do_parse(buf, rc, profile))
retval = 1;
Mar 28, 2008
Mar 28, 2008
176
177
178
179
free(buf);
} // else
} // for
} // else
Feb 10, 2008
Feb 10, 2008
180
Apr 19, 2008
Apr 19, 2008
181
return retval;
Feb 10, 2008
Feb 10, 2008
182
183
184
} // main
// end of testparse.c ...