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