Quick Search:

View

Revision:
Expand:  
Changeset: MAIN:ragge:20030730112747

Diff

Diff from 1.28 to:

Annotations

Annotate by Age | Author | Mixed | None
/fisheye/browse/pcc/pcc/mip/manifest.h

Annotated File View

ragge
1.28
1 /*      $Id: manifest.h,v 1.28 2003/07/30 11:27:47 ragge Exp $  */
2 /*
3  * Copyright(C) Caldera International Inc. 2001-2002. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * Redistributions of source code and documentation must retain the above
10  * copyright notice, this list of conditions and the following disclaimer.
11  * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditionsand the following disclaimer in the
13  * documentation and/or other materials provided with the distribution.
14  * All advertising materials mentioning features or use of this software
15  * must display the following acknowledgement:
16  *      This product includes software developed or owned by Caldera
17  *      International, Inc.
18  * Neither the name of Caldera International, Inc. nor the names of other
19  * contributors may be used to endorse or promote products derived from
20  * this software without specific prior written permission.
21  *
22  * USE OF THE SOFTWARE PROVIDED FOR UNDER THIS LICENSE BY CALDERA
23  * INTERNATIONAL, INC. AND CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR
24  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
25  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26  * DISCLAIMED.  IN NO EVENT SHALL CALDERA INTERNATIONAL, INC. BE LIABLE
27  * FOR ANY DIRECT, INDIRECT INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OFLIABILITY, WHETHER IN CONTRACT,
31  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
32  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
33  * POSSIBILITY OF SUCH DAMAGE.
34  */
ragge
1.1
35
36 #ifndef _MANIFEST_
37 #define _MANIFEST_
38
39 #include <stdio.h>
ragge
1.11
40 #include "node.h"
ragge
1.20
41 #include "main.h"
ragge
1.1
42
43 /*
44  * Node types
45  */
46 #define LTYPE   02              /* leaf */
47 #define UTYPE   04              /* unary */
48 #define BITYPE  010             /* binary */
49
50 /*
ragge
1.28
51  * DSIZE is the size of the dope array
52  */
53 #define DSIZE   (MAXOP+1)
54
55 /*
56  * Type names, used in symbol table building.
57  * The order of the integer types are important.
58  */
59 #define UNDEF           0
60 #define FARG            1       /* function argument */
61 #define CHAR            2
62 #define UCHAR           3
63 #define SHORT           4
64 #define USHORT          5
65 #define INT             6
66 #define UNSIGNED        7
67 #define LONG            8
68 #define ULONG           9      
69 #define LONGLONG        10
70 #define ULONGLONG       11
71 #define FLOAT           12
72 #define DOUBLE          13
73 #define LDOUBLE         14
74 #define STRTY           15
75 #define UNIONTY         16
76 #define ENUMTY          17
77 #define MOETY           18      /* member of enum */
78 #define VOID            19
79 /*
80  * The following are only used in pass1, for simplicity.
81  */
82 #define SIGNED          20
83 #define CONST           21
84 #define VOLATILE        22
85
86 /*
87  * Various flags
88  */
89 #define NOLAB   (-1)
90
91 /* 
92  * Type modifiers.
ragge
1.1
93  */
ragge
1.28
94 #define PTR             0x20
95 #define FTN             0x40
96 #define ARY             0x60
ragge
1.1
97
98 /*
99  * Type packing constants
100  */
ragge
1.28
101 #define TMASK   0x60
102 #define TMASK1  0x180
103 #define TMASK2  0x1e0
104 #define BTMASK  0x1f
105 #define BTSHIFT 5
106 #define TSHIFT  2
ragge
1.1
107
108 /*
ragge
1.28
109  * Macros
ragge
1.1
110  */
111 #define MODTYPE(x,y)    x = ((x)&(~BTMASK))|(y) /* set basic type of x to y */
112 #define BTYPE(x)        ((x)&BTMASK)            /* basic type of x */
ragge
1.9
113 #define ISLONGLONG(x)   ((x) == LONGLONG || (x) == ULONGLONG)
ragge
1.24
114 #define ISUNSIGNED(x)   (((x) & 1) == (UNSIGNED & 1))
115 #define UNSIGNABLE(x)   (((x)<=ULONGLONG&&(x)>=CHAR) && !ISUNSIGNED(x))
116 #define ENUNSIGN(x)     ((x)+1)
117 #define DEUNSIGN(x)     ((x)-1)
ragge
1.1
118 #define ISPTR(x)        (((x)&TMASK)==PTR)
119 #define ISFTN(x)        (((x)&TMASK)==FTN)      /* is x a function type */
120 #define ISARY(x)        (((x)&TMASK)==ARY)      /* is x an array type */
121 #define INCREF(x)       ((((x)&~BTMASK)<<TSHIFT)|PTR|((x)&BTMASK))
122 #define DECREF(x)       ((((x)>>TSHIFT)&~BTMASK)|( (x)&BTMASK))
123 #define SETOFF(x,y)     if ((x)%(y) != 0) (x) = (((x)/(y) + 1) * (y))
ragge
1.28
124                 /* advance x to a multiple of y */
ragge
1.1
125 #define NOFIT(x,y,z)    (((x)%(z) + (y)) > (z))
ragge
1.28
126                 /* can y bits be added to x without overflowing z */
ragge
1.1
127
128 /*
129  * Pack and unpack field descriptors (size and offset)
130  */
131 #define PKFIELD(s,o)    (((o)<<6)| (s))
ragge
1.28
132 #define UPKFSZ(v)       ((v)&077)
ragge
1.1
133 #define UPKFOFF(v)      ((v)>>6)
134
135 /*
136  * Operator information
137  */
138 #define TYFLG   016
139 #define ASGFLG  01
140 #define LOGFLG  020
141
142 #define SIMPFLG 040
143 #define COMMFLG 0100
144 #define DIVFLG  0200
145 #define FLOFLG  0400
146 #define LTYFLG  01000
147 #define CALLFLG 02000
148 #define MULFLG  04000
149 #define SHFFLG  010000
150 #define ASGOPFLG 020000
151
152 #define SPFLG   040000
153
ragge
1.8
154 /*
ragge
1.28
155  * Table sizes.
ragge
1.8
156  */
ragge
1.28
157 #define TREESZ  20000           /* space for building parse tree */
158 #define SWITSZ  1000            /* size of switch table */
ragge
1.1
159
160 /*
ragge
1.21
161  * Location counters
162  */
163 #define PROG            0               /* program segment */
164 #define DATA            1               /* data segment */
165 #define ADATA           2               /* array data segment */
166 #define STRNG           3               /* string data segment */
167 #define ISTRNG          4               /* initialized string segment */
168 #define STAB            5               /* symbol table segment */
169
170
171 /*
ragge
1.1
172  * External declarations, typedefs and the like
173  */
ragge
1.2
174 char    *hash(char *s);
175 char    *savestr(char *cp);
176 char    *tstr(char *cp);
ragge
1.1
177
ragge
1.13
178 /* memory management */
179 void *permalloc(int size);
180 void *tmpalloc(int size);
181 void tmpfree(void);
182
ragge
1.19
183 /* pass t communication subroutines */
ragge
1.20
184 void topt_compile(struct interpass *);
ragge
1.19
185
186 /* pass 2 communication subroutines */
ragge
1.20
187 void pass2_compile(struct interpass *);
ragge
1.18
188
ragge
1.22
189 /* node routines */
190 void nfree(NODE *);
191
ragge
1.1
192 extern  int nerrors;            /* number of errors seen so far */
193 #endif
FishEye: Open Source License registered to PCC.
Your maintenance has expired. You can renew your license at http://www.atlassian.com/fisheye/renew
Atlassian FishEye, CVS analysis. (Version:1.6.3 Build:build-336 2008-11-04) - Administration - Page generated 2014-10-31 20:16 +0100