Blob Blame History Raw
/* strsearch.c
 *
 * Copyright (c) Chris Putnam 1995-2018
 *
 * Source code released under the GPL version 2
 *
 * strsearch() locates a case-independent substring
 *    e.g. a case-independent version of strstr()
 *
 * returns pointer to first occurrence of substring needle in
 * the string haystack when found, NULL if not found
 *
 * '\0' characters terminating strings are not compared
 *
 * strsearch returns haystack when needle is empty as per strstr()
 * conventions
 *
 */
#include <stdio.h>
#include <ctype.h>
#include "strsearch.h"

char *strsearch (const char *haystack, const char *needle)
{
	char *returnptr=NULL;
	unsigned long pos=0;

	if ( !(*needle) ) returnptr = (char *) haystack;

	while (*(haystack+pos) && returnptr==NULL) {
		if ( toupper((unsigned char)*(haystack+pos)) == toupper((unsigned char)*(needle+pos)) )
			pos++;
		else {
			pos = 0;
			haystack++;
		}
		if ( ! (*(needle+pos)) ) returnptr = (char *) haystack;
	}
	return returnptr;
}