tst.index.d   [plain text]


/*
 * 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	"@(#)tst.index.d	1.1	06/08/28 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/perl5/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);
}