1 /**************************************************************************
3 * Copyright 2009 VMware, Inc.
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 **************************************************************************/
32 #include "../pp/sl_pp_public.h"
42 struct sl_pp_purify_options options
;
44 struct sl_pp_context
*context
;
45 struct sl_pp_token_info
*tokens
;
53 in
= fopen(argv
[1], "rb");
58 fseek(in
, 0, SEEK_END
);
60 fseek(in
, 0, SEEK_SET
);
62 out
= fopen(argv
[2], "wb");
68 inbuf
= malloc(size
+ 1);
70 fprintf(out
, "$OOMERROR\n");
77 if (fread(inbuf
, 1, size
, in
) != size
) {
78 fprintf(out
, "$READERROR\n");
89 memset(&options
, 0, sizeof(options
));
91 if (sl_pp_purify(inbuf
, &options
, &outbuf
)) {
92 fprintf(out
, "$PURIFYERROR\n");
101 context
= sl_pp_context_create();
103 fprintf(out
, "$CONTEXERROR\n");
110 if (sl_pp_tokenise(context
, outbuf
, &tokens
)) {
111 fprintf(out
, "$ERROR: `%s'\n", sl_pp_context_error_message(context
));
113 sl_pp_context_destroy(context
);
121 for (i
= 0; tokens
[i
].token
!= SL_PP_EOF
; i
++) {
122 switch (tokens
[i
].token
) {
123 case SL_PP_WHITESPACE
:
138 case SL_PP_SEMICOLON
:
170 case SL_PP_INCREMENT
:
174 case SL_PP_ADDASSIGN
:
182 case SL_PP_DECREMENT
:
186 case SL_PP_SUBASSIGN
:
206 case SL_PP_MULASSIGN
:
214 case SL_PP_DIVASSIGN
:
222 case SL_PP_MODASSIGN
:
223 fprintf(out
, "%%= ");
230 case SL_PP_LSHIFTASSIGN
:
231 fprintf(out
, "<<= ");
238 case SL_PP_LESSEQUAL
:
246 case SL_PP_RSHIFTASSIGN
:
247 fprintf(out
, ">>= ");
254 case SL_PP_GREATEREQUAL
:
274 case SL_PP_BITANDASSIGN
:
286 case SL_PP_BITXORASSIGN
:
298 case SL_PP_BITORASSIGN
:
314 case SL_PP_IDENTIFIER
:
315 fprintf(out
, "%s ", sl_pp_context_cstr(context
, tokens
[i
].data
.identifier
));
319 fprintf(out
, "(%s) ", sl_pp_context_cstr(context
, tokens
[i
].data
._uint
));
323 fprintf(out
, "(%s) ", sl_pp_context_cstr(context
, tokens
[i
].data
._float
));
327 if (tokens
[i
].data
.other
== '\'') {
328 fprintf(out
, "'\\'' ");
330 fprintf(out
, "'%c' ", tokens
[i
].data
.other
);
339 sl_pp_context_destroy(context
);