/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #pragma ident "%Z%%M% %I% %E% SMI" #pragma D option quiet struct { string str; string substr; int haspos; int position; } command[int]; int i; BEGIN { command[i].str = "foobarbaz"; command[i].substr = "barbaz"; i++; command[i].str = "foofoofoo"; command[i].substr = "foo"; i++; command[i].str = "boofoofoo"; command[i].substr = "foo"; i++; command[i].str = "foobarbaz"; command[i].substr = "barbazzy"; i++; command[i].str = "foobar"; command[i].substr = "foobar"; i++; command[i].str = "foobar"; command[i].substr = "foobarbaz"; i++; command[i].str = ""; command[i].substr = "foobar"; i++; command[i].str = "foobar"; command[i].substr = ""; i++; command[i].str = ""; command[i].substr = ""; i++; command[i].str = "foo"; command[i].substr = ""; i++; end = j = k = 0; printf("#!/usr/bin/perl\n\nBEGIN {\n"); } tick-1ms /j < i && end == 0/ { command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = -400; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = -1; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = 0; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = strlen(command[j].str) / 2; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = strlen(command[j].str); k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = strlen(command[j].str) + 1; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = strlen(command[j].str) + 2; k++; command[i + k].str = command[j].str; command[i + k].substr = command[j].substr; command[i + k].haspos = 1; command[i + k].position = 400; k++; j++; } tick-1ms /j == i && end == 0/ { end = k; i = 0; } tick-1ms /end != 0 && i < end && !command[i].haspos/ { this->result = index(command[i].str, command[i].substr); printf("\tif (index(\"%s\", \"%s\") != %d) {\n", command[i].str, command[i].substr, this->result); printf("\t\tprintf(\"perl => index(\\\"%s\\\", \\\"%s\\\") = ", command[i].str, command[i].substr); printf("%%d\\n\",\n\t\t index(\"%s\", \"%s\"));\n", command[i].str, command[i].substr); printf("\t\tprintf(\" D => index(\\\"%s\\\", \\\"%s\\\") = ", command[i].str, command[i].substr); printf("%d\\n\");\n", this->result); printf("\t\t$failed++;\n"); printf("\t}\n\n"); } tick-1ms /end != 0 && i < end && !command[i].haspos/ { this->result = rindex(command[i].str, command[i].substr); printf("\tif (rindex(\"%s\", \"%s\") != %d) {\n", command[i].str, command[i].substr, this->result); printf("\t\tprintf(\"perl => rindex(\\\"%s\\\", \\\"%s\\\") = ", command[i].str, command[i].substr); printf("%%d\\n\",\n\t\t rindex(\"%s\", \"%s\"));\n", command[i].str, command[i].substr); printf("\t\tprintf(\" D => rindex(\\\"%s\\\", \\\"%s\\\") = ", command[i].str, command[i].substr); printf("%d\\n\");\n", this->result); printf("\t\t$failed++;\n"); printf("\t}\n\n"); } tick-1ms /end != 0 && i < end && command[i].haspos/ { this->result = index(command[i].str, command[i].substr, command[i].position); printf("\tif (index(\"%s\", \"%s\", %d) != %d) {\n", command[i].str, command[i].substr, command[i].position, this->result); printf("\t\tprintf(\"perl => index(\\\"%s\\\", \\\"%s\\\", %d) = ", command[i].str, command[i].substr, command[i].position); printf("%%d\\n\",\n\t\t index(\"%s\", \"%s\", %d));\n", command[i].str, command[i].substr, command[i].position); printf("\t\tprintf(\" D => index(\\\"%s\\\", \\\"%s\\\", %d) = ", command[i].str, command[i].substr, command[i].position); printf("%d\\n\");\n", this->result); printf("\t\t$failed++;\n"); printf("\t}\n\n"); } tick-1ms /end != 0 && i < end && command[i].haspos/ { this->result = rindex(command[i].str, command[i].substr, command[i].position); printf("\tif (rindex(\"%s\", \"%s\", %d) != %d) {\n", command[i].str, command[i].substr, command[i].position, this->result); printf("\t\tprintf(\"perl => rindex(\\\"%s\\\", \\\"%s\\\", %d) = ", command[i].str, command[i].substr, command[i].position); printf("%%d\\n\",\n\t\t rindex(\"%s\", \"%s\", %d));\n", command[i].str, command[i].substr, command[i].position); printf("\t\tprintf(\" D => rindex(\\\"%s\\\", \\\"%s\\\", %d) = ", command[i].str, command[i].substr, command[i].position); printf("%d\\n\");\n", this->result); printf("\t\t$failed++;\n"); printf("\t}\n\n"); } tick-1ms /end != 0 && ++i == end/ { printf("\texit($failed);\n}\n"); exit(0); }