1*9512fe85Sahl /*
2*9512fe85Sahl  * CDDL HEADER START
3*9512fe85Sahl  *
4*9512fe85Sahl  * The contents of this file are subject to the terms of the
5*9512fe85Sahl  * Common Development and Distribution License (the "License").
6*9512fe85Sahl  * You may not use this file except in compliance with the License.
7*9512fe85Sahl  *
8*9512fe85Sahl  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9*9512fe85Sahl  * or http://www.opensolaris.org/os/licensing.
10*9512fe85Sahl  * See the License for the specific language governing permissions
11*9512fe85Sahl  * and limitations under the License.
12*9512fe85Sahl  *
13*9512fe85Sahl  * When distributing Covered Code, include this CDDL HEADER in each
14*9512fe85Sahl  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15*9512fe85Sahl  * If applicable, add the following below this CDDL HEADER, with the
16*9512fe85Sahl  * fields enclosed by brackets "[]" replaced with your own identifying
17*9512fe85Sahl  * information: Portions Copyright [yyyy] [name of copyright owner]
18*9512fe85Sahl  *
19*9512fe85Sahl  * CDDL HEADER END
20*9512fe85Sahl  */
21*9512fe85Sahl 
22*9512fe85Sahl /*
23*9512fe85Sahl  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
24*9512fe85Sahl  * Use is subject to license terms.
25*9512fe85Sahl  */
26*9512fe85Sahl 
27*9512fe85Sahl /*
28*9512fe85Sahl  * Test the code generation and results of the various kinds of inlines.
29*9512fe85Sahl  * In particular, we test constant and expression-based scalar inlines,
30*9512fe85Sahl  * associative array inlines, and inlines using translators.
31*9512fe85Sahl  */
32*9512fe85Sahl 
33*9512fe85Sahl #pragma D option quiet
34*9512fe85Sahl 
35*9512fe85Sahl inline int i0 = 100 + 23;		/* constant-folded integer constant */
36*9512fe85Sahl inline string i1 = probename;		/* string variable reference */
37*9512fe85Sahl inline int i2 = pid != 0;		/* expression involving a variable */
38*9512fe85Sahl 
39*9512fe85Sahl struct s {
40*9512fe85Sahl 	int s_x;
41*9512fe85Sahl };
42*9512fe85Sahl 
43*9512fe85Sahl translator struct s < int T > {
44*9512fe85Sahl 	s_x = T + 1;
45*9512fe85Sahl };
46*9512fe85Sahl 
47*9512fe85Sahl inline struct s i3 = xlate < struct s > (i0);		/* translator */
48*9512fe85Sahl inline int i4[int x, int y] = x + y;			/* associative array */
49*9512fe85Sahl inline int i5[int x] = (xlate < struct s > (x)).s_x;	/* array by xlate */
50*9512fe85Sahl 
51*9512fe85Sahl BEGIN
52*9512fe85Sahl {
53*9512fe85Sahl 	printf("i0 = %d\n", i0);
54*9512fe85Sahl 	printf("i1 = %s\n", i1);
55*9512fe85Sahl 	printf("i2 = %d\n", i2);
56*9512fe85Sahl 
57*9512fe85Sahl 	printf("i3.s_x = %d\n", i3.s_x);
58*9512fe85Sahl 	printf("i4[10, 20] = %d\n", i4[10, 20]);
59*9512fe85Sahl 	printf("i5[123] = %d\n", i5[123]);
60*9512fe85Sahl 
61*9512fe85Sahl 	exit(0);
62*9512fe85Sahl }
63