File: icast.c

package info (click to toggle)
icmake 6.30-3
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 2,360 kB
  • ctags: 1,415
  • sloc: ansic: 7,727; makefile: 1,465; sh: 244; asm: 126; cpp: 39
file content (33 lines) | stat: -rw-r--r-- 852 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/*
                                    I C A S T . C
*/

#include "iccomp.h"

ESTRUC_ *icast(e)
    ESTRUC_
        *e;
{
    if (test_type(e, e_list))               /* (int)list not ok */
    {
        semantic(illegal_cast);
        discard(e);
        set_type(e, e_int | e_const);
    }
    else if (test_type(e, e_str))           /* (int)string ok */
    {
        if (test_type(e, e_const))          /* string const to a */
        {
            e->evalue =                      /* convert to string */
                atoi(stringtab[e->evalue].string);
            set_type(e, e_const | e_int);
        }
        else
        {
            etoc(e);                        /* convert to code */
            gencode(e, op_atoi);            /* runtime conversion needed */
            set_type(e, e_int | e_code);
        }
    }
    return (e);
}